\frac{x \cdot 2}{y \cdot z - t \cdot z}\begin{array}{l}
\mathbf{if}\;x \cdot 2 \le 1.20445290796802163 \cdot 10^{-28}:\\
\;\;\;\;\left(\left(2 \cdot x\right) \cdot \left(\sqrt[3]{\frac{1}{z}} \cdot \sqrt[3]{\frac{1}{z}}\right)\right) \cdot \frac{\sqrt[3]{\frac{1}{z}}}{y - t}\\
\mathbf{else}:\\
\;\;\;\;\frac{\frac{x \cdot 2}{y - t}}{z}\\
\end{array}double f(double x, double y, double z, double t) {
double r517482 = x;
double r517483 = 2.0;
double r517484 = r517482 * r517483;
double r517485 = y;
double r517486 = z;
double r517487 = r517485 * r517486;
double r517488 = t;
double r517489 = r517488 * r517486;
double r517490 = r517487 - r517489;
double r517491 = r517484 / r517490;
return r517491;
}
double f(double x, double y, double z, double t) {
double r517492 = x;
double r517493 = 2.0;
double r517494 = r517492 * r517493;
double r517495 = 1.2044529079680216e-28;
bool r517496 = r517494 <= r517495;
double r517497 = r517493 * r517492;
double r517498 = 1.0;
double r517499 = z;
double r517500 = r517498 / r517499;
double r517501 = cbrt(r517500);
double r517502 = r517501 * r517501;
double r517503 = r517497 * r517502;
double r517504 = y;
double r517505 = t;
double r517506 = r517504 - r517505;
double r517507 = r517501 / r517506;
double r517508 = r517503 * r517507;
double r517509 = r517494 / r517506;
double r517510 = r517509 / r517499;
double r517511 = r517496 ? r517508 : r517510;
return r517511;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 6.7 |
|---|---|
| Target | 2.0 |
| Herbie | 3.4 |
if (* x 2.0) < 1.2044529079680216e-28Initial program 5.7
Simplified4.5
rmApplied div-inv4.7
rmApplied associate-/r*4.5
rmApplied *-un-lft-identity4.5
Applied add-cube-cbrt5.1
Applied times-frac5.1
Applied associate-*r*3.7
Simplified3.7
if 1.2044529079680216e-28 < (* x 2.0) Initial program 9.8
Simplified9.0
rmApplied *-commutative9.0
rmApplied associate-/r*2.5
Final simplification3.4
herbie shell --seed 2020045 +o rules:numerics
(FPCore (x y z t)
:name "Linear.Projection:infinitePerspective from linear-1.19.1.3, A"
:precision binary64
:herbie-target
(if (< (/ (* x 2) (- (* y z) (* t z))) -2.559141628295061e-13) (* (/ x (* (- y t) z)) 2) (if (< (/ (* x 2) (- (* y z) (* t z))) 1.0450278273301259e-269) (/ (* (/ x z) 2) (- y t)) (* (/ x (* (- y t) z)) 2)))
(/ (* x 2) (- (* y z) (* t z))))