double f(double a, double b, double c, double __attribute__((unused)) d) {
double r14234923 = b;
double r14234924 = -r14234923;
double r14234925 = r14234923 * r14234923;
double r14234926 = 3.0;
double r14234927 = a;
double r14234928 = r14234926 * r14234927;
double r14234929 = c;
double r14234930 = r14234928 * r14234929;
double r14234931 = r14234925 - r14234930;
double r14234932 = sqrt(r14234931);
double r14234933 = r14234924 + r14234932;
double r14234934 = r14234933 / r14234928;
return r14234934;
}
double f(double a, double b, double c, double __attribute__((unused)) d) {
double r14234935 = -3.0;
double r14234936 = a;
double r14234937 = c;
double r14234938 = r14234936 * r14234937;
double r14234939 = b;
double r14234940 = r14234939 * r14234939;
double r14234941 = fma(r14234935, r14234938, r14234940);
double r14234942 = 0.3333333333333333;
double r14234943 = pow(r14234941, r14234942);
double r14234944 = sqrt(r14234941);
double r14234945 = cbrt(r14234944);
double r14234946 = r14234945 * r14234945;
double r14234947 = r14234946 * r14234946;
double r14234948 = r14234943 * r14234947;
double r14234949 = sqrt(r14234948);
double r14234950 = sqrt(r14234949);
double r14234951 = sqrt(r14234944);
double r14234952 = -r14234939;
double r14234953 = fma(r14234950, r14234951, r14234952);
double r14234954 = 3.0;
double r14234955 = r14234954 * r14234936;
double r14234956 = r14234953 / r14234955;
return r14234956;
}
\frac{\left(-b\right) + \sqrt{b \cdot b - \left(3 \cdot a\right) \cdot c}}{3 \cdot a}\frac{(\left(\sqrt{\sqrt{{\left((-3 \cdot \left(a \cdot c\right) + \left(b \cdot b\right))_*\right)}^{\frac{1}{3}} \cdot \left(\left(\sqrt[3]{\sqrt{(-3 \cdot \left(a \cdot c\right) + \left(b \cdot b\right))_*}} \cdot \sqrt[3]{\sqrt{(-3 \cdot \left(a \cdot c\right) + \left(b \cdot b\right))_*}}\right) \cdot \left(\sqrt[3]{\sqrt{(-3 \cdot \left(a \cdot c\right) + \left(b \cdot b\right))_*}} \cdot \sqrt[3]{\sqrt{(-3 \cdot \left(a \cdot c\right) + \left(b \cdot b\right))_*}}\right)\right)}}\right) \cdot \left(\sqrt{\sqrt{(-3 \cdot \left(a \cdot c\right) + \left(b \cdot b\right))_*}}\right) + \left(-b\right))_*}{3 \cdot a}


Bits error versus a



Bits error versus b



Bits error versus c



Bits error versus d
Initial program 52.5
Simplified52.5
rmApplied add-sqr-sqrt52.5
Applied sqrt-prod52.3
Applied fma-neg51.7
rmApplied add-cube-cbrt51.9
rmApplied pow1/350.7
rmApplied add-sqr-sqrt50.7
Applied cbrt-prod50.7
Applied add-sqr-sqrt50.7
Applied cbrt-prod50.7
Applied swap-sqr50.7
Final simplification50.7
herbie shell --seed 2019102 +o rules:numerics
(FPCore (a b c d)
:name "Cubic critical, wide range"
:pre (and (< 4.930380657631324e-32 a 2.028240960365167e+31) (< 4.930380657631324e-32 b 2.028240960365167e+31) (< 4.930380657631324e-32 c 2.028240960365167e+31))
(/ (+ (- b) (sqrt (- (* b b) (* (* 3 a) c)))) (* 3 a)))