The primary computational method used in numerical algebraic geometry is homotopy continuation, in which a homotopy is formed between two polynomial systems, and the isolated solutions (points) of one are continued to the other. This is a specialization of the more general method of numerical continuation.
Let represent the variables of the system. By abuse of notation, and to facilitate the spectrum of ambient spaces over which one can solve the system, we do not use vector notation for . Similarly for the polynomial systems and .
Current canonical notation calls the start system , and the target system, i.e., the system to solve, .[4][5] A very common homotopy, the straight-line homotopy, between and is
In the above homotopy, one starts the path variable at and continues toward . Another common choice is to run from to . In principle, the choice is completely arbitrary. In practice, regarding endgame methods for computing singular solutions using homotopy continuation, the target time being can significantly ease analysis, so this perspective is here taken.[6]
Regardless of the choice of start and target times, the ought to be formulated such that , and .
One has a choice in , including
Roots of unity
Total degree
Polyhedral
Multi-homogeneous
and beyond these, specific start systems that closely mirror the structure of may be formed for particular systems. The choice of start system impacts the computational time it takes to solve , in that those that are easy to formulate (such as total degree) tend to have higher numbers of paths to track, and those that take significant effort (such as the polyhedral method) are much sharper. There is currently no good way to predict which will lead to the quickest time to solve.[citation needed]
Actual continuation is typically done using predictor–corrector methods, with additional features as implemented. Predicting is done using a standard ODE predictor method, such as Runge–Kutta, and correction often uses Newton–Raphson iteration.
Because and are polynomial, homotopy continuation in this context is theoretically guaranteed to compute all solutions of , due to Bertini's theorem. However, this guarantee is not always achieved in practice, because of issues arising from limitations of the modern computer, most namely finite precision. That is, despite the strength of the probability-1 argument underlying this theory, without using a priori certified tracking methods, some paths may fail to track perfectly for various reasons.
Witness set
A witness set
is a data structure used to describe algebraic varieties. The witness set for an affine variety that is equidimensional consists of three pieces of information. The first piece of information is a system of equations . These equations define the algebraic variety that is being studied. The second piece of information is a linear space . The dimension of is the codimension of , and chosen to intersect transversely. The third piece of information is the list of points in the intersection . This intersection has finitely many points and the number of points is the degree of the algebraic variety . Thus, witness sets encode the answer to the first two questions one asks about an algebraic variety: What is the dimension, and what is the degree? Witness sets also allow one to perform a numerical irreducible decomposition, component membership tests, and component sampling. This makes witness sets a good description of an algebraic variety.
Certification
Solutions to polynomial systems computed using numerical algebraic geometric methods can be certified, meaning that the approximate solution is "correct". This can be achieved in several ways, either a priori using a certified tracker,[7][8] or a posteriori by showing that the point is, say, in the basin of convergence for Newton's method.[9]
Software
Several software packages implement portions of the theoretical body of numerical algebraic geometry. These include, in alphabetic order:
^Sommese, Andrew J.; Wampler, II, Charles W. (2005). The numerical solution of systems of polynomials arising in engineering and science. World Scientific. ISBN978-981-256-184-8.
^ abBates, Daniel J.; Sommese, Andrew J.; Hauenstein, Jonathan D; Wampler, Charles W. (2013). Numerically solving polynomial systems with Bertini. Society for Industrial and Applied Mathematics. ISBN978-1-61197-269-6.
^Hom4PS Team. "Featured Products". Hom4PS-3. Michigan State University. Retrieved 28 April 2020.{{cite web}}: CS1 maint: numeric names: authors list (link)
^Breiding, Paul; Timme, Sascha (May 2018). "HomotopyContinuation.jl: A package for homotopy continuation in Julia". arXiv:1711.10911v2 [cs.MS].