\frac{x \cdot y - \left(z \cdot 9\right) \cdot t}{a \cdot 2}\begin{array}{l}
\mathbf{if}\;x \cdot y - \left(z \cdot 9\right) \cdot t = -\infty \lor \neg \left(x \cdot y - \left(z \cdot 9\right) \cdot t \le 1.2344983160605906 \cdot 10^{285}\right):\\
\;\;\;\;0.5 \cdot \left(x \cdot \frac{y}{a}\right) - 4.5 \cdot \left(\frac{t}{\sqrt[3]{a} \cdot \sqrt[3]{a}} \cdot \frac{z}{\sqrt[3]{a}}\right)\\
\mathbf{else}:\\
\;\;\;\;\frac{0.5 \cdot \left(x \cdot y\right) - 4.5 \cdot \left(t \cdot z\right)}{a}\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r802093 = x;
double r802094 = y;
double r802095 = r802093 * r802094;
double r802096 = z;
double r802097 = 9.0;
double r802098 = r802096 * r802097;
double r802099 = t;
double r802100 = r802098 * r802099;
double r802101 = r802095 - r802100;
double r802102 = a;
double r802103 = 2.0;
double r802104 = r802102 * r802103;
double r802105 = r802101 / r802104;
return r802105;
}
double f(double x, double y, double z, double t, double a) {
double r802106 = x;
double r802107 = y;
double r802108 = r802106 * r802107;
double r802109 = z;
double r802110 = 9.0;
double r802111 = r802109 * r802110;
double r802112 = t;
double r802113 = r802111 * r802112;
double r802114 = r802108 - r802113;
double r802115 = -inf.0;
bool r802116 = r802114 <= r802115;
double r802117 = 1.2344983160605906e+285;
bool r802118 = r802114 <= r802117;
double r802119 = !r802118;
bool r802120 = r802116 || r802119;
double r802121 = 0.5;
double r802122 = a;
double r802123 = r802107 / r802122;
double r802124 = r802106 * r802123;
double r802125 = r802121 * r802124;
double r802126 = 4.5;
double r802127 = cbrt(r802122);
double r802128 = r802127 * r802127;
double r802129 = r802112 / r802128;
double r802130 = r802109 / r802127;
double r802131 = r802129 * r802130;
double r802132 = r802126 * r802131;
double r802133 = r802125 - r802132;
double r802134 = r802121 * r802108;
double r802135 = r802112 * r802109;
double r802136 = r802126 * r802135;
double r802137 = r802134 - r802136;
double r802138 = r802137 / r802122;
double r802139 = r802120 ? r802133 : r802138;
return r802139;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 7.7 |
|---|---|
| Target | 5.8 |
| Herbie | 0.8 |
if (- (* x y) (* (* z 9.0) t)) < -inf.0 or 1.2344983160605906e+285 < (- (* x y) (* (* z 9.0) t)) Initial program 57.1
Taylor expanded around 0 57.0
rmApplied add-cube-cbrt57.0
Applied times-frac31.3
rmApplied *-un-lft-identity31.3
Applied times-frac0.9
Simplified0.9
if -inf.0 < (- (* x y) (* (* z 9.0) t)) < 1.2344983160605906e+285Initial program 0.9
Taylor expanded around 0 0.9
rmApplied associate-*r/0.9
Applied associate-*r/0.8
Applied sub-div0.8
Final simplification0.8
herbie shell --seed 2020042
(FPCore (x y z t a)
:name "Diagrams.Solve.Polynomial:cubForm from diagrams-solve-0.1, I"
:precision binary64
:herbie-target
(if (< a -2.090464557976709e+86) (- (* 0.5 (/ (* y x) a)) (* 4.5 (/ t (/ a z)))) (if (< a 2.144030707833976e+99) (/ (- (* x y) (* z (* 9 t))) (* a 2)) (- (* (/ y a) (* x 0.5)) (* (/ t a) (* z 4.5)))))
(/ (- (* x y) (* (* z 9) t)) (* a 2)))