\frac{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\frac{1}{2} \cdot \frac{4 \cdot c}{\left(-b\right) - \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}double f(double a, double b, double c) {
double r46413 = b;
double r46414 = -r46413;
double r46415 = r46413 * r46413;
double r46416 = 4.0;
double r46417 = a;
double r46418 = r46416 * r46417;
double r46419 = c;
double r46420 = r46418 * r46419;
double r46421 = r46415 - r46420;
double r46422 = sqrt(r46421);
double r46423 = r46414 + r46422;
double r46424 = 2.0;
double r46425 = r46424 * r46417;
double r46426 = r46423 / r46425;
return r46426;
}
double f(double a, double b, double c) {
double r46427 = 1.0;
double r46428 = 2.0;
double r46429 = r46427 / r46428;
double r46430 = 4.0;
double r46431 = c;
double r46432 = r46430 * r46431;
double r46433 = b;
double r46434 = -r46433;
double r46435 = r46433 * r46433;
double r46436 = a;
double r46437 = r46430 * r46436;
double r46438 = r46437 * r46431;
double r46439 = r46435 - r46438;
double r46440 = sqrt(r46439);
double r46441 = r46434 - r46440;
double r46442 = r46432 / r46441;
double r46443 = r46429 * r46442;
return r46443;
}



Bits error versus a



Bits error versus b



Bits error versus c
Results
Initial program 43.8
rmApplied flip-+43.9
Simplified0.4
rmApplied *-un-lft-identity0.4
Applied *-un-lft-identity0.4
Applied times-frac0.4
Applied times-frac0.4
Simplified0.4
Simplified0.4
rmApplied associate-/r*0.2
rmApplied *-un-lft-identity0.2
Applied associate-/r*0.2
Simplified0.2
Final simplification0.2
herbie shell --seed 2019353
(FPCore (a b c)
:name "Quadratic roots, medium range"
:precision binary64
:pre (and (< 1.11022e-16 a 9.0072e+15) (< 1.11022e-16 b 9.0072e+15) (< 1.11022e-16 c 9.0072e+15))
(/ (+ (- b) (sqrt (- (* b b) (* (* 4 a) c)))) (* 2 a)))