\frac{\left(-b\right) + \sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}}{2 \cdot a}\frac{0 + 4 \cdot \left(a \cdot c\right)}{\left(2 \cdot a\right) \cdot \left(-b\right) + \left(2 \cdot a\right) \cdot \left(-\sqrt{b \cdot b - \left(4 \cdot a\right) \cdot c}\right)}double f(double a, double b, double c) {
double r31076 = b;
double r31077 = -r31076;
double r31078 = r31076 * r31076;
double r31079 = 4.0;
double r31080 = a;
double r31081 = r31079 * r31080;
double r31082 = c;
double r31083 = r31081 * r31082;
double r31084 = r31078 - r31083;
double r31085 = sqrt(r31084);
double r31086 = r31077 + r31085;
double r31087 = 2.0;
double r31088 = r31087 * r31080;
double r31089 = r31086 / r31088;
return r31089;
}
double f(double a, double b, double c) {
double r31090 = 0.0;
double r31091 = 4.0;
double r31092 = a;
double r31093 = c;
double r31094 = r31092 * r31093;
double r31095 = r31091 * r31094;
double r31096 = r31090 + r31095;
double r31097 = 2.0;
double r31098 = r31097 * r31092;
double r31099 = b;
double r31100 = -r31099;
double r31101 = r31098 * r31100;
double r31102 = r31099 * r31099;
double r31103 = r31091 * r31092;
double r31104 = r31103 * r31093;
double r31105 = r31102 - r31104;
double r31106 = sqrt(r31105);
double r31107 = -r31106;
double r31108 = r31098 * r31107;
double r31109 = r31101 + r31108;
double r31110 = r31096 / r31109;
return r31110;
}



Bits error versus a



Bits error versus b



Bits error versus c
Results
Initial program 28.6
rmApplied flip-+28.6
Simplified0.4
rmApplied div-inv0.5
Applied associate-/l*0.5
Simplified0.5
rmApplied sub-neg0.5
Applied distribute-lft-in0.4
Final simplification0.4
herbie shell --seed 2020020
(FPCore (a b c)
:name "Quadratic roots, 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) (* (* 4 a) c)))) (* 2 a)))