\frac{x \cdot 2}{y \cdot z - t \cdot z}\begin{array}{l}
\mathbf{if}\;x \cdot 2 \le -4.082997335416073103530238461094942047904 \cdot 10^{-59}:\\
\;\;\;\;\frac{1}{z} \cdot \left(\left(x \cdot 2\right) \cdot \frac{1}{y - t}\right)\\
\mathbf{elif}\;x \cdot 2 \le -1.26004965952634262675149776359190053847 \cdot 10^{-299}:\\
\;\;\;\;\frac{1}{\frac{z}{x} \cdot \frac{y - t}{2}}\\
\mathbf{elif}\;x \cdot 2 \le 3.150439875880527469243981674889617959112 \cdot 10^{104}:\\
\;\;\;\;\frac{x \cdot 2}{z \cdot \left(y - t\right)}\\
\mathbf{else}:\\
\;\;\;\;\frac{1}{z} \cdot \left(\left(x \cdot 2\right) \cdot \frac{1}{y - t}\right)\\
\end{array}double f(double x, double y, double z, double t) {
double r107192902 = x;
double r107192903 = 2.0;
double r107192904 = r107192902 * r107192903;
double r107192905 = y;
double r107192906 = z;
double r107192907 = r107192905 * r107192906;
double r107192908 = t;
double r107192909 = r107192908 * r107192906;
double r107192910 = r107192907 - r107192909;
double r107192911 = r107192904 / r107192910;
return r107192911;
}
double f(double x, double y, double z, double t) {
double r107192912 = x;
double r107192913 = 2.0;
double r107192914 = r107192912 * r107192913;
double r107192915 = -4.082997335416073e-59;
bool r107192916 = r107192914 <= r107192915;
double r107192917 = 1.0;
double r107192918 = z;
double r107192919 = r107192917 / r107192918;
double r107192920 = y;
double r107192921 = t;
double r107192922 = r107192920 - r107192921;
double r107192923 = r107192917 / r107192922;
double r107192924 = r107192914 * r107192923;
double r107192925 = r107192919 * r107192924;
double r107192926 = -1.2600496595263426e-299;
bool r107192927 = r107192914 <= r107192926;
double r107192928 = r107192918 / r107192912;
double r107192929 = r107192922 / r107192913;
double r107192930 = r107192928 * r107192929;
double r107192931 = r107192917 / r107192930;
double r107192932 = 3.1504398758805275e+104;
bool r107192933 = r107192914 <= r107192932;
double r107192934 = r107192918 * r107192922;
double r107192935 = r107192914 / r107192934;
double r107192936 = r107192933 ? r107192935 : r107192925;
double r107192937 = r107192927 ? r107192931 : r107192936;
double r107192938 = r107192916 ? r107192925 : r107192937;
return r107192938;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 6.7 |
|---|---|
| Target | 2.1 |
| Herbie | 2.9 |
if (* x 2.0) < -4.082997335416073e-59 or 3.1504398758805275e+104 < (* x 2.0) Initial program 10.7
Simplified9.9
rmApplied clear-num10.0
rmApplied div-inv10.1
Applied associate-/r*10.1
rmApplied *-un-lft-identity10.1
Applied add-cube-cbrt10.1
Applied times-frac9.4
Applied times-frac3.4
Simplified3.4
Simplified3.4
if -4.082997335416073e-59 < (* x 2.0) < -1.2600496595263426e-299Initial program 3.6
Simplified2.1
rmApplied clear-num2.7
rmApplied times-frac2.6
if -1.2600496595263426e-299 < (* x 2.0) < 3.1504398758805275e+104Initial program 3.9
Simplified2.4
Final simplification2.9
herbie shell --seed 2019173 +o rules:numerics
(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))))