\frac{x \cdot y}{z}\begin{array}{l}
\mathbf{if}\;x \cdot y \le -2.0212306242717315 \cdot 10^{115}:\\
\;\;\;\;x \cdot \frac{y}{z}\\
\mathbf{elif}\;x \cdot y \le -2.08794536631012826 \cdot 10^{-85}:\\
\;\;\;\;\left(x \cdot y\right) \cdot \frac{1}{z}\\
\mathbf{elif}\;x \cdot y \le 0.0:\\
\;\;\;\;\frac{x}{z} \cdot y\\
\mathbf{else}:\\
\;\;\;\;\left(x \cdot y\right) \cdot \frac{1}{z}\\
\end{array}double code(double x, double y, double z) {
return ((x * y) / z);
}
double code(double x, double y, double z) {
double temp;
if (((x * y) <= -2.0212306242717315e+115)) {
temp = (x * (y / z));
} else {
double temp_1;
if (((x * y) <= -2.0879453663101283e-85)) {
temp_1 = ((x * y) * (1.0 / z));
} else {
double temp_2;
if (((x * y) <= 0.0)) {
temp_2 = ((x / z) * y);
} else {
temp_2 = ((x * y) * (1.0 / z));
}
temp_1 = temp_2;
}
temp = temp_1;
}
return temp;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 5.8 |
|---|---|
| Target | 5.9 |
| Herbie | 2.9 |
if (* x y) < -2.0212306242717315e+115Initial program 13.5
rmApplied *-un-lft-identity13.5
Applied times-frac3.0
Simplified3.0
if -2.0212306242717315e+115 < (* x y) < -2.0879453663101283e-85 or 0.0 < (* x y) Initial program 3.1
rmApplied div-inv3.1
if -2.0879453663101283e-85 < (* x y) < 0.0Initial program 9.0
rmApplied associate-/l*1.9
rmApplied associate-/r/2.2
Final simplification2.9
herbie shell --seed 2020056 +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))