\frac{x \cdot y}{z}\begin{array}{l}
\mathbf{if}\;x \cdot y \le -1.4207015214909779 \cdot 10^{277}:\\
\;\;\;\;x \cdot \frac{y}{z}\\
\mathbf{elif}\;x \cdot y \le -5.02402572648450271 \cdot 10^{-243}:\\
\;\;\;\;\frac{x \cdot y}{z}\\
\mathbf{elif}\;x \cdot y \le 1.2224174804579308 \cdot 10^{-187}:\\
\;\;\;\;\frac{\frac{x}{z}}{\frac{1}{y}}\\
\mathbf{elif}\;x \cdot y \le 7.8080925129091553 \cdot 10^{141}:\\
\;\;\;\;\frac{x \cdot y}{z}\\
\mathbf{else}:\\
\;\;\;\;x \cdot \frac{y}{z}\\
\end{array}double code(double x, double y, double z) {
return ((x * y) / z);
}
double code(double x, double y, double z) {
double VAR;
if (((x * y) <= -1.4207015214909779e+277)) {
VAR = (x * (y / z));
} else {
double VAR_1;
if (((x * y) <= -5.024025726484503e-243)) {
VAR_1 = ((x * y) / z);
} else {
double VAR_2;
if (((x * y) <= 1.2224174804579308e-187)) {
VAR_2 = ((x / z) / (1.0 / y));
} else {
double VAR_3;
if (((x * y) <= 7.808092512909155e+141)) {
VAR_3 = ((x * y) / z);
} else {
VAR_3 = (x * (y / z));
}
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.3 |
|---|---|
| Target | 6.3 |
| Herbie | 0.5 |
if (* x y) < -1.4207015214909779e+277 or 7.808092512909155e+141 < (* x y) Initial program 26.9
rmApplied *-un-lft-identity26.9
Applied times-frac1.9
Simplified1.9
if -1.4207015214909779e+277 < (* x y) < -5.024025726484503e-243 or 1.2224174804579308e-187 < (* x y) < 7.808092512909155e+141Initial program 0.2
if -5.024025726484503e-243 < (* x y) < 1.2224174804579308e-187Initial program 11.1
rmApplied associate-/l*0.6
rmApplied div-inv0.7
Applied associate-/r*0.6
Final simplification0.5
herbie shell --seed 2020078 +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))