\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 \le -5.81880234558190669 \cdot 10^{134} \lor \neg \left(x \cdot y - \left(z \cdot 9\right) \cdot t \le 1.95624520253703639 \cdot 10^{220}\right):\\
\;\;\;\;\left(x \cdot 0.5\right) \cdot \frac{y}{a} - \left(t \cdot 4.5\right) \cdot \frac{z}{a}\\
\mathbf{else}:\\
\;\;\;\;\left(x \cdot y - \left(z \cdot 9\right) \cdot t\right) \cdot \frac{1}{a \cdot 2}\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r840534 = x;
double r840535 = y;
double r840536 = r840534 * r840535;
double r840537 = z;
double r840538 = 9.0;
double r840539 = r840537 * r840538;
double r840540 = t;
double r840541 = r840539 * r840540;
double r840542 = r840536 - r840541;
double r840543 = a;
double r840544 = 2.0;
double r840545 = r840543 * r840544;
double r840546 = r840542 / r840545;
return r840546;
}
double f(double x, double y, double z, double t, double a) {
double r840547 = x;
double r840548 = y;
double r840549 = r840547 * r840548;
double r840550 = z;
double r840551 = 9.0;
double r840552 = r840550 * r840551;
double r840553 = t;
double r840554 = r840552 * r840553;
double r840555 = r840549 - r840554;
double r840556 = -5.818802345581907e+134;
bool r840557 = r840555 <= r840556;
double r840558 = 1.9562452025370364e+220;
bool r840559 = r840555 <= r840558;
double r840560 = !r840559;
bool r840561 = r840557 || r840560;
double r840562 = 0.5;
double r840563 = r840547 * r840562;
double r840564 = a;
double r840565 = r840548 / r840564;
double r840566 = r840563 * r840565;
double r840567 = 4.5;
double r840568 = r840553 * r840567;
double r840569 = r840550 / r840564;
double r840570 = r840568 * r840569;
double r840571 = r840566 - r840570;
double r840572 = 1.0;
double r840573 = 2.0;
double r840574 = r840564 * r840573;
double r840575 = r840572 / r840574;
double r840576 = r840555 * r840575;
double r840577 = r840561 ? r840571 : r840576;
return r840577;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 8.0 |
|---|---|
| Target | 5.6 |
| Herbie | 1.7 |
if (- (* x y) (* (* z 9.0) t)) < -5.818802345581907e+134 or 1.9562452025370364e+220 < (- (* x y) (* (* z 9.0) t)) Initial program 24.6
Taylor expanded around 0 24.2
rmApplied *-un-lft-identity24.2
Applied times-frac14.1
Applied associate-*r*14.2
Simplified14.2
rmApplied *-un-lft-identity14.2
Applied times-frac2.9
Applied associate-*r*2.8
Simplified2.8
if -5.818802345581907e+134 < (- (* x y) (* (* z 9.0) t)) < 1.9562452025370364e+220Initial program 1.1
rmApplied div-inv1.2
Final simplification1.7
herbie shell --seed 2020100 +o rules:numerics
(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)))