\frac{x \cdot 2}{y \cdot z - t \cdot z}\begin{array}{l}
\mathbf{if}\;z \le \frac{-3667224765870525}{6.150157786156810428392372384161183220787 \cdot 10^{259}}:\\
\;\;\;\;\frac{1}{\frac{1}{\sqrt[3]{\sqrt[3]{x}} \cdot \sqrt[3]{\sqrt[3]{x}}}} \cdot \left(\frac{\sqrt[3]{x}}{\frac{z}{\sqrt[3]{\sqrt[3]{x}}}} \cdot \frac{\sqrt[3]{x}}{\frac{y - t}{2}}\right)\\
\mathbf{elif}\;z \le 68239040246147683780956561417961472:\\
\;\;\;\;\frac{x}{\frac{{\left(z \cdot \left(y - t\right)\right)}^{1}}{2}}\\
\mathbf{else}:\\
\;\;\;\;\frac{1}{z} \cdot \frac{x}{\frac{y - t}{2}}\\
\end{array}double f(double x, double y, double z, double t) {
double r561657 = x;
double r561658 = 2.0;
double r561659 = r561657 * r561658;
double r561660 = y;
double r561661 = z;
double r561662 = r561660 * r561661;
double r561663 = t;
double r561664 = r561663 * r561661;
double r561665 = r561662 - r561664;
double r561666 = r561659 / r561665;
return r561666;
}
double f(double x, double y, double z, double t) {
double r561667 = z;
double r561668 = -3667224765870525.0;
double r561669 = 6.1501577861568104e+259;
double r561670 = r561668 / r561669;
bool r561671 = r561667 <= r561670;
double r561672 = 1.0;
double r561673 = x;
double r561674 = cbrt(r561673);
double r561675 = cbrt(r561674);
double r561676 = r561675 * r561675;
double r561677 = r561672 / r561676;
double r561678 = r561672 / r561677;
double r561679 = r561667 / r561675;
double r561680 = r561674 / r561679;
double r561681 = y;
double r561682 = t;
double r561683 = r561681 - r561682;
double r561684 = 2.0;
double r561685 = r561683 / r561684;
double r561686 = r561674 / r561685;
double r561687 = r561680 * r561686;
double r561688 = r561678 * r561687;
double r561689 = 6.823904024614768e+34;
bool r561690 = r561667 <= r561689;
double r561691 = r561667 * r561683;
double r561692 = pow(r561691, r561672);
double r561693 = r561692 / r561684;
double r561694 = r561673 / r561693;
double r561695 = r561672 / r561667;
double r561696 = r561673 / r561685;
double r561697 = r561695 * r561696;
double r561698 = r561690 ? r561694 : r561697;
double r561699 = r561671 ? r561688 : r561698;
return r561699;
}




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.8 |
if z < -5.962814115314182e-245Initial program 7.0
Simplified5.8
rmApplied *-un-lft-identity5.8
Applied times-frac5.8
Applied add-cube-cbrt6.5
Applied times-frac3.5
Simplified3.5
rmApplied add-cube-cbrt3.8
Applied *-un-lft-identity3.8
Applied times-frac3.8
Applied *-un-lft-identity3.8
Applied times-frac3.8
Applied associate-*l*3.1
if -5.962814115314182e-245 < z < 6.823904024614768e+34Initial program 2.8
Simplified2.7
rmApplied pow12.7
Applied pow12.7
Applied pow-prod-down2.7
if 6.823904024614768e+34 < z Initial program 11.4
Simplified9.3
rmApplied *-un-lft-identity9.3
Applied times-frac9.3
Applied *-un-lft-identity9.3
Applied times-frac2.4
Simplified2.4
Final simplification2.8
herbie shell --seed 2019304
(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.045027827330126e-269) (/ (* (/ x z) 2) (- y t)) (* (/ x (* (- y t) z)) 2)))
(/ (* x 2) (- (* y z) (* t z))))