\frac{x \cdot 100}{x + y}x \cdot \frac{100}{x + y}double code(double x, double y) {
return ((double) (((double) (x * 100.0)) / ((double) (x + y))));
}
double code(double x, double y) {
return ((double) (x * ((double) (100.0 / ((double) (x + y))))));
}




Bits error versus x




Bits error versus y
Results
| Original | 0.4 |
|---|---|
| Target | 0.2 |
| Herbie | 0.2 |
Initial program 0.4
rmApplied *-un-lft-identity0.4
Applied times-frac0.2
Simplified0.2
Final simplification0.2
herbie shell --seed 2020113 +o rules:numerics
(FPCore (x y)
:name "Development.Shake.Progress:message from shake-0.15.5"
:precision binary64
:herbie-target
(* (/ x 1) (/ 100 (+ x y)))
(/ (* x 100) (+ x y)))