\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 r81912 = b;
double r81913 = -r81912;
double r81914 = r81912 * r81912;
double r81915 = 3.0;
double r81916 = a;
double r81917 = r81915 * r81916;
double r81918 = c;
double r81919 = r81917 * r81918;
double r81920 = r81914 - r81919;
double r81921 = sqrt(r81920);
double r81922 = r81913 + r81921;
double r81923 = r81922 / r81917;
return r81923;
}
double f(double a, double b, double c) {
double r81924 = b;
double r81925 = 2.0;
double r81926 = pow(r81924, r81925);
double r81927 = r81926 - r81926;
double r81928 = 3.0;
double r81929 = a;
double r81930 = r81928 * r81929;
double r81931 = c;
double r81932 = r81930 * r81931;
double r81933 = r81927 + r81932;
double r81934 = -r81924;
double r81935 = r81924 * r81924;
double r81936 = r81935 - r81932;
double r81937 = sqrt(r81936);
double r81938 = r81934 - r81937;
double r81939 = r81933 / r81938;
double r81940 = r81939 / r81930;
return r81940;
}



Bits error versus a



Bits error versus b



Bits error versus c
Results
Initial program 52.8
rmApplied flip-+52.8
Simplified0.5
rmApplied associate-*r*0.4
Final simplification0.4
herbie shell --seed 2020057
(FPCore (a b c)
:name "Cubic critical, wide range"
:precision binary64
:pre (and (< 4.9303800000000003e-32 a 2.02824e+31) (< 4.9303800000000003e-32 b 2.02824e+31) (< 4.9303800000000003e-32 c 2.02824e+31))
(/ (+ (- b) (sqrt (- (* b b) (* (* 3 a) c)))) (* 3 a)))