\frac{\left(-b\right) + \sqrt{b \cdot b - \left(3 \cdot a\right) \cdot c}}{3 \cdot a}\begin{array}{l}
\mathbf{if}\;\frac{\left(-b\right) + \sqrt{b \cdot b - \left(3 \cdot a\right) \cdot c}}{3 \cdot a} \le -3.6373948679911628 \cdot 10^{-7}:\\
\;\;\;\;\frac{\frac{\mathsf{fma}\left(b, b, -\left(b \cdot b - \left(3 \cdot a\right) \cdot c\right)\right)}{\left(-b\right) - \sqrt{b \cdot b - \left(3 \cdot a\right) \cdot c}}}{3 \cdot a}\\
\mathbf{else}:\\
\;\;\;\;-0.5 \cdot \frac{c}{b}\\
\end{array}double f(double a, double b, double c) {
double r104540 = b;
double r104541 = -r104540;
double r104542 = r104540 * r104540;
double r104543 = 3.0;
double r104544 = a;
double r104545 = r104543 * r104544;
double r104546 = c;
double r104547 = r104545 * r104546;
double r104548 = r104542 - r104547;
double r104549 = sqrt(r104548);
double r104550 = r104541 + r104549;
double r104551 = r104550 / r104545;
return r104551;
}
double f(double a, double b, double c) {
double r104552 = b;
double r104553 = -r104552;
double r104554 = r104552 * r104552;
double r104555 = 3.0;
double r104556 = a;
double r104557 = r104555 * r104556;
double r104558 = c;
double r104559 = r104557 * r104558;
double r104560 = r104554 - r104559;
double r104561 = sqrt(r104560);
double r104562 = r104553 + r104561;
double r104563 = r104562 / r104557;
double r104564 = -3.637394867991163e-07;
bool r104565 = r104563 <= r104564;
double r104566 = -r104560;
double r104567 = fma(r104552, r104552, r104566);
double r104568 = r104553 - r104561;
double r104569 = r104567 / r104568;
double r104570 = r104569 / r104557;
double r104571 = -0.5;
double r104572 = r104558 / r104552;
double r104573 = r104571 * r104572;
double r104574 = r104565 ? r104570 : r104573;
return r104574;
}



Bits error versus a



Bits error versus b



Bits error versus c
if (/ (+ (- b) (sqrt (- (* b b) (* (* 3.0 a) c)))) (* 3.0 a)) < -3.637394867991163e-07Initial program 18.8
rmApplied flip-+18.8
Simplified18.0
if -3.637394867991163e-07 < (/ (+ (- b) (sqrt (- (* b b) (* (* 3.0 a) c)))) (* 3.0 a)) Initial program 43.7
Taylor expanded around inf 10.5
Final simplification15.1
herbie shell --seed 2020056 +o rules:numerics
(FPCore (a b c)
:name "Cubic critical, narrow range"
:precision binary64
:pre (and (< 1.0536712127723509e-08 a 94906265.62425156) (< 1.0536712127723509e-08 b 94906265.62425156) (< 1.0536712127723509e-08 c 94906265.62425156))
(/ (+ (- b) (sqrt (- (* b b) (* (* 3 a) c)))) (* 3 a)))