\frac{x \cdot 2}{y \cdot z - t \cdot z}\begin{array}{l}
\mathbf{if}\;z \le -1.17849036859476826 \cdot 10^{26}:\\
\;\;\;\;\frac{x}{z} \cdot \frac{2}{y - t}\\
\mathbf{elif}\;z \le 8.30947769597875437 \cdot 10^{-100}:\\
\;\;\;\;\frac{x \cdot 2}{z \cdot \left(y - t\right)}\\
\mathbf{else}:\\
\;\;\;\;\left(x \cdot \frac{\sqrt{2}}{\sqrt[3]{y - t} \cdot \sqrt[3]{y - t}}\right) \cdot \frac{\frac{\sqrt{2}}{z}}{\sqrt[3]{y - t}}\\
\end{array}double code(double x, double y, double z, double t) {
return ((double) (((double) (x * 2.0)) / ((double) (((double) (y * z)) - ((double) (t * z))))));
}
double code(double x, double y, double z, double t) {
double VAR;
if ((z <= -1.1784903685947683e+26)) {
VAR = ((double) (((double) (x / z)) * ((double) (2.0 / ((double) (y - t))))));
} else {
double VAR_1;
if ((z <= 8.309477695978754e-100)) {
VAR_1 = ((double) (((double) (x * 2.0)) / ((double) (z * ((double) (y - t))))));
} else {
VAR_1 = ((double) (((double) (x * ((double) (((double) sqrt(2.0)) / ((double) (((double) cbrt(((double) (y - t)))) * ((double) cbrt(((double) (y - t)))))))))) * ((double) (((double) (((double) sqrt(2.0)) / z)) / ((double) cbrt(((double) (y - t))))))));
}
VAR = VAR_1;
}
return VAR;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 6.8 |
|---|---|
| Target | 2.0 |
| Herbie | 2.6 |
if z < -1.17849036859476826e26Initial program 11.7
Simplified9.8
rmApplied *-un-lft-identity9.8
Applied times-frac9.2
Applied associate-*r*2.3
Simplified2.2
if -1.17849036859476826e26 < z < 8.30947769597875437e-100Initial program 2.6
Simplified3.1
rmApplied associate-*r/2.6
if 8.30947769597875437e-100 < z Initial program 8.4
Simplified6.7
rmApplied associate-/r*6.2
rmApplied add-cube-cbrt6.7
Applied *-un-lft-identity6.7
Applied add-sqr-sqrt6.8
Applied times-frac6.8
Applied times-frac6.8
Applied associate-*r*2.9
Simplified2.9
Final simplification2.6
herbie shell --seed 2020179
(FPCore (x y z t)
:name "Linear.Projection:infinitePerspective from linear-1.19.1.3, A"
:precision binary64
:herbie-target
(if (< (/ (* x 2.0) (- (* y z) (* t z))) -2.559141628295061e-13) (* (/ x (* (- y t) z)) 2.0) (if (< (/ (* x 2.0) (- (* y z) (* t z))) 1.0450278273301259e-269) (/ (* (/ x z) 2.0) (- y t)) (* (/ x (* (- y t) z)) 2.0)))
(/ (* x 2.0) (- (* y z) (* t z))))