\begin{array}{l}
\mathbf{if}\;b \ge 0.0:\\
\;\;\;\;\frac{2 \cdot c}{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\
\mathbf{else}:\\
\;\;\;\;\frac{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\\
\end{array}\begin{array}{l}
\mathbf{if}\;b \le -1.540303319601975724380105553995528530303 \cdot 10^{125}:\\
\;\;\;\;\begin{array}{l}
\mathbf{if}\;b \ge 0.0:\\
\;\;\;\;\frac{2 \cdot c}{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\
\mathbf{else}:\\
\;\;\;\;\frac{\left(\frac{2 \cdot a}{\frac{b}{c}} - b\right) + \left(-b\right)}{2 \cdot a}\\
\end{array}\\
\mathbf{elif}\;b \le 8.269023837734684175347589133239203342013 \cdot 10^{75}:\\
\;\;\;\;\begin{array}{l}
\mathbf{if}\;b \ge 0.0:\\
\;\;\;\;\frac{2 \cdot c}{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}\\
\mathbf{else}:\\
\;\;\;\;\frac{\left(-b\right) + \left|\sqrt[3]{b \cdot b - \left(4 \cdot c\right) \cdot a}\right| \cdot \sqrt{\sqrt[3]{b \cdot b - \left(4 \cdot c\right) \cdot a}}}{2 \cdot a}\\
\end{array}\\
\mathbf{elif}\;b \ge 0.0:\\
\;\;\;\;\frac{2 \cdot c}{\frac{2 \cdot a}{\frac{b}{c}} + -2 \cdot b}\\
\mathbf{else}:\\
\;\;\;\;\frac{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + \left(-b\right)}{2 \cdot a}\\
\end{array}double f(double a, double b, double c) {
double r33023 = b;
double r33024 = 0.0;
bool r33025 = r33023 >= r33024;
double r33026 = 2.0;
double r33027 = c;
double r33028 = r33026 * r33027;
double r33029 = -r33023;
double r33030 = r33023 * r33023;
double r33031 = 4.0;
double r33032 = a;
double r33033 = r33031 * r33032;
double r33034 = r33033 * r33027;
double r33035 = r33030 - r33034;
double r33036 = sqrt(r33035);
double r33037 = r33029 - r33036;
double r33038 = r33028 / r33037;
double r33039 = r33029 + r33036;
double r33040 = r33026 * r33032;
double r33041 = r33039 / r33040;
double r33042 = r33025 ? r33038 : r33041;
return r33042;
}
double f(double a, double b, double c) {
double r33043 = b;
double r33044 = -1.5403033196019757e+125;
bool r33045 = r33043 <= r33044;
double r33046 = 0.0;
bool r33047 = r33043 >= r33046;
double r33048 = 2.0;
double r33049 = c;
double r33050 = r33048 * r33049;
double r33051 = -r33043;
double r33052 = r33043 * r33043;
double r33053 = 4.0;
double r33054 = a;
double r33055 = r33053 * r33054;
double r33056 = r33055 * r33049;
double r33057 = r33052 - r33056;
double r33058 = sqrt(r33057);
double r33059 = r33051 - r33058;
double r33060 = r33050 / r33059;
double r33061 = r33048 * r33054;
double r33062 = r33043 / r33049;
double r33063 = r33061 / r33062;
double r33064 = r33063 - r33043;
double r33065 = r33064 + r33051;
double r33066 = r33065 / r33061;
double r33067 = r33047 ? r33060 : r33066;
double r33068 = 8.269023837734684e+75;
bool r33069 = r33043 <= r33068;
double r33070 = r33053 * r33049;
double r33071 = r33070 * r33054;
double r33072 = r33052 - r33071;
double r33073 = cbrt(r33072);
double r33074 = fabs(r33073);
double r33075 = sqrt(r33073);
double r33076 = r33074 * r33075;
double r33077 = r33051 + r33076;
double r33078 = r33077 / r33061;
double r33079 = r33047 ? r33060 : r33078;
double r33080 = -2.0;
double r33081 = r33080 * r33043;
double r33082 = r33063 + r33081;
double r33083 = r33050 / r33082;
double r33084 = r33058 + r33051;
double r33085 = r33084 / r33061;
double r33086 = r33047 ? r33083 : r33085;
double r33087 = r33069 ? r33079 : r33086;
double r33088 = r33045 ? r33067 : r33087;
return r33088;
}



Bits error versus a



Bits error versus b



Bits error versus c
Results
if b < -1.5403033196019757e+125Initial program 53.2
Taylor expanded around -inf 10.8
Simplified3.5
if -1.5403033196019757e+125 < b < 8.269023837734684e+75Initial program 9.3
rmApplied add-cube-cbrt9.5
Applied sqrt-prod9.5
Simplified9.5
Simplified9.5
if 8.269023837734684e+75 < b Initial program 27.7
Taylor expanded around inf 7.3
Simplified3.5
Final simplification7.2
herbie shell --seed 2019196
(FPCore (a b c)
:name "jeff quadratic root 2"
(if (>= b 0.0) (/ (* 2.0 c) (- (- b) (sqrt (- (* b b) (* (* 4.0 a) c))))) (/ (+ (- b) (sqrt (- (* b b) (* (* 4.0 a) c)))) (* 2.0 a))))