\frac{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\begin{array}{l}
\mathbf{if}\;b \le 627.9389082699839:\\
\;\;\;\;\frac{\frac{\frac{\sqrt{\mathsf{fma}\left(a \cdot c, -4, b \cdot b\right)} \cdot \mathsf{fma}\left(a \cdot c, -4, b \cdot b\right) - \left(b \cdot b\right) \cdot b}{\mathsf{fma}\left(b, \sqrt{\mathsf{fma}\left(a \cdot c, -4, b \cdot b\right)}, b \cdot b + \mathsf{fma}\left(a \cdot c, -4, b \cdot b\right)\right)}}{a}}{2}\\
\mathbf{else}:\\
\;\;\;\;\frac{-2 \cdot \frac{c}{b}}{2}\\
\end{array}double f(double a, double b, double c) {
double r857851 = b;
double r857852 = -r857851;
double r857853 = r857851 * r857851;
double r857854 = 4.0;
double r857855 = a;
double r857856 = r857854 * r857855;
double r857857 = c;
double r857858 = r857856 * r857857;
double r857859 = r857853 - r857858;
double r857860 = sqrt(r857859);
double r857861 = r857852 + r857860;
double r857862 = 2.0;
double r857863 = r857862 * r857855;
double r857864 = r857861 / r857863;
return r857864;
}
double f(double a, double b, double c) {
double r857865 = b;
double r857866 = 627.9389082699839;
bool r857867 = r857865 <= r857866;
double r857868 = a;
double r857869 = c;
double r857870 = r857868 * r857869;
double r857871 = -4.0;
double r857872 = r857865 * r857865;
double r857873 = fma(r857870, r857871, r857872);
double r857874 = sqrt(r857873);
double r857875 = r857874 * r857873;
double r857876 = r857872 * r857865;
double r857877 = r857875 - r857876;
double r857878 = r857872 + r857873;
double r857879 = fma(r857865, r857874, r857878);
double r857880 = r857877 / r857879;
double r857881 = r857880 / r857868;
double r857882 = 2.0;
double r857883 = r857881 / r857882;
double r857884 = -2.0;
double r857885 = r857869 / r857865;
double r857886 = r857884 * r857885;
double r857887 = r857886 / r857882;
double r857888 = r857867 ? r857883 : r857887;
return r857888;
}



Bits error versus a



Bits error versus b



Bits error versus c
if b < 627.9389082699839Initial program 16.6
Simplified16.5
rmApplied flip3--16.5
Simplified15.9
Simplified15.9
if 627.9389082699839 < b Initial program 36.4
Simplified36.4
Taylor expanded around inf 16.2
Final simplification16.1
herbie shell --seed 2019142 +o rules:numerics
(FPCore (a b c)
:name "Quadratic roots, narrow range"
:pre (and (< 1.0536712127723509e-08 a 94906265.62425156) (< 1.0536712127723509e-08 b 94906265.62425156) (< 1.0536712127723509e-08 c 94906265.62425156))
(/ (+ (- b) (sqrt (- (* b b) (* (* 4 a) c)))) (* 2 a)))