\frac{\left(-b\right) + \sqrt{b \cdot b - \left(3 \cdot a\right) \cdot c}}{3 \cdot a}\frac{\left({b}^{2} - {b}^{2}\right) + \left(3 \cdot a\right) \cdot c}{\left(3 \cdot a\right) \cdot \left(-b\right) + \left(3 \cdot a\right) \cdot \left(-\sqrt{b \cdot b - \left(3 \cdot a\right) \cdot c}\right)}double f(double a, double b, double c) {
double r102143 = b;
double r102144 = -r102143;
double r102145 = r102143 * r102143;
double r102146 = 3.0;
double r102147 = a;
double r102148 = r102146 * r102147;
double r102149 = c;
double r102150 = r102148 * r102149;
double r102151 = r102145 - r102150;
double r102152 = sqrt(r102151);
double r102153 = r102144 + r102152;
double r102154 = r102153 / r102148;
return r102154;
}
double f(double a, double b, double c) {
double r102155 = b;
double r102156 = 2.0;
double r102157 = pow(r102155, r102156);
double r102158 = r102157 - r102157;
double r102159 = 3.0;
double r102160 = a;
double r102161 = r102159 * r102160;
double r102162 = c;
double r102163 = r102161 * r102162;
double r102164 = r102158 + r102163;
double r102165 = -r102155;
double r102166 = r102161 * r102165;
double r102167 = r102155 * r102155;
double r102168 = r102167 - r102163;
double r102169 = sqrt(r102168);
double r102170 = -r102169;
double r102171 = r102161 * r102170;
double r102172 = r102166 + r102171;
double r102173 = r102164 / r102172;
return r102173;
}



Bits error versus a



Bits error versus b



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