\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}\;t \le -2.6023650830861039 \cdot 10^{-202}:\\
\;\;\;\;\left(t \cdot \left(\left(\left(x \cdot 18\right) \cdot y\right) \cdot z - a \cdot 4\right) + b \cdot c\right) - \left(\left(x \cdot 4\right) \cdot i + \left(\left(j \cdot 27\right) \cdot \left(\sqrt[3]{k} \cdot \sqrt[3]{k}\right)\right) \cdot \sqrt[3]{k}\right)\\
\mathbf{elif}\;t \le 1.24034573106726284 \cdot 10^{-70}:\\
\;\;\;\;\left(t \cdot \left(-a \cdot 4\right) + b \cdot c\right) - \left(\left(x \cdot 4\right) \cdot i + j \cdot \left(27 \cdot k\right)\right)\\
\mathbf{else}:\\
\;\;\;\;\left(t \cdot \left(\left(x \cdot 18\right) \cdot \left(y \cdot z\right) - a \cdot 4\right) + b \cdot c\right) - \left(\left(x \cdot 4\right) \cdot i + j \cdot \left(27 \cdot k\right)\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 r1493836 = x;
double r1493837 = 18.0;
double r1493838 = r1493836 * r1493837;
double r1493839 = y;
double r1493840 = r1493838 * r1493839;
double r1493841 = z;
double r1493842 = r1493840 * r1493841;
double r1493843 = t;
double r1493844 = r1493842 * r1493843;
double r1493845 = a;
double r1493846 = 4.0;
double r1493847 = r1493845 * r1493846;
double r1493848 = r1493847 * r1493843;
double r1493849 = r1493844 - r1493848;
double r1493850 = b;
double r1493851 = c;
double r1493852 = r1493850 * r1493851;
double r1493853 = r1493849 + r1493852;
double r1493854 = r1493836 * r1493846;
double r1493855 = i;
double r1493856 = r1493854 * r1493855;
double r1493857 = r1493853 - r1493856;
double r1493858 = j;
double r1493859 = 27.0;
double r1493860 = r1493858 * r1493859;
double r1493861 = k;
double r1493862 = r1493860 * r1493861;
double r1493863 = r1493857 - r1493862;
return r1493863;
}
double f(double x, double y, double z, double t, double a, double b, double c, double i, double j, double k) {
double r1493864 = t;
double r1493865 = -2.602365083086104e-202;
bool r1493866 = r1493864 <= r1493865;
double r1493867 = x;
double r1493868 = 18.0;
double r1493869 = r1493867 * r1493868;
double r1493870 = y;
double r1493871 = r1493869 * r1493870;
double r1493872 = z;
double r1493873 = r1493871 * r1493872;
double r1493874 = a;
double r1493875 = 4.0;
double r1493876 = r1493874 * r1493875;
double r1493877 = r1493873 - r1493876;
double r1493878 = r1493864 * r1493877;
double r1493879 = b;
double r1493880 = c;
double r1493881 = r1493879 * r1493880;
double r1493882 = r1493878 + r1493881;
double r1493883 = r1493867 * r1493875;
double r1493884 = i;
double r1493885 = r1493883 * r1493884;
double r1493886 = j;
double r1493887 = 27.0;
double r1493888 = r1493886 * r1493887;
double r1493889 = k;
double r1493890 = cbrt(r1493889);
double r1493891 = r1493890 * r1493890;
double r1493892 = r1493888 * r1493891;
double r1493893 = r1493892 * r1493890;
double r1493894 = r1493885 + r1493893;
double r1493895 = r1493882 - r1493894;
double r1493896 = 1.2403457310672628e-70;
bool r1493897 = r1493864 <= r1493896;
double r1493898 = -r1493876;
double r1493899 = r1493864 * r1493898;
double r1493900 = r1493899 + r1493881;
double r1493901 = r1493887 * r1493889;
double r1493902 = r1493886 * r1493901;
double r1493903 = r1493885 + r1493902;
double r1493904 = r1493900 - r1493903;
double r1493905 = r1493870 * r1493872;
double r1493906 = r1493869 * r1493905;
double r1493907 = r1493906 - r1493876;
double r1493908 = r1493864 * r1493907;
double r1493909 = r1493908 + r1493881;
double r1493910 = r1493909 - r1493903;
double r1493911 = r1493897 ? r1493904 : r1493910;
double r1493912 = r1493866 ? r1493895 : r1493911;
return r1493912;
}




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.2 |
|---|---|
| Target | 1.5 |
| Herbie | 4.7 |
if t < -2.602365083086104e-202Initial program 4.2
Simplified4.2
rmApplied add-cube-cbrt4.4
Applied associate-*r*4.4
if -2.602365083086104e-202 < t < 1.2403457310672628e-70Initial program 8.3
Simplified8.3
rmApplied associate-*l*8.4
Taylor expanded around 0 6.0
if 1.2403457310672628e-70 < t Initial program 2.3
Simplified2.3
rmApplied associate-*l*2.3
rmApplied associate-*l*3.5
Final simplification4.7
herbie shell --seed 2020047
(FPCore (x y z t a b c i j k)
:name "Diagrams.Solve.Polynomial:cubForm from diagrams-solve-0.1, E"
:precision binary64
:herbie-target
(if (< t -1.6210815397541398e-69) (- (- (* (* 18 t) (* (* x y) z)) (* (+ (* a t) (* i x)) 4)) (- (* (* k j) 27) (* c b))) (if (< t 165.68027943805222) (+ (- (* (* 18 y) (* x (* z t))) (* (+ (* a t) (* i x)) 4)) (- (* c b) (* 27 (* k j)))) (- (- (* (* 18 t) (* (* x y) z)) (* (+ (* a t) (* i x)) 4)) (- (* (* k j) 27) (* c b)))))
(- (- (+ (- (* (* (* (* x 18) y) z) t) (* (* a 4) t)) (* b c)) (* (* x 4) i)) (* (* j 27) k)))