\left(\left(\left(\left(\left(\left(x \cdot 18\right) \cdot y\right) \cdot z\right) \cdot t - \left(a \cdot 4\right) \cdot t\right) + b \cdot c\right) - \left(x \cdot 4\right) \cdot i\right) - \left(j \cdot 27\right) \cdot k
\begin{array}{l}
\mathbf{if}\;\left(\left(t \cdot \left(\left(\left(x \cdot 18\right) \cdot y\right) \cdot z\right) - \left(a \cdot 4\right) \cdot t\right) + c \cdot b\right) - \left(x \cdot 4\right) \cdot i = -\infty \lor \neg \left(\left(\left(t \cdot \left(\left(\left(x \cdot 18\right) \cdot y\right) \cdot z\right) - \left(a \cdot 4\right) \cdot t\right) + c \cdot b\right) - \left(x \cdot 4\right) \cdot i \le 4.448119603122321026114316643374029554495 \cdot 10^{305}\right):\\
\;\;\;\;\left(\left(c \cdot b + \left(\left(y \cdot \left(\left(t \cdot x\right) \cdot z\right)\right) \cdot 18 - \left(a \cdot 4\right) \cdot t\right)\right) - \left(x \cdot 4\right) \cdot i\right) - k \cdot \left(j \cdot 27\right)\\
\mathbf{else}:\\
\;\;\;\;\left(\left(\left(t \cdot \left(\left(\left(x \cdot 18\right) \cdot y\right) \cdot z\right) - \left(a \cdot 4\right) \cdot t\right) + c \cdot b\right) - \left(x \cdot 4\right) \cdot i\right) - \left(\sqrt[3]{k \cdot 27} \cdot \sqrt[3]{j}\right) \cdot \left(\sqrt[3]{\left(k \cdot 27\right) \cdot j} \cdot \sqrt[3]{\left(k \cdot 27\right) \cdot j}\right)\\
\end{array}double f(double x, double y, double z, double t, double a, double b, double c, double i, double j, double k) {
double r532953 = x;
double r532954 = 18.0;
double r532955 = r532953 * r532954;
double r532956 = y;
double r532957 = r532955 * r532956;
double r532958 = z;
double r532959 = r532957 * r532958;
double r532960 = t;
double r532961 = r532959 * r532960;
double r532962 = a;
double r532963 = 4.0;
double r532964 = r532962 * r532963;
double r532965 = r532964 * r532960;
double r532966 = r532961 - r532965;
double r532967 = b;
double r532968 = c;
double r532969 = r532967 * r532968;
double r532970 = r532966 + r532969;
double r532971 = r532953 * r532963;
double r532972 = i;
double r532973 = r532971 * r532972;
double r532974 = r532970 - r532973;
double r532975 = j;
double r532976 = 27.0;
double r532977 = r532975 * r532976;
double r532978 = k;
double r532979 = r532977 * r532978;
double r532980 = r532974 - r532979;
return r532980;
}
double f(double x, double y, double z, double t, double a, double b, double c, double i, double j, double k) {
double r532981 = t;
double r532982 = x;
double r532983 = 18.0;
double r532984 = r532982 * r532983;
double r532985 = y;
double r532986 = r532984 * r532985;
double r532987 = z;
double r532988 = r532986 * r532987;
double r532989 = r532981 * r532988;
double r532990 = a;
double r532991 = 4.0;
double r532992 = r532990 * r532991;
double r532993 = r532992 * r532981;
double r532994 = r532989 - r532993;
double r532995 = c;
double r532996 = b;
double r532997 = r532995 * r532996;
double r532998 = r532994 + r532997;
double r532999 = r532982 * r532991;
double r533000 = i;
double r533001 = r532999 * r533000;
double r533002 = r532998 - r533001;
double r533003 = -inf.0;
bool r533004 = r533002 <= r533003;
double r533005 = 4.448119603122321e+305;
bool r533006 = r533002 <= r533005;
double r533007 = !r533006;
bool r533008 = r533004 || r533007;
double r533009 = r532981 * r532982;
double r533010 = r533009 * r532987;
double r533011 = r532985 * r533010;
double r533012 = r533011 * r532983;
double r533013 = r533012 - r532993;
double r533014 = r532997 + r533013;
double r533015 = r533014 - r533001;
double r533016 = k;
double r533017 = j;
double r533018 = 27.0;
double r533019 = r533017 * r533018;
double r533020 = r533016 * r533019;
double r533021 = r533015 - r533020;
double r533022 = r533016 * r533018;
double r533023 = cbrt(r533022);
double r533024 = cbrt(r533017);
double r533025 = r533023 * r533024;
double r533026 = r533022 * r533017;
double r533027 = cbrt(r533026);
double r533028 = r533027 * r533027;
double r533029 = r533025 * r533028;
double r533030 = r533002 - r533029;
double r533031 = r533008 ? r533021 : r533030;
return r533031;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a




Bits error versus b




Bits error versus c




Bits error versus i




Bits error versus j




Bits error versus k
Results
| Original | 5.8 |
|---|---|
| Target | 1.4 |
| Herbie | 1.1 |
if (- (+ (- (* (* (* (* x 18.0) y) z) t) (* (* a 4.0) t)) (* b c)) (* (* x 4.0) i)) < -inf.0 or 4.448119603122321e+305 < (- (+ (- (* (* (* (* x 18.0) y) z) t) (* (* a 4.0) t)) (* b c)) (* (* x 4.0) i)) Initial program 61.8
Taylor expanded around inf 40.6
Simplified6.2
if -inf.0 < (- (+ (- (* (* (* (* x 18.0) y) z) t) (* (* a 4.0) t)) (* b c)) (* (* x 4.0) i)) < 4.448119603122321e+305Initial program 0.3
rmApplied add-cube-cbrt0.6
Simplified0.7
Simplified0.6
rmApplied cbrt-prod0.6
Simplified0.6
Final simplification1.1
herbie shell --seed 2019196
(FPCore (x y z t a b c i j k)
:name "Diagrams.Solve.Polynomial:cubForm from diagrams-solve-0.1, E"
:herbie-target
(if (< t -1.6210815397541398e-69) (- (- (* (* 18.0 t) (* (* x y) z)) (* (+ (* a t) (* i x)) 4.0)) (- (* (* k j) 27.0) (* c b))) (if (< t 165.68027943805222) (+ (- (* (* 18.0 y) (* x (* z t))) (* (+ (* a t) (* i x)) 4.0)) (- (* c b) (* 27.0 (* k j)))) (- (- (* (* 18.0 t) (* (* x y) z)) (* (+ (* a t) (* i x)) 4.0)) (- (* (* k j) 27.0) (* c b)))))
(- (- (+ (- (* (* (* (* x 18.0) y) z) t) (* (* a 4.0) t)) (* b c)) (* (* x 4.0) i)) (* (* j 27.0) k)))