\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 -2.91176630904645143 \cdot 10^{116}:\\
\;\;\;\;\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{\frac{2 \cdot c}{\sqrt{\left(-b\right) + \left(2 \cdot \left(\frac{a}{\sqrt[3]{b} \cdot \sqrt[3]{b}} \cdot \frac{c}{\sqrt[3]{b}}\right) - b\right)}}}{\sqrt{\left(-b\right) + \left(2 \cdot \left(\frac{a}{\sqrt[3]{b} \cdot \sqrt[3]{b}} \cdot \frac{c}{\sqrt[3]{b}}\right) - b\right)}}\\
\end{array}\\
\mathbf{elif}\;b \le 1.2919983862558445 \cdot 10^{30}:\\
\;\;\;\;\begin{array}{l}
\mathbf{if}\;b \ge 0.0:\\
\;\;\;\;\frac{\left(-b\right) - \sqrt{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}} \cdot \sqrt{\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}\\
\mathbf{elif}\;b \ge 0.0:\\
\;\;\;\;\frac{2 \cdot \frac{a \cdot c}{b} - 2 \cdot b}{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 r29007 = b;
double r29008 = 0.0;
bool r29009 = r29007 >= r29008;
double r29010 = -r29007;
double r29011 = r29007 * r29007;
double r29012 = 4.0;
double r29013 = a;
double r29014 = r29012 * r29013;
double r29015 = c;
double r29016 = r29014 * r29015;
double r29017 = r29011 - r29016;
double r29018 = sqrt(r29017);
double r29019 = r29010 - r29018;
double r29020 = 2.0;
double r29021 = r29020 * r29013;
double r29022 = r29019 / r29021;
double r29023 = r29020 * r29015;
double r29024 = r29010 + r29018;
double r29025 = r29023 / r29024;
double r29026 = r29009 ? r29022 : r29025;
return r29026;
}
double f(double a, double b, double c) {
double r29027 = b;
double r29028 = -2.9117663090464514e+116;
bool r29029 = r29027 <= r29028;
double r29030 = 0.0;
bool r29031 = r29027 >= r29030;
double r29032 = -r29027;
double r29033 = r29027 * r29027;
double r29034 = 4.0;
double r29035 = a;
double r29036 = r29034 * r29035;
double r29037 = c;
double r29038 = r29036 * r29037;
double r29039 = r29033 - r29038;
double r29040 = sqrt(r29039);
double r29041 = r29032 - r29040;
double r29042 = 2.0;
double r29043 = r29042 * r29035;
double r29044 = r29041 / r29043;
double r29045 = r29042 * r29037;
double r29046 = cbrt(r29027);
double r29047 = r29046 * r29046;
double r29048 = r29035 / r29047;
double r29049 = r29037 / r29046;
double r29050 = r29048 * r29049;
double r29051 = r29042 * r29050;
double r29052 = r29051 - r29027;
double r29053 = r29032 + r29052;
double r29054 = sqrt(r29053);
double r29055 = r29045 / r29054;
double r29056 = r29055 / r29054;
double r29057 = r29031 ? r29044 : r29056;
double r29058 = 1.2919983862558445e+30;
bool r29059 = r29027 <= r29058;
double r29060 = sqrt(r29040);
double r29061 = r29060 * r29060;
double r29062 = r29032 - r29061;
double r29063 = r29062 / r29043;
double r29064 = r29032 + r29040;
double r29065 = r29045 / r29064;
double r29066 = r29031 ? r29063 : r29065;
double r29067 = r29035 * r29037;
double r29068 = r29067 / r29027;
double r29069 = r29042 * r29068;
double r29070 = 2.0;
double r29071 = r29070 * r29027;
double r29072 = r29069 - r29071;
double r29073 = r29072 / r29043;
double r29074 = r29031 ? r29073 : r29065;
double r29075 = r29059 ? r29066 : r29074;
double r29076 = r29029 ? r29057 : r29075;
return r29076;
}



Bits error versus a



Bits error versus b



Bits error versus c
Results
if b < -2.9117663090464514e+116Initial program 30.6
Taylor expanded around -inf 5.8
rmApplied add-cube-cbrt5.8
Applied times-frac2.2
rmApplied add-sqr-sqrt2.5
Applied associate-/r*2.5
if -2.9117663090464514e+116 < b < 1.2919983862558445e+30Initial program 9.4
rmApplied add-sqr-sqrt9.4
Applied sqrt-prod9.5
if 1.2919983862558445e+30 < b Initial program 34.2
rmApplied add-sqr-sqrt34.2
Applied sqrt-prod34.3
Taylor expanded around inf 11.8
Final simplification8.5
herbie shell --seed 2020100 +o rules:numerics
(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)))))))