\frac{x \cdot y}{z}\begin{array}{l}
\mathbf{if}\;x \cdot y \le -7.725807749934587 \cdot 10^{96}:\\
\;\;\;\;\frac{x}{z} \cdot y\\
\mathbf{elif}\;x \cdot y \le -3.0807367441454416 \cdot 10^{-282}:\\
\;\;\;\;\frac{x \cdot y}{z}\\
\mathbf{elif}\;x \cdot y \le -0.0:\\
\;\;\;\;x \cdot \frac{y}{z}\\
\mathbf{elif}\;x \cdot y \le 5.31151602867187701 \cdot 10^{255}:\\
\;\;\;\;\frac{x \cdot y}{z}\\
\mathbf{else}:\\
\;\;\;\;\frac{1}{\frac{1}{\frac{x}{\frac{z}{y}}}}\\
\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) <= -7.725807749934587e+96)) {
temp = ((x / z) * y);
} else {
double temp_1;
if (((x * y) <= -3.0807367441454416e-282)) {
temp_1 = ((x * y) / z);
} else {
double temp_2;
if (((x * y) <= -0.0)) {
temp_2 = (x * (y / z));
} else {
double temp_3;
if (((x * y) <= 5.311516028671877e+255)) {
temp_3 = ((x * y) / z);
} else {
temp_3 = (1.0 / (1.0 / (x / (z / y))));
}
temp_2 = temp_3;
}
temp_1 = temp_2;
}
temp = temp_1;
}
return temp;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 6.3 |
|---|---|
| Target | 6.4 |
| Herbie | 0.8 |
if (* x y) < -7.725807749934587e+96Initial program 14.6
rmApplied associate-/l*3.3
rmApplied associate-/r/4.1
if -7.725807749934587e+96 < (* x y) < -3.0807367441454416e-282 or -0.0 < (* x y) < 5.311516028671877e+255Initial program 0.4
if -3.0807367441454416e-282 < (* x y) < -0.0Initial program 17.6
rmApplied *-un-lft-identity17.6
Applied times-frac0.1
Simplified0.1
if 5.311516028671877e+255 < (* x y) Initial program 40.0
rmApplied associate-/l*0.3
rmApplied clear-num0.3
rmApplied *-un-lft-identity0.3
Applied *-un-lft-identity0.3
Applied times-frac0.3
Applied associate-/l*0.4
Final simplification0.8
herbie shell --seed 2020060
(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))