\frac{x \cdot 100}{x + y}10 \cdot \frac{x}{\frac{x + y}{10}}(FPCore (x y) :precision binary64 (/ (* x 100.0) (+ x y)))
(FPCore (x y) :precision binary64 (* 10.0 (/ x (/ (+ x y) 10.0))))
double code(double x, double y) {
return (x * 100.0) / (x + y);
}
double code(double x, double y) {
return 10.0 * (x / ((x + y) / 10.0));
}




Bits error versus x




Bits error versus y
Results
| Original | 0.5 |
|---|---|
| Target | 0.2 |
| Herbie | 0.2 |
Initial program 0.5
rmApplied associate-/l*_binary64_187780.2
rmApplied add-sqr-sqrt_binary64_188550.2
Applied *-un-lft-identity_binary64_188330.2
Applied times-frac_binary64_188390.4
Applied *-un-lft-identity_binary64_188330.4
Applied times-frac_binary64_188390.2
Simplified0.2
Simplified0.2
Final simplification0.2
herbie shell --seed 2021043
(FPCore (x y)
:name "Development.Shake.Progress:message from shake-0.15.5"
:precision binary64
:herbie-target
(* (/ x 1.0) (/ 100.0 (+ x y)))
(/ (* x 100.0) (+ x y)))