\frac{x \cdot y}{z}\begin{array}{l}
\mathbf{if}\;x \cdot y \le -4.6140384460535245 \cdot 10^{82}:\\
\;\;\;\;\frac{x \cdot 1}{\frac{z}{y}}\\
\mathbf{elif}\;x \cdot y \le -3.6212587147018839 \cdot 10^{-153}:\\
\;\;\;\;\frac{1}{z} \cdot \left(x \cdot y\right)\\
\mathbf{elif}\;x \cdot y \le 2.936539165865314 \cdot 10^{-207}:\\
\;\;\;\;\frac{y}{\frac{z}{x}}\\
\mathbf{elif}\;x \cdot y \le 4.3105297737350413 \cdot 10^{140}:\\
\;\;\;\;\frac{1}{z} \cdot \left(x \cdot y\right)\\
\mathbf{else}:\\
\;\;\;\;\frac{y}{\frac{z}{x}}\\
\end{array}double code(double x, double y, double z) {
return ((double) (((double) (x * y)) / z));
}
double code(double x, double y, double z) {
double VAR;
if ((((double) (x * y)) <= -4.6140384460535245e+82)) {
VAR = ((double) (((double) (x * 1.0)) / ((double) (z / y))));
} else {
double VAR_1;
if ((((double) (x * y)) <= -3.621258714701884e-153)) {
VAR_1 = ((double) (((double) (1.0 / z)) * ((double) (x * y))));
} else {
double VAR_2;
if ((((double) (x * y)) <= 2.9365391658653136e-207)) {
VAR_2 = ((double) (y / ((double) (z / x))));
} else {
double VAR_3;
if ((((double) (x * y)) <= 4.310529773735041e+140)) {
VAR_3 = ((double) (((double) (1.0 / z)) * ((double) (x * y))));
} else {
VAR_3 = ((double) (y / ((double) (z / x))));
}
VAR_2 = VAR_3;
}
VAR_1 = VAR_2;
}
VAR = VAR_1;
}
return VAR;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 6.2 |
|---|---|
| Target | 6.0 |
| Herbie | 1.3 |
if (* x y) < -4.6140384460535245e+82Initial program 12.7
rmApplied *-un-lft-identity12.7
Applied associate-*r*12.7
Applied associate-/l*4.6
if -4.6140384460535245e+82 < (* x y) < -3.621258714701884e-153 or 2.9365391658653136e-207 < (* x y) < 4.310529773735041e+140Initial program 0.2
rmApplied *-commutative0.2
Applied associate-/l*10.4
rmApplied div-inv10.5
Applied *-un-lft-identity10.5
Applied times-frac0.4
Simplified0.3
if -3.621258714701884e-153 < (* x y) < 2.9365391658653136e-207 or 4.310529773735041e+140 < (* x y) Initial program 11.1
rmApplied *-commutative11.1
Applied associate-/l*1.5
Final simplification1.3
herbie shell --seed 2020113 +o rules:numerics
(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))