\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 -3.096213968564233657917495852755546644219 \cdot 10^{153}:\\
\;\;\;\;\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{\mathsf{fma}\left(2, \frac{a \cdot c}{b}, b \cdot -2\right)}{2 \cdot a}\\
\end{array}\\
\mathbf{elif}\;b \le 1.042426094136287989665052757228371789389 \cdot 10^{152}:\\
\;\;\;\;\begin{array}{l}
\mathbf{if}\;b \ge 0.0:\\
\;\;\;\;\frac{2 \cdot c}{\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}}}\\
\mathbf{else}:\\
\;\;\;\;\frac{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} + \left(-b\right)}{2 \cdot a}\\
\end{array}\\
\mathbf{elif}\;b \ge 0.0:\\
\;\;\;\;\frac{2 \cdot c}{\mathsf{fma}\left(-2, b, \frac{2 \cdot a}{\frac{b}{c}}\right)}\\
\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 r932061 = b;
double r932062 = 0.0;
bool r932063 = r932061 >= r932062;
double r932064 = 2.0;
double r932065 = c;
double r932066 = r932064 * r932065;
double r932067 = -r932061;
double r932068 = r932061 * r932061;
double r932069 = 4.0;
double r932070 = a;
double r932071 = r932069 * r932070;
double r932072 = r932071 * r932065;
double r932073 = r932068 - r932072;
double r932074 = sqrt(r932073);
double r932075 = r932067 - r932074;
double r932076 = r932066 / r932075;
double r932077 = r932067 + r932074;
double r932078 = r932064 * r932070;
double r932079 = r932077 / r932078;
double r932080 = r932063 ? r932076 : r932079;
return r932080;
}
double f(double a, double b, double c) {
double r932081 = b;
double r932082 = -3.0962139685642337e+153;
bool r932083 = r932081 <= r932082;
double r932084 = 0.0;
bool r932085 = r932081 >= r932084;
double r932086 = 2.0;
double r932087 = c;
double r932088 = r932086 * r932087;
double r932089 = -r932081;
double r932090 = r932081 * r932081;
double r932091 = 4.0;
double r932092 = a;
double r932093 = r932091 * r932092;
double r932094 = r932093 * r932087;
double r932095 = r932090 - r932094;
double r932096 = sqrt(r932095);
double r932097 = r932089 - r932096;
double r932098 = r932088 / r932097;
double r932099 = r932092 * r932087;
double r932100 = r932099 / r932081;
double r932101 = -2.0;
double r932102 = r932081 * r932101;
double r932103 = fma(r932086, r932100, r932102);
double r932104 = r932086 * r932092;
double r932105 = r932103 / r932104;
double r932106 = r932085 ? r932098 : r932105;
double r932107 = 1.042426094136288e+152;
bool r932108 = r932081 <= r932107;
double r932109 = sqrt(r932096);
double r932110 = r932109 * r932109;
double r932111 = r932089 - r932110;
double r932112 = r932088 / r932111;
double r932113 = r932096 + r932089;
double r932114 = r932113 / r932104;
double r932115 = r932085 ? r932112 : r932114;
double r932116 = r932081 / r932087;
double r932117 = r932104 / r932116;
double r932118 = fma(r932101, r932081, r932117);
double r932119 = r932088 / r932118;
double r932120 = r932085 ? r932119 : r932114;
double r932121 = r932108 ? r932115 : r932120;
double r932122 = r932083 ? r932106 : r932121;
return r932122;
}



Bits error versus a



Bits error versus b



Bits error versus c
if b < -3.0962139685642337e+153Initial program 63.5
Taylor expanded around -inf 11.6
Simplified11.6
if -3.0962139685642337e+153 < b < 1.042426094136288e+152Initial program 8.3
rmApplied add-sqr-sqrt8.3
Applied sqrt-prod8.4
if 1.042426094136288e+152 < b Initial program 37.5
rmApplied add-sqr-sqrt37.5
Applied sqrt-prod37.5
Taylor expanded around inf 6.3
Simplified1.8
Final simplification7.6
herbie shell --seed 2019172 +o rules:numerics
(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))))