\frac{x \cdot 2}{y \cdot z - t \cdot z}\begin{array}{l}
\mathbf{if}\;z \le -49355.0736941491268:\\
\;\;\;\;\frac{\frac{x}{z}}{\frac{y - t}{2}}\\
\mathbf{elif}\;z \le 1.74137454924600484 \cdot 10^{79}:\\
\;\;\;\;\frac{x}{\frac{1 \cdot \left(z \cdot \left(y - t\right)\right)}{2}}\\
\mathbf{else}:\\
\;\;\;\;\frac{\sqrt[3]{x}}{\frac{z}{\sqrt[3]{x}}} \cdot \frac{\sqrt[3]{x}}{\frac{y - t}{2}}\\
\end{array}double f(double x, double y, double z, double t) {
double r751650 = x;
double r751651 = 2.0;
double r751652 = r751650 * r751651;
double r751653 = y;
double r751654 = z;
double r751655 = r751653 * r751654;
double r751656 = t;
double r751657 = r751656 * r751654;
double r751658 = r751655 - r751657;
double r751659 = r751652 / r751658;
return r751659;
}
double f(double x, double y, double z, double t) {
double r751660 = z;
double r751661 = -49355.07369414913;
bool r751662 = r751660 <= r751661;
double r751663 = x;
double r751664 = r751663 / r751660;
double r751665 = y;
double r751666 = t;
double r751667 = r751665 - r751666;
double r751668 = 2.0;
double r751669 = r751667 / r751668;
double r751670 = r751664 / r751669;
double r751671 = 1.741374549246005e+79;
bool r751672 = r751660 <= r751671;
double r751673 = 1.0;
double r751674 = r751660 * r751667;
double r751675 = r751673 * r751674;
double r751676 = r751675 / r751668;
double r751677 = r751663 / r751676;
double r751678 = cbrt(r751663);
double r751679 = r751660 / r751678;
double r751680 = r751678 / r751679;
double r751681 = r751678 / r751669;
double r751682 = r751680 * r751681;
double r751683 = r751672 ? r751677 : r751682;
double r751684 = r751662 ? r751670 : r751683;
return r751684;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 6.8 |
|---|---|
| Target | 2.2 |
| Herbie | 2.1 |
if z < -49355.07369414913Initial program 11.2
Simplified9.2
rmApplied *-un-lft-identity9.2
Applied times-frac9.2
Applied associate-/r*1.7
Simplified1.7
if -49355.07369414913 < z < 1.741374549246005e+79Initial program 2.4
Simplified2.4
rmApplied *-un-lft-identity2.4
if 1.741374549246005e+79 < z Initial program 12.7
Simplified10.3
rmApplied *-un-lft-identity10.3
Applied times-frac10.2
Applied add-cube-cbrt10.6
Applied times-frac1.9
Simplified1.9
Final simplification2.1
herbie shell --seed 2020060 +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))))