\begin{array}{l}
\mathbf{if}\;b \ge 0.0:\\
\;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\
\mathbf{else}:\\
\;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\
\end{array}\begin{array}{l}
\mathbf{if}\;b \le -6.6114837319571935 \cdot 10^{38}:\\
\;\;\;\;\begin{array}{l}
\mathbf{if}\;b \ge 0.0:\\
\;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\
\mathbf{else}:\\
\;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \left(2 \cdot \frac{a \cdot c}{b} - b\right)}\\
\end{array}\\
\mathbf{elif}\;b \le 2.3866645776898725 \cdot 10^{85}:\\
\;\;\;\;\begin{array}{l}
\mathbf{if}\;b \ge 0.0:\\
\;\;\;\;\frac{\left(-b\right) - \sqrt{\left(\sqrt[3]{b \cdot b - \left(4 \cdot a\right) \cdot c} \cdot \sqrt[3]{b \cdot b - \left(4 \cdot a\right) \cdot c}\right) \cdot \left(\sqrt[3]{\sqrt[3]{b \cdot b - \left(4 \cdot a\right) \cdot c} \cdot \sqrt[3]{b \cdot b - \left(4 \cdot a\right) \cdot c}} \cdot \sqrt[3]{\sqrt[3]{b \cdot b - \left(4 \cdot a\right) \cdot c}}\right)}}{2 \cdot a}\\
\mathbf{else}:\\
\;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\
\end{array}\\
\mathbf{elif}\;b \ge 0.0:\\
\;\;\;\;\frac{\left(-b\right) - \left(b - 2 \cdot \frac{a \cdot c}{b}\right)}{2 \cdot a}\\
\mathbf{else}:\\
\;\;\;\;\frac{2 \cdot c}{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\
\end{array}double f(double a, double b, double c) {
double r47707 = b;
double r47708 = 0.0;
bool r47709 = r47707 >= r47708;
double r47710 = -r47707;
double r47711 = r47707 * r47707;
double r47712 = 4.0;
double r47713 = a;
double r47714 = r47712 * r47713;
double r47715 = c;
double r47716 = r47714 * r47715;
double r47717 = r47711 - r47716;
double r47718 = sqrt(r47717);
double r47719 = r47710 - r47718;
double r47720 = 2.0;
double r47721 = r47720 * r47713;
double r47722 = r47719 / r47721;
double r47723 = r47720 * r47715;
double r47724 = r47710 + r47718;
double r47725 = r47723 / r47724;
double r47726 = r47709 ? r47722 : r47725;
return r47726;
}
double f(double a, double b, double c) {
double r47727 = b;
double r47728 = -6.6114837319571935e+38;
bool r47729 = r47727 <= r47728;
double r47730 = 0.0;
bool r47731 = r47727 >= r47730;
double r47732 = -r47727;
double r47733 = r47727 * r47727;
double r47734 = 4.0;
double r47735 = a;
double r47736 = r47734 * r47735;
double r47737 = c;
double r47738 = r47736 * r47737;
double r47739 = r47733 - r47738;
double r47740 = sqrt(r47739);
double r47741 = r47732 - r47740;
double r47742 = 2.0;
double r47743 = r47742 * r47735;
double r47744 = r47741 / r47743;
double r47745 = r47742 * r47737;
double r47746 = r47735 * r47737;
double r47747 = r47746 / r47727;
double r47748 = r47742 * r47747;
double r47749 = r47748 - r47727;
double r47750 = r47732 + r47749;
double r47751 = r47745 / r47750;
double r47752 = r47731 ? r47744 : r47751;
double r47753 = 2.3866645776898725e+85;
bool r47754 = r47727 <= r47753;
double r47755 = cbrt(r47739);
double r47756 = r47755 * r47755;
double r47757 = cbrt(r47756);
double r47758 = cbrt(r47755);
double r47759 = r47757 * r47758;
double r47760 = r47756 * r47759;
double r47761 = sqrt(r47760);
double r47762 = r47732 - r47761;
double r47763 = r47762 / r47743;
double r47764 = r47732 + r47740;
double r47765 = r47745 / r47764;
double r47766 = r47731 ? r47763 : r47765;
double r47767 = r47727 - r47748;
double r47768 = r47732 - r47767;
double r47769 = r47768 / r47743;
double r47770 = r47731 ? r47769 : r47765;
double r47771 = r47754 ? r47766 : r47770;
double r47772 = r47729 ? r47752 : r47771;
return r47772;
}



Bits error versus a



Bits error versus b



Bits error versus c
Results
if b < -6.6114837319571935e+38Initial program 25.1
Taylor expanded around -inf 7.9
if -6.6114837319571935e+38 < b < 2.3866645776898725e+85Initial program 9.7
rmApplied add-cube-cbrt10.0
rmApplied add-cube-cbrt10.0
Applied cbrt-prod10.0
if 2.3866645776898725e+85 < b Initial program 43.7
Taylor expanded around inf 10.2
Final simplification9.4
herbie shell --seed 2020039
(FPCore (a b c)
:name "jeff quadratic root 1"
:precision binary64
(if (>= b 0.0) (/ (- (- b) (sqrt (- (* b b) (* (* 4 a) c)))) (* 2 a)) (/ (* 2 c) (+ (- b) (sqrt (- (* b b) (* (* 4 a) c)))))))