We present a new algorithm to solve polynomial equations, and publish its code, which is 1.6–3 times faster than the ZROOTS subroutine that is commercially available from Numerical Recipes, depending on application. The largest improvement, when compared to naive solvers, comes from a fail-safe procedure that permits us to skip the majority of the calculations in the great majority of cases, without risking catastrophic failure in the few cases that these are actually required. Second, we identify a discriminant that enables a rational choice between Laguerre’s Method and Newton’s Method (or a new intermediate method) on a case-by-case basis. We briefly review the history of root solving and demonstrate that “Newton’s Method” was discovered neither by Newton (1671) nor by Raphson (1690), but only by Simpson (1740). Some of the arguments leading to this conclusion were first given by the British historian of science Nick Kollerstrom in 1992, but these do not appear to have penetrated the astronomical community. Finally, we argue that Numerical Recipes should voluntarily surrender its copyright protection for non-profit applications, despite the fact that, in this particular case, such protection was the major stimulant for developing our improved algorithm.
[1]
William H. Press,et al.
Numerical recipes
,
1990
.
[2]
Niels Henrik Abel,et al.
Mémoire sur les equations algébriques, où l'on démontre l'impossibilité de la résolution de l'équation générale du cinquième degré
,
2012
.
[3]
N. H. Abel.
Beweis der Unmöglichkeit, algebraische Gleichungen von höheren Graden als dem vierten allgemein aufzulösen.
,
1826
.
[4]
Lior Shamir,et al.
Practices in Code Discoverability
,
2012
.
[5]
Wen Lea Pearn,et al.
(Journal of Computational and Applied Mathematics,228(1):274-278)Optimization of the T Policy M/G/1 Queue with Server Breakdowns and General Startup Times
,
2009
.
[6]
Daniel Gooch,et al.
Communications of the ACM
,
2011,
XRDS.