\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 -3.710887557865060611891812934492943223731 \cdot 10^{138}:\\
\;\;\;\;\frac{\frac{b}{2} \cdot -2}{a}\\
\mathbf{elif}\;b \le 1.627160326743933989296751920246101845745 \cdot 10^{-46}:\\
\;\;\;\;\frac{\frac{1}{\sqrt{\sqrt{2}}} \cdot \frac{\frac{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} - b}{\sqrt{\sqrt{2}}}}{\sqrt{2}}}{a}\\
\mathbf{else}:\\
\;\;\;\;\frac{-1 \cdot \frac{a \cdot c}{b}}{a}\\
\end{array}double f(double a, double b, double c) {
double r2434774 = b;
double r2434775 = -r2434774;
double r2434776 = r2434774 * r2434774;
double r2434777 = 4.0;
double r2434778 = a;
double r2434779 = r2434777 * r2434778;
double r2434780 = c;
double r2434781 = r2434779 * r2434780;
double r2434782 = r2434776 - r2434781;
double r2434783 = sqrt(r2434782);
double r2434784 = r2434775 + r2434783;
double r2434785 = 2.0;
double r2434786 = r2434785 * r2434778;
double r2434787 = r2434784 / r2434786;
return r2434787;
}
double f(double a, double b, double c) {
double r2434788 = b;
double r2434789 = -3.7108875578650606e+138;
bool r2434790 = r2434788 <= r2434789;
double r2434791 = 2.0;
double r2434792 = r2434788 / r2434791;
double r2434793 = -2.0;
double r2434794 = r2434792 * r2434793;
double r2434795 = a;
double r2434796 = r2434794 / r2434795;
double r2434797 = 1.627160326743934e-46;
bool r2434798 = r2434788 <= r2434797;
double r2434799 = 1.0;
double r2434800 = sqrt(r2434791);
double r2434801 = sqrt(r2434800);
double r2434802 = r2434799 / r2434801;
double r2434803 = r2434788 * r2434788;
double r2434804 = 4.0;
double r2434805 = r2434804 * r2434795;
double r2434806 = c;
double r2434807 = r2434805 * r2434806;
double r2434808 = r2434803 - r2434807;
double r2434809 = sqrt(r2434808);
double r2434810 = r2434809 - r2434788;
double r2434811 = r2434810 / r2434801;
double r2434812 = r2434811 / r2434800;
double r2434813 = r2434802 * r2434812;
double r2434814 = r2434813 / r2434795;
double r2434815 = -1.0;
double r2434816 = r2434795 * r2434806;
double r2434817 = r2434816 / r2434788;
double r2434818 = r2434815 * r2434817;
double r2434819 = r2434818 / r2434795;
double r2434820 = r2434798 ? r2434814 : r2434819;
double r2434821 = r2434790 ? r2434796 : r2434820;
return r2434821;
}



Bits error versus a



Bits error versus b



Bits error versus c
Results
if b < -3.7108875578650606e+138Initial program 58.5
Simplified58.5
rmApplied add-sqr-sqrt58.6
Applied associate-/r*58.6
Taylor expanded around -inf 3.3
Simplified2.1
if -3.7108875578650606e+138 < b < 1.627160326743934e-46Initial program 13.0
Simplified13.0
rmApplied add-sqr-sqrt13.8
Applied associate-/r*13.5
rmApplied *-un-lft-identity13.5
Applied sqrt-prod13.5
Applied add-sqr-sqrt13.5
Applied sqrt-prod13.1
Applied *-un-lft-identity13.1
Applied times-frac13.2
Applied times-frac13.2
Simplified13.2
if 1.627160326743934e-46 < b Initial program 54.2
Simplified54.2
Taylor expanded around inf 18.5
Final simplification13.8
herbie shell --seed 2019174 +o rules:numerics
(FPCore (a b c)
:name "Quadratic roots, full range"
(/ (+ (- b) (sqrt (- (* b b) (* (* 4.0 a) c)))) (* 2.0 a)))