double code(double x, double y) {
return ((double) (((double) (((double) (x * 3.0)) * x)) * y));
}
double code(double x, double y) {
return ((double) (x * ((double) (((double) (x * 3.0)) * y))));
}




Bits error versus x




Bits error versus y
Results
| Original | 10.1 |
|---|---|
| Target | 0.2 |
| Herbie | 0.3 |
Initial program 10.1
Simplified0.3
rmApplied associate-*r*0.3
Final simplification0.3
herbie shell --seed 2020191
(FPCore (x y)
:name "Diagrams.Segment:$catParam from diagrams-lib-1.3.0.3, A"
:precision binary64
:herbie-target
(* (* x 3.0) (* x y))
(* (* (* x 3.0) x) y))