\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.367568263477709863540308694818264401956 \cdot 10^{124}:\\
\;\;\;\;\begin{array}{l}
\mathbf{if}\;b \ge 0.0:\\
\;\;\;\;\frac{2}{\frac{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{c}}\\
\mathbf{else}:\\
\;\;\;\;1 \cdot \left(\frac{c}{b} - \frac{b}{a}\right)\\
\end{array}\\
\mathbf{elif}\;b \le 2098947641.3561494350433349609375:\\
\;\;\;\;\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{\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}} - b}{2 \cdot a}\\
\end{array}\\
\mathbf{elif}\;b \ge 0.0:\\
\;\;\;\;\frac{2 \cdot c}{\left(-b\right) - \left(b - 2 \cdot \frac{a \cdot c}{b}\right)}\\
\mathbf{else}:\\
\;\;\;\;\frac{\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c} - b}{2 \cdot a}\\
\end{array}double f(double a, double b, double c) {
double r31419 = b;
double r31420 = 0.0;
bool r31421 = r31419 >= r31420;
double r31422 = 2.0;
double r31423 = c;
double r31424 = r31422 * r31423;
double r31425 = -r31419;
double r31426 = r31419 * r31419;
double r31427 = 4.0;
double r31428 = a;
double r31429 = r31427 * r31428;
double r31430 = r31429 * r31423;
double r31431 = r31426 - r31430;
double r31432 = sqrt(r31431);
double r31433 = r31425 - r31432;
double r31434 = r31424 / r31433;
double r31435 = r31425 + r31432;
double r31436 = r31422 * r31428;
double r31437 = r31435 / r31436;
double r31438 = r31421 ? r31434 : r31437;
return r31438;
}
double f(double a, double b, double c) {
double r31439 = b;
double r31440 = -1.3675682634777099e+124;
bool r31441 = r31439 <= r31440;
double r31442 = 0.0;
bool r31443 = r31439 >= r31442;
double r31444 = 2.0;
double r31445 = -r31439;
double r31446 = r31439 * r31439;
double r31447 = 4.0;
double r31448 = a;
double r31449 = r31447 * r31448;
double r31450 = c;
double r31451 = r31449 * r31450;
double r31452 = r31446 - r31451;
double r31453 = sqrt(r31452);
double r31454 = r31445 - r31453;
double r31455 = r31454 / r31450;
double r31456 = r31444 / r31455;
double r31457 = 1.0;
double r31458 = r31450 / r31439;
double r31459 = r31439 / r31448;
double r31460 = r31458 - r31459;
double r31461 = r31457 * r31460;
double r31462 = r31443 ? r31456 : r31461;
double r31463 = 2098947641.3561494;
bool r31464 = r31439 <= r31463;
double r31465 = r31444 * r31450;
double r31466 = r31465 / r31454;
double r31467 = sqrt(r31453);
double r31468 = r31467 * r31467;
double r31469 = r31468 - r31439;
double r31470 = r31444 * r31448;
double r31471 = r31469 / r31470;
double r31472 = r31443 ? r31466 : r31471;
double r31473 = r31448 * r31450;
double r31474 = r31473 / r31439;
double r31475 = r31444 * r31474;
double r31476 = r31439 - r31475;
double r31477 = r31445 - r31476;
double r31478 = r31465 / r31477;
double r31479 = r31453 - r31439;
double r31480 = r31479 / r31470;
double r31481 = r31443 ? r31478 : r31480;
double r31482 = r31464 ? r31472 : r31481;
double r31483 = r31441 ? r31462 : r31482;
return r31483;
}



Bits error versus a



Bits error versus b



Bits error versus c
Results
if b < -1.3675682634777099e+124Initial program 54.3
Simplified54.3
Taylor expanded around -inf 10.3
Taylor expanded around 0 2.7
Simplified2.7
rmApplied associate-/l*2.7
if -1.3675682634777099e+124 < b < 2098947641.3561494Initial program 10.0
Simplified10.0
rmApplied add-sqr-sqrt10.0
Applied sqrt-prod10.1
if 2098947641.3561494 < b Initial program 23.5
Simplified23.5
Taylor expanded around inf 8.6
Final simplification8.7
herbie shell --seed 2019209
(FPCore (a b c)
:name "jeff quadratic root 2"
:precision binary64
(if (>= b 0.0) (/ (* 2 c) (- (- b) (sqrt (- (* b b) (* (* 4 a) c))))) (/ (+ (- b) (sqrt (- (* b b) (* (* 4 a) c)))) (* 2 a))))