a \cdot x + a \cdot y
a \cdot \left(x + y\right)
double code(double a, double x, double y) {
return ((double) (((double) (a * x)) + ((double) (a * y))));
}
double code(double a, double x, double y) {
return ((double) (a * ((double) (x + y))));
}



Bits error versus a



Bits error versus x



Bits error versus y
Results
Initial program 0.0
Simplified0.0
Final simplification0.0
herbie shell --seed 2020153
(FPCore (a x y)
:name "(+ (* a x) (* a y))"
:precision binary64
(+ (* a x) (* a y)))