x \cdot \frac{\frac{y}{z} \cdot t}{t}\begin{array}{l}
\mathbf{if}\;\frac{y}{z} \leq -\infty:\\
\;\;\;\;\frac{1}{\frac{z}{y \cdot x}}\\
\mathbf{elif}\;\frac{y}{z} \leq -3.1180330985036686 \cdot 10^{-216}:\\
\;\;\;\;\frac{x}{\frac{z}{y}}\\
\mathbf{elif}\;\frac{y}{z} \leq 4.9952376169741 \cdot 10^{-312}:\\
\;\;\;\;\frac{y \cdot x}{z}\\
\mathbf{elif}\;\frac{y}{z} \leq 4.684813618637737 \cdot 10^{+228}:\\
\;\;\;\;\frac{x}{\frac{z}{y}}\\
\mathbf{else}:\\
\;\;\;\;y \cdot \frac{x}{z}\\
\end{array}(FPCore (x y z t) :precision binary64 (* x (/ (* (/ y z) t) t)))
(FPCore (x y z t)
:precision binary64
(if (<= (/ y z) (- INFINITY))
(/ 1.0 (/ z (* y x)))
(if (<= (/ y z) -3.1180330985036686e-216)
(/ x (/ z y))
(if (<= (/ y z) 4.9952376169741e-312)
(/ (* y x) z)
(if (<= (/ y z) 4.684813618637737e+228) (/ x (/ z y)) (* y (/ x z)))))))double code(double x, double y, double z, double t) {
return x * (((y / z) * t) / t);
}
double code(double x, double y, double z, double t) {
double tmp;
if ((y / z) <= -((double) INFINITY)) {
tmp = 1.0 / (z / (y * x));
} else if ((y / z) <= -3.1180330985036686e-216) {
tmp = x / (z / y);
} else if ((y / z) <= 4.9952376169741e-312) {
tmp = (y * x) / z;
} else if ((y / z) <= 4.684813618637737e+228) {
tmp = x / (z / y);
} else {
tmp = y * (x / z);
}
return tmp;
}









Bits error versus x









Bits error versus y









Bits error versus z









Bits error versus t
Results
| Original | 14.3 |
|---|---|
| Target | 1.5 |
| Herbie | 0.3 |
| Alternative 1 | |
|---|---|
| Error | 0.3 |
| Cost | 2116 |
| Alternative 2 | |
|---|---|
| Error | 5.8 |
| Cost | 780 |
| Alternative 3 | |
|---|---|
| Error | 5.8 |
| Cost | 320 |
| Alternative 4 | |
|---|---|
| Error | 49.3 |
| Cost | 64 |
| Alternative 5 | |
|---|---|
| Error | 61.7 |
| Cost | 64 |

if (/.f64 y z) < -inf.0Initial program 64.0
Simplified64.0
rmApplied associate-*r/_binary64_177520.3
rmApplied clear-num_binary64_178090.4
Simplified0.4
if -inf.0 < (/.f64 y z) < -3.1180330985036686e-216 or 4.9952376169741e-312 < (/.f64 y z) < 4.6848136186377372e228Initial program 9.4
Simplified0.2
rmApplied associate-*r/_binary64_177528.5
rmApplied associate-/l*_binary64_177550.3
Simplified0.3
if -3.1180330985036686e-216 < (/.f64 y z) < 4.9952376169741e-312Initial program 17.7
Simplified14.0
rmApplied associate-*r/_binary64_177520.2
Simplified0.2
if 4.6848136186377372e228 < (/.f64 y z) Initial program 46.0
Simplified33.2
rmApplied add-cube-cbrt_binary64_1784533.7
Applied *-un-lft-identity_binary64_1781033.7
Applied times-frac_binary64_1781633.7
Applied associate-*r*_binary64_177509.1
Simplified9.1
rmApplied pow1_binary64_178719.1
Applied pow1_binary64_178719.1
Applied pow-prod-down_binary64_178819.1
Simplified0.5
Simplified0.5
Final simplification0.3
herbie shell --seed 2021044
(FPCore (x y z t)
:name "Graphics.Rendering.Chart.Backend.Diagrams:calcFontMetrics from Chart-diagrams-1.5.1, B"
:precision binary64
:herbie-target
(if (< (/ (* (/ y z) t) t) -1.20672205123045e+245) (/ y (/ z x)) (if (< (/ (* (/ y z) t) t) -5.907522236933906e-275) (* x (/ y z)) (if (< (/ (* (/ y z) t) t) 5.658954423153415e-65) (/ y (/ z x)) (if (< (/ (* (/ y z) t) t) 2.0087180502407133e+217) (* x (/ y z)) (/ (* y x) z)))))
(* x (/ (* (/ y z) t) t)))