\frac{x \cdot y}{z}\begin{array}{l}
\mathbf{if}\;x \cdot y \le -1.28814127502927457 \cdot 10^{-255} \lor \neg \left(x \cdot y \le 2.06616796455329214 \cdot 10^{-194} \lor \neg \left(x \cdot y \le 2.76589914113834434 \cdot 10^{248}\right)\right):\\
\;\;\;\;\frac{x \cdot y}{z}\\
\mathbf{else}:\\
\;\;\;\;x \cdot \frac{y}{z}\\
\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)) <= -1.2881412750292746e-255) || !((((double) (x * y)) <= 2.066167964553292e-194) || !(((double) (x * y)) <= 2.7658991411383443e+248)))) {
VAR = ((double) (((double) (x * y)) / z));
} else {
VAR = ((double) (x * ((double) (y / z))));
}
return VAR;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 6.1 |
|---|---|
| Target | 6.1 |
| Herbie | 1.8 |
if (* x y) < -1.28814127502927457e-255 or 2.06616796455329214e-194 < (* x y) < 2.76589914113834434e248Initial program 2.4
if -1.28814127502927457e-255 < (* x y) < 2.06616796455329214e-194 or 2.76589914113834434e248 < (* x y) Initial program 15.3
rmApplied *-un-lft-identity15.3
Applied times-frac0.5
Simplified0.5
Final simplification1.8
herbie shell --seed 2020163
(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))