\frac{\left(-b\right) + \sqrt{b \cdot b - \left(3 \cdot a\right) \cdot c}}{3 \cdot a}\begin{array}{l}
\mathbf{if}\;b \le 174.55343675894656:\\
\;\;\;\;\frac{\frac{\left(b \cdot b - c \cdot \left(3 \cdot a\right)\right) \cdot \sqrt{b \cdot b - c \cdot \left(3 \cdot a\right)} - \left(b \cdot b\right) \cdot b}{\left(b \cdot b - c \cdot \left(3 \cdot a\right)\right) + \left(b \cdot \sqrt{b \cdot b - c \cdot \left(3 \cdot a\right)} + b \cdot b\right)}}{3 \cdot a}\\
\mathbf{else}:\\
\;\;\;\;\frac{-1}{2} \cdot \frac{c}{b}\\
\end{array}double f(double a, double b, double c) {
double r3428323 = b;
double r3428324 = -r3428323;
double r3428325 = r3428323 * r3428323;
double r3428326 = 3.0;
double r3428327 = a;
double r3428328 = r3428326 * r3428327;
double r3428329 = c;
double r3428330 = r3428328 * r3428329;
double r3428331 = r3428325 - r3428330;
double r3428332 = sqrt(r3428331);
double r3428333 = r3428324 + r3428332;
double r3428334 = r3428333 / r3428328;
return r3428334;
}
double f(double a, double b, double c) {
double r3428335 = b;
double r3428336 = 174.55343675894656;
bool r3428337 = r3428335 <= r3428336;
double r3428338 = r3428335 * r3428335;
double r3428339 = c;
double r3428340 = 3.0;
double r3428341 = a;
double r3428342 = r3428340 * r3428341;
double r3428343 = r3428339 * r3428342;
double r3428344 = r3428338 - r3428343;
double r3428345 = sqrt(r3428344);
double r3428346 = r3428344 * r3428345;
double r3428347 = r3428338 * r3428335;
double r3428348 = r3428346 - r3428347;
double r3428349 = r3428335 * r3428345;
double r3428350 = r3428349 + r3428338;
double r3428351 = r3428344 + r3428350;
double r3428352 = r3428348 / r3428351;
double r3428353 = r3428352 / r3428342;
double r3428354 = -0.5;
double r3428355 = r3428339 / r3428335;
double r3428356 = r3428354 * r3428355;
double r3428357 = r3428337 ? r3428353 : r3428356;
return r3428357;
}



Bits error versus a



Bits error versus b



Bits error versus c
Results
if b < 174.55343675894656Initial program 15.8
Simplified15.8
rmApplied flip3--15.9
Simplified15.2
Simplified15.2
if 174.55343675894656 < b Initial program 35.3
Simplified35.3
Taylor expanded around inf 17.1
rmApplied *-un-lft-identity17.1
Applied times-frac17.1
Applied associate-*r*17.0
Simplified17.0
Taylor expanded around 0 17.0
Final simplification16.4
herbie shell --seed 2019158
(FPCore (a b c)
:name "Cubic critical, narrow range"
: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)))