\frac{x \cdot y}{z}\begin{array}{l}
\mathbf{if}\;\frac{x \cdot y}{z} \le -7.768603561893780181171682032240737260521 \cdot 10^{305}:\\
\;\;\;\;x \cdot \frac{y}{z}\\
\mathbf{elif}\;\frac{x \cdot y}{z} \le -5.989061428235972049640443908724325403146 \cdot 10^{-77}:\\
\;\;\;\;\frac{x \cdot y}{z}\\
\mathbf{elif}\;\frac{x \cdot y}{z} \le -0.0:\\
\;\;\;\;\frac{\frac{x}{\sqrt[3]{z} \cdot \sqrt[3]{z}}}{\frac{\sqrt[3]{z}}{y}}\\
\mathbf{elif}\;\frac{x \cdot y}{z} \le 3.534109248982643983253870825363988567111 \cdot 10^{298}:\\
\;\;\;\;\frac{x \cdot y}{z}\\
\mathbf{else}:\\
\;\;\;\;\frac{x}{\frac{z}{y}}\\
\end{array}double f(double x, double y, double z) {
double r503790 = x;
double r503791 = y;
double r503792 = r503790 * r503791;
double r503793 = z;
double r503794 = r503792 / r503793;
return r503794;
}
double f(double x, double y, double z) {
double r503795 = x;
double r503796 = y;
double r503797 = r503795 * r503796;
double r503798 = z;
double r503799 = r503797 / r503798;
double r503800 = -7.76860356189378e+305;
bool r503801 = r503799 <= r503800;
double r503802 = r503796 / r503798;
double r503803 = r503795 * r503802;
double r503804 = -5.989061428235972e-77;
bool r503805 = r503799 <= r503804;
double r503806 = -0.0;
bool r503807 = r503799 <= r503806;
double r503808 = cbrt(r503798);
double r503809 = r503808 * r503808;
double r503810 = r503795 / r503809;
double r503811 = r503808 / r503796;
double r503812 = r503810 / r503811;
double r503813 = 3.534109248982644e+298;
bool r503814 = r503799 <= r503813;
double r503815 = r503798 / r503796;
double r503816 = r503795 / r503815;
double r503817 = r503814 ? r503799 : r503816;
double r503818 = r503807 ? r503812 : r503817;
double r503819 = r503805 ? r503799 : r503818;
double r503820 = r503801 ? r503803 : r503819;
return r503820;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 6.4 |
|---|---|
| Target | 6.5 |
| Herbie | 1.7 |
if (/ (* x y) z) < -7.76860356189378e+305Initial program 62.6
rmApplied *-un-lft-identity62.6
Applied times-frac0.3
Simplified0.3
if -7.76860356189378e+305 < (/ (* x y) z) < -5.989061428235972e-77 or -0.0 < (/ (* x y) z) < 3.534109248982644e+298Initial program 2.2
if -5.989061428235972e-77 < (/ (* x y) z) < -0.0Initial program 5.7
rmApplied associate-/l*6.4
rmApplied *-un-lft-identity6.4
Applied add-cube-cbrt7.0
Applied times-frac7.0
Applied associate-/r*5.3
Simplified5.3
if 3.534109248982644e+298 < (/ (* x y) z) Initial program 57.5
rmApplied associate-/l*1.5
Final simplification1.7
herbie shell --seed 2019303
(FPCore (x y z)
:name "Diagrams.Solve.Tridiagonal:solveCyclicTriDiagonal from diagrams-solve-0.1, A"
:precision binary64
:herbie-target
(if (< z -4.262230790519429e-138) (/ (* x y) z) (if (< z 1.70421306606504721e-164) (/ x (/ z y)) (* (/ x z) y)))
(/ (* x y) z))