\left(a + \left(b + \left(c + d\right)\right)\right) \cdot 2
\left(\left(a + \left(b + c\right)\right) + d\right) \cdot 2
double f(double a, double b, double c, double d) {
double r83705 = a;
double r83706 = b;
double r83707 = c;
double r83708 = d;
double r83709 = r83707 + r83708;
double r83710 = r83706 + r83709;
double r83711 = r83705 + r83710;
double r83712 = 2.0;
double r83713 = r83711 * r83712;
return r83713;
}
double f(double a, double b, double c, double d) {
double r83714 = a;
double r83715 = b;
double r83716 = c;
double r83717 = r83715 + r83716;
double r83718 = r83714 + r83717;
double r83719 = d;
double r83720 = r83718 + r83719;
double r83721 = 2.0;
double r83722 = r83720 * r83721;
return r83722;
}




Bits error versus a




Bits error versus b




Bits error versus c




Bits error versus d
Results
| Original | 3.7 |
|---|---|
| Target | 3.8 |
| Herbie | 2.8 |
Initial program 3.7
rmApplied associate-+r+2.8
rmApplied associate-+r+2.8
Final simplification2.8
herbie shell --seed 2020083 +o rules:numerics
(FPCore (a b c d)
:name "Expression, p6"
:precision binary64
:pre (and (<= -14 a -13) (<= -3 b -2) (<= 3 c 3.5) (<= 12.5 d 13.5))
:herbie-target
(+ (* (+ a b) 2) (* (+ c d) 2))
(* (+ a (+ b (+ c d))) 2))