\frac{x \cdot 2}{y \cdot z - t \cdot z}\begin{array}{l}
\mathbf{if}\;x \cdot 2 \le -8.487545604087800663717439236716923273121 \cdot 10^{116}:\\
\;\;\;\;\frac{\sqrt[3]{\frac{x \cdot 2}{y - t}} \cdot \sqrt[3]{\frac{x \cdot 2}{y - t}}}{\frac{z}{\sqrt[3]{\frac{x \cdot 2}{y - t}}}}\\
\mathbf{elif}\;x \cdot 2 \le 4.672191924242227383090621876278125047429 \cdot 10^{-197}:\\
\;\;\;\;\frac{\frac{x \cdot 2}{z}}{y - t}\\
\mathbf{elif}\;x \cdot 2 \le 3.071367817763602617128651373833917514734 \cdot 10^{113}:\\
\;\;\;\;\frac{\frac{x \cdot 2}{\left(\sqrt[3]{z} \cdot \sqrt[3]{z}\right) \cdot \left(y - t\right)}}{\sqrt[3]{z}}\\
\mathbf{else}:\\
\;\;\;\;\frac{\sqrt[3]{\frac{x \cdot 2}{y - t}} \cdot \sqrt[3]{\frac{x \cdot 2}{y - t}}}{\frac{z}{\sqrt[3]{\frac{x \cdot 2}{y - t}}}}\\
\end{array}double f(double x, double y, double z, double t) {
double r525781 = x;
double r525782 = 2.0;
double r525783 = r525781 * r525782;
double r525784 = y;
double r525785 = z;
double r525786 = r525784 * r525785;
double r525787 = t;
double r525788 = r525787 * r525785;
double r525789 = r525786 - r525788;
double r525790 = r525783 / r525789;
return r525790;
}
double f(double x, double y, double z, double t) {
double r525791 = x;
double r525792 = 2.0;
double r525793 = r525791 * r525792;
double r525794 = -8.4875456040878e+116;
bool r525795 = r525793 <= r525794;
double r525796 = y;
double r525797 = t;
double r525798 = r525796 - r525797;
double r525799 = r525793 / r525798;
double r525800 = cbrt(r525799);
double r525801 = r525800 * r525800;
double r525802 = z;
double r525803 = r525802 / r525800;
double r525804 = r525801 / r525803;
double r525805 = 4.6721919242422274e-197;
bool r525806 = r525793 <= r525805;
double r525807 = r525793 / r525802;
double r525808 = r525807 / r525798;
double r525809 = 3.0713678177636026e+113;
bool r525810 = r525793 <= r525809;
double r525811 = cbrt(r525802);
double r525812 = r525811 * r525811;
double r525813 = r525812 * r525798;
double r525814 = r525793 / r525813;
double r525815 = r525814 / r525811;
double r525816 = r525810 ? r525815 : r525804;
double r525817 = r525806 ? r525808 : r525816;
double r525818 = r525795 ? r525804 : r525817;
return r525818;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 6.6 |
|---|---|
| Target | 1.9 |
| Herbie | 2.9 |
if (* x 2.0) < -8.4875456040878e+116 or 3.0713678177636026e+113 < (* x 2.0) Initial program 14.4
Simplified14.7
rmApplied associate-*r/4.0
Simplified3.9
rmApplied add-cube-cbrt4.9
Applied associate-/l*4.9
if -8.4875456040878e+116 < (* x 2.0) < 4.6721919242422274e-197Initial program 3.8
Simplified2.3
rmApplied *-un-lft-identity2.3
Applied add-cube-cbrt2.9
Applied times-frac2.9
Applied associate-*r*5.1
Simplified5.1
rmApplied associate-*l/2.9
Simplified2.2
if 4.6721919242422274e-197 < (* x 2.0) < 3.0713678177636026e+113Initial program 3.5
Simplified2.8
rmApplied associate-*r/4.6
Simplified4.5
rmApplied add-cube-cbrt5.3
Applied associate-/r*5.3
Simplified2.1
Final simplification2.9
herbie shell --seed 2019194
(FPCore (x y z t)
:name "Linear.Projection:infinitePerspective from linear-1.19.1.3, A"
: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.045027827330126e-269) (/ (* (/ x z) 2.0) (- y t)) (* (/ x (* (- y t) z)) 2.0)))
(/ (* x 2.0) (- (* y z) (* t z))))