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



Bits error versus a



Bits error versus x



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