\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 -7.93152454634661985 \cdot 10^{153}:\\
\;\;\;\;1 \cdot \left(\frac{c}{b} - \frac{b}{a}\right)\\
\mathbf{elif}\;b \le 2.0569776426586135 \cdot 10^{-106}:\\
\;\;\;\;\frac{\frac{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} - b}{2}}{a}\\
\mathbf{else}:\\
\;\;\;\;-1 \cdot \frac{c}{b}\\
\end{array}double f(double a, double b, double c) {
double r56733 = b;
double r56734 = -r56733;
double r56735 = r56733 * r56733;
double r56736 = 4.0;
double r56737 = a;
double r56738 = r56736 * r56737;
double r56739 = c;
double r56740 = r56738 * r56739;
double r56741 = r56735 - r56740;
double r56742 = sqrt(r56741);
double r56743 = r56734 + r56742;
double r56744 = 2.0;
double r56745 = r56744 * r56737;
double r56746 = r56743 / r56745;
return r56746;
}
double f(double a, double b, double c) {
double r56747 = b;
double r56748 = -7.93152454634662e+153;
bool r56749 = r56747 <= r56748;
double r56750 = 1.0;
double r56751 = c;
double r56752 = r56751 / r56747;
double r56753 = a;
double r56754 = r56747 / r56753;
double r56755 = r56752 - r56754;
double r56756 = r56750 * r56755;
double r56757 = 2.0569776426586135e-106;
bool r56758 = r56747 <= r56757;
double r56759 = r56747 * r56747;
double r56760 = 4.0;
double r56761 = r56760 * r56753;
double r56762 = r56761 * r56751;
double r56763 = r56759 - r56762;
double r56764 = sqrt(r56763);
double r56765 = r56764 - r56747;
double r56766 = 2.0;
double r56767 = r56765 / r56766;
double r56768 = r56767 / r56753;
double r56769 = -1.0;
double r56770 = r56769 * r56752;
double r56771 = r56758 ? r56768 : r56770;
double r56772 = r56749 ? r56756 : r56771;
return r56772;
}



Bits error versus a



Bits error versus b



Bits error versus c
Results
if b < -7.93152454634662e+153Initial program 63.8
Simplified63.8
rmApplied clear-num63.8
rmApplied *-un-lft-identity63.8
Applied *-un-lft-identity63.8
Applied times-frac63.8
Applied *-un-lft-identity63.8
Applied times-frac63.8
Applied add-cube-cbrt63.8
Applied times-frac63.8
Simplified63.8
Simplified63.8
Taylor expanded around -inf 1.9
Simplified1.9
if -7.93152454634662e+153 < b < 2.0569776426586135e-106Initial program 11.2
Simplified11.2
rmApplied clear-num11.3
rmApplied *-un-lft-identity11.3
Applied *-un-lft-identity11.3
Applied times-frac11.3
Applied *-un-lft-identity11.3
Applied times-frac11.3
Applied add-cube-cbrt11.3
Applied times-frac11.3
Simplified11.3
Simplified11.2
if 2.0569776426586135e-106 < b Initial program 52.0
Simplified52.0
Taylor expanded around inf 10.3
Final simplification9.8
herbie shell --seed 2020043
(FPCore (a b c)
:name "Quadratic roots, full range"
:precision binary64
(/ (+ (- b) (sqrt (- (* b b) (* (* 4 a) c)))) (* 2 a)))