\frac{x \cdot y}{z}\begin{array}{l}
\mathbf{if}\;x \cdot y \le -1.588825970129451 \cdot 10^{194}:\\
\;\;\;\;\frac{x}{\frac{z}{y}}\\
\mathbf{elif}\;x \cdot y \le -1.7052229471066912 \cdot 10^{-221}:\\
\;\;\;\;\frac{x \cdot y}{z}\\
\mathbf{elif}\;x \cdot y \le 0.0:\\
\;\;\;\;\frac{x}{z} \cdot y\\
\mathbf{elif}\;x \cdot y \le 1.3529508649280254 \cdot 10^{152}:\\
\;\;\;\;\frac{x \cdot y}{z}\\
\mathbf{else}:\\
\;\;\;\;\frac{x}{\frac{z}{y}}\\
\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.5888259701294508e+194)) {
VAR = ((double) (x / ((double) (z / y))));
} else {
double VAR_1;
if ((((double) (x * y)) <= -1.7052229471066912e-221)) {
VAR_1 = ((double) (((double) (x * y)) / z));
} else {
double VAR_2;
if ((((double) (x * y)) <= 0.0)) {
VAR_2 = ((double) (((double) (x / z)) * y));
} else {
double VAR_3;
if ((((double) (x * y)) <= 1.3529508649280254e+152)) {
VAR_3 = ((double) (((double) (x * y)) / z));
} else {
VAR_3 = ((double) (x / ((double) (z / y))));
}
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.1 |
| Herbie | 0.6 |
if (* x y) < -1.588825970129451e194 or 1.3529508649280254e152 < (* x y) Initial program 22.2
rmApplied associate-/l*1.7
if -1.588825970129451e194 < (* x y) < -1.7052229471066912e-221 or 0.0 < (* x y) < 1.3529508649280254e152Initial program 0.4
if -1.7052229471066912e-221 < (* x y) < 0.0Initial program 13.9
rmApplied associate-/l*0.4
rmApplied associate-/r/0.4
Final simplification0.6
herbie shell --seed 2020149
(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))