\begin{array}{l}
\mathbf{if}\;b \ge 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 -8.130457313724135 \cdot 10^{+141}:\\
\;\;\;\;\begin{array}{l}
\mathbf{if}\;b \ge 0:\\
\;\;\;\;\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\
\mathbf{else}:\\
\;\;\;\;\frac{c \cdot 2}{2 \cdot \left(a \cdot \frac{c}{b} - b\right)}\\
\end{array}\\
\mathbf{elif}\;b \le 7.086915338165871 \cdot 10^{+90}:\\
\;\;\;\;\begin{array}{l}
\mathbf{if}\;b \ge 0:\\
\;\;\;\;\frac{\left(-b\right) - \left|\sqrt[3]{\sqrt[3]{b \cdot b - \left(4 \cdot a\right) \cdot c} \cdot \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)}\right| \cdot \sqrt{\sqrt[3]{b \cdot b - \left(4 \cdot a\right) \cdot c}}}{2 \cdot a}\\
\mathbf{else}:\\
\;\;\;\;\frac{c \cdot 2}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + \left(-b\right)}\\
\end{array}\\
\mathbf{elif}\;b \ge 0:\\
\;\;\;\;\frac{2 \cdot \left(a \cdot \frac{c}{b} - b\right)}{2 \cdot a}\\
\mathbf{else}:\\
\;\;\;\;\frac{c \cdot 2}{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + \left(-b\right)}\\
\end{array}double f(double a, double b, double c) {
double r2058745 = b;
double r2058746 = 0.0;
bool r2058747 = r2058745 >= r2058746;
double r2058748 = -r2058745;
double r2058749 = r2058745 * r2058745;
double r2058750 = 4.0;
double r2058751 = a;
double r2058752 = r2058750 * r2058751;
double r2058753 = c;
double r2058754 = r2058752 * r2058753;
double r2058755 = r2058749 - r2058754;
double r2058756 = sqrt(r2058755);
double r2058757 = r2058748 - r2058756;
double r2058758 = 2.0;
double r2058759 = r2058758 * r2058751;
double r2058760 = r2058757 / r2058759;
double r2058761 = r2058758 * r2058753;
double r2058762 = r2058748 + r2058756;
double r2058763 = r2058761 / r2058762;
double r2058764 = r2058747 ? r2058760 : r2058763;
return r2058764;
}
double f(double a, double b, double c) {
double r2058765 = b;
double r2058766 = -8.130457313724135e+141;
bool r2058767 = r2058765 <= r2058766;
double r2058768 = 0.0;
bool r2058769 = r2058765 >= r2058768;
double r2058770 = -r2058765;
double r2058771 = r2058765 * r2058765;
double r2058772 = 4.0;
double r2058773 = a;
double r2058774 = r2058772 * r2058773;
double r2058775 = c;
double r2058776 = r2058774 * r2058775;
double r2058777 = r2058771 - r2058776;
double r2058778 = sqrt(r2058777);
double r2058779 = r2058770 - r2058778;
double r2058780 = 2.0;
double r2058781 = r2058780 * r2058773;
double r2058782 = r2058779 / r2058781;
double r2058783 = r2058775 * r2058780;
double r2058784 = r2058775 / r2058765;
double r2058785 = r2058773 * r2058784;
double r2058786 = r2058785 - r2058765;
double r2058787 = r2058780 * r2058786;
double r2058788 = r2058783 / r2058787;
double r2058789 = r2058769 ? r2058782 : r2058788;
double r2058790 = 7.086915338165871e+90;
bool r2058791 = r2058765 <= r2058790;
double r2058792 = cbrt(r2058777);
double r2058793 = r2058792 * r2058792;
double r2058794 = r2058792 * r2058793;
double r2058795 = cbrt(r2058794);
double r2058796 = fabs(r2058795);
double r2058797 = sqrt(r2058792);
double r2058798 = r2058796 * r2058797;
double r2058799 = r2058770 - r2058798;
double r2058800 = r2058799 / r2058781;
double r2058801 = r2058778 + r2058770;
double r2058802 = r2058783 / r2058801;
double r2058803 = r2058769 ? r2058800 : r2058802;
double r2058804 = r2058787 / r2058781;
double r2058805 = r2058769 ? r2058804 : r2058802;
double r2058806 = r2058791 ? r2058803 : r2058805;
double r2058807 = r2058767 ? r2058789 : r2058806;
return r2058807;
}



Bits error versus a



Bits error versus b



Bits error versus c
Results
if b < -8.130457313724135e+141Initial program 35.6
Taylor expanded around -inf 6.0
Simplified1.1
if -8.130457313724135e+141 < b < 7.086915338165871e+90Initial program 8.9
rmApplied add-cube-cbrt9.1
Applied sqrt-prod9.1
Simplified9.1
rmApplied add-cbrt-cube9.1
if 7.086915338165871e+90 < b Initial program 42.3
Taylor expanded around inf 8.8
Simplified3.8
Final simplification6.8
herbie shell --seed 2019112
(FPCore (a b c)
:name "jeff quadratic root 1"
(if (>= b 0) (/ (- (- b) (sqrt (- (* b b) (* (* 4 a) c)))) (* 2 a)) (/ (* 2 c) (+ (- b) (sqrt (- (* b b) (* (* 4 a) c)))))))