\frac{x \cdot y}{z}\begin{array}{l}
\mathbf{if}\;x \cdot y \le -1.6207759867400651 \cdot 10^{260}:\\
\;\;\;\;x \cdot \frac{-y}{-z}\\
\mathbf{elif}\;x \cdot y \le -5.6900917550780378 \cdot 10^{-61}:\\
\;\;\;\;\frac{x \cdot y}{z}\\
\mathbf{elif}\;x \cdot y \le -0.0:\\
\;\;\;\;x \cdot \frac{-y}{-z}\\
\mathbf{elif}\;x \cdot y \le 4.3629336611497376 \cdot 10^{104}:\\
\;\;\;\;\frac{x \cdot y}{z}\\
\mathbf{else}:\\
\;\;\;\;\frac{x}{\frac{z}{y}}\\
\end{array}double f(double x, double y, double z) {
double r396755 = x;
double r396756 = y;
double r396757 = r396755 * r396756;
double r396758 = z;
double r396759 = r396757 / r396758;
return r396759;
}
double f(double x, double y, double z) {
double r396760 = x;
double r396761 = y;
double r396762 = r396760 * r396761;
double r396763 = -1.6207759867400651e+260;
bool r396764 = r396762 <= r396763;
double r396765 = -r396761;
double r396766 = z;
double r396767 = -r396766;
double r396768 = r396765 / r396767;
double r396769 = r396760 * r396768;
double r396770 = -5.690091755078038e-61;
bool r396771 = r396762 <= r396770;
double r396772 = r396762 / r396766;
double r396773 = -0.0;
bool r396774 = r396762 <= r396773;
double r396775 = 4.3629336611497376e+104;
bool r396776 = r396762 <= r396775;
double r396777 = r396766 / r396761;
double r396778 = r396760 / r396777;
double r396779 = r396776 ? r396772 : r396778;
double r396780 = r396774 ? r396769 : r396779;
double r396781 = r396771 ? r396772 : r396780;
double r396782 = r396764 ? r396769 : r396781;
return r396782;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 6.5 |
|---|---|
| Target | 6.4 |
| Herbie | 1.6 |
if (* x y) < -1.6207759867400651e+260 or -5.690091755078038e-61 < (* x y) < -0.0Initial program 13.1
rmApplied clear-num13.4
rmApplied frac-2neg13.4
Simplified13.4
rmApplied *-un-lft-identity13.4
Applied times-frac3.3
Applied distribute-rgt-neg-in3.3
Applied *-un-lft-identity3.3
Applied times-frac3.0
Simplified3.0
Simplified2.7
if -1.6207759867400651e+260 < (* x y) < -5.690091755078038e-61 or -0.0 < (* x y) < 4.3629336611497376e+104Initial program 0.4
if 4.3629336611497376e+104 < (* x y) Initial program 14.3
rmApplied associate-/l*3.9
Final simplification1.6
herbie shell --seed 2020042
(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.7042130660650472e-164) (/ x (/ z y)) (* (/ x z) y)))
(/ (* x y) z))