\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 r886079 = x;
double r886080 = 18.0;
double r886081 = r886079 * r886080;
double r886082 = y;
double r886083 = r886081 * r886082;
double r886084 = z;
double r886085 = r886083 * r886084;
double r886086 = t;
double r886087 = r886085 * r886086;
double r886088 = a;
double r886089 = 4.0;
double r886090 = r886088 * r886089;
double r886091 = r886090 * r886086;
double r886092 = r886087 - r886091;
double r886093 = b;
double r886094 = c;
double r886095 = r886093 * r886094;
double r886096 = r886092 + r886095;
double r886097 = r886079 * r886089;
double r886098 = i;
double r886099 = r886097 * r886098;
double r886100 = r886096 - r886099;
double r886101 = j;
double r886102 = 27.0;
double r886103 = r886101 * r886102;
double r886104 = k;
double r886105 = r886103 * r886104;
double r886106 = r886100 - r886105;
return r886106;
}
double f(double x, double y, double z, double t, double a, double b, double c, double i, double j, double k) {
double r886107 = t;
double r886108 = -2.602365083086104e-202;
bool r886109 = r886107 <= r886108;
double r886110 = x;
double r886111 = 18.0;
double r886112 = r886110 * r886111;
double r886113 = y;
double r886114 = r886112 * r886113;
double r886115 = z;
double r886116 = r886114 * r886115;
double r886117 = a;
double r886118 = 4.0;
double r886119 = r886117 * r886118;
double r886120 = r886116 - r886119;
double r886121 = r886107 * r886120;
double r886122 = b;
double r886123 = c;
double r886124 = r886122 * r886123;
double r886125 = r886121 + r886124;
double r886126 = r886110 * r886118;
double r886127 = i;
double r886128 = r886126 * r886127;
double r886129 = j;
double r886130 = 27.0;
double r886131 = r886129 * r886130;
double r886132 = k;
double r886133 = cbrt(r886132);
double r886134 = r886133 * r886133;
double r886135 = r886131 * r886134;
double r886136 = r886135 * r886133;
double r886137 = r886128 + r886136;
double r886138 = r886125 - r886137;
double r886139 = 1.2403457310672628e-70;
bool r886140 = r886107 <= r886139;
double r886141 = -r886119;
double r886142 = r886107 * r886141;
double r886143 = r886142 + r886124;
double r886144 = r886130 * r886132;
double r886145 = r886129 * r886144;
double r886146 = r886128 + r886145;
double r886147 = r886143 - r886146;
double r886148 = r886113 * r886115;
double r886149 = r886112 * r886148;
double r886150 = r886149 - r886119;
double r886151 = r886107 * r886150;
double r886152 = r886151 + r886124;
double r886153 = r886152 - r886146;
double r886154 = r886140 ? r886147 : r886153;
double r886155 = r886109 ? r886138 : r886154;
return r886155;
}




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)))