- Bairstow's method
In
numerical analysis , Bairstow's method is an efficientalgorithm for finding the roots of a realpolynomial of arbitrary degree. The algorithm first appeared in the appendix of the 1920 book "Applied Aerodynamics" byLeonard Bairstow . The algorithm finds the roots incomplex conjugate pairs using only real arithmetic.See
root-finding algorithm for other algorithms.Description of the method
Bairstow's approach is to use
Newton's method to adjust the coefficients "u" and "v" in the quadratic until its roots are also roots of the polynomial being solved. The roots of the quadratic may then be determined, and the polynomial may be divided by the quadratic to eliminate those roots. This process is then iterated until the polynomial becomes quadratic or linear, and all the roots have been determined.Long division of a polynomial : by yields a quotient: and a remainder such that:The variables , , and the are functions of and . They can be found recursively as follows.::::The quadratic evenly divides the polynomial when:Values of and for which this occurs can be discovered by picking starting values and iterating Newton's method in two dimensions:until convergence occurs.
Performance
Bairstow's algorithm inherits the quadratic convergence of Newton's method, except in the case of quadratic factors of multiplicity higher than 1, when convergence can be rather slow.
External links
* [http://mathworld.wolfram.com/BairstowsMethod.html Bairstow's Algorithm on Mathworld]
* [http://library.lanl.gov/numerical/bookfpdf.html Numerical Recipes in Fortran 77 Online]
* [http://www.savetman.com/roots.html Compute roots of polynomials interactively using Bairstow's Method on savetman.com]
* [http://www.polarhome.com:793/~amate2/php/polysolver_en.php Determine the roots of polynomials (gr(P)<= 10) using Bairstow's Method]
* [http://www.vtk.org/doc/nightly/html/classvtkMath.html LinBairstowSolve, an open-source C++ implementation of the Lin-Bairstow method is available as a method of the VTK library]
Wikimedia Foundation. 2010.