x \cdot \left(y + 1\right)
x + x \cdot y
(FPCore (x y) :precision binary64 (* x (+ y 1.0)))
(FPCore (x y) :precision binary64 (+ x (* x y)))
double code(double x, double y) {
return x * (y + 1.0);
}
double code(double x, double y) {
return x + (x * y);
}




Bits error versus x




Bits error versus y
Results
| Original | 0.0 |
|---|---|
| Target | 0.0 |
| Herbie | 0.0 |
Initial program 0.0
rmApplied distribute-lft-in_binary640.0
Simplified0.0
Final simplification0.0
herbie shell --seed 2020224
(FPCore (x y)
:name "Data.Colour.RGBSpace.HSL:hsl from colour-2.3.3, B"
:precision binary64
:herbie-target
(+ x (* x y))
(* x (+ y 1.0)))