\frac{\left(-b\right) + \sqrt{b \cdot b - \left(3 \cdot a\right) \cdot c}}{3 \cdot a}\frac{\frac{\left({b}^{2} - {b}^{2}\right) + \left(3 \cdot a\right) \cdot c}{\left(-b\right) - \sqrt{b \cdot b - \left(3 \cdot a\right) \cdot c}}}{3 \cdot a}double f(double a, double b, double c) {
double r97333 = b;
double r97334 = -r97333;
double r97335 = r97333 * r97333;
double r97336 = 3.0;
double r97337 = a;
double r97338 = r97336 * r97337;
double r97339 = c;
double r97340 = r97338 * r97339;
double r97341 = r97335 - r97340;
double r97342 = sqrt(r97341);
double r97343 = r97334 + r97342;
double r97344 = r97343 / r97338;
return r97344;
}
double f(double a, double b, double c) {
double r97345 = b;
double r97346 = 2.0;
double r97347 = pow(r97345, r97346);
double r97348 = r97347 - r97347;
double r97349 = 3.0;
double r97350 = a;
double r97351 = r97349 * r97350;
double r97352 = c;
double r97353 = r97351 * r97352;
double r97354 = r97348 + r97353;
double r97355 = -r97345;
double r97356 = r97345 * r97345;
double r97357 = r97356 - r97353;
double r97358 = sqrt(r97357);
double r97359 = r97355 - r97358;
double r97360 = r97354 / r97359;
double r97361 = r97360 / r97351;
return r97361;
}



Bits error versus a



Bits error versus b



Bits error versus c
Results
Initial program 28.3
rmApplied flip-+28.4
Simplified0.6
rmApplied associate-*r*0.4
Final simplification0.4
herbie shell --seed 2020083
(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)))