\left(\left(\left(e + d\right) + c\right) + b\right) + a
\left(e + d\right) + \left(c + \left(b + a\right)\right)
double f(double a, double b, double c, double d, double e) {
double r61184 = e;
double r61185 = d;
double r61186 = r61184 + r61185;
double r61187 = c;
double r61188 = r61186 + r61187;
double r61189 = b;
double r61190 = r61188 + r61189;
double r61191 = a;
double r61192 = r61190 + r61191;
return r61192;
}
double f(double a, double b, double c, double d, double e) {
double r61193 = e;
double r61194 = d;
double r61195 = r61193 + r61194;
double r61196 = c;
double r61197 = b;
double r61198 = a;
double r61199 = r61197 + r61198;
double r61200 = r61196 + r61199;
double r61201 = r61195 + r61200;
return r61201;
}




Bits error versus a




Bits error versus b




Bits error versus c




Bits error versus d




Bits error versus e
Results
| Original | 0.4 |
|---|---|
| Target | 0.2 |
| Herbie | 0.3 |
Initial program 0.4
rmApplied associate-+l+0.3
rmApplied associate-+l+0.3
Final simplification0.3
herbie shell --seed 2019304 +o rules:numerics
(FPCore (a b c d e)
:name "Expression 1, p15"
:precision binary64
:pre (<= 1 a 2 b 4 c 8 d 16 e 32)
:herbie-target
(+ (+ d (+ c (+ a b))) e)
(+ (+ (+ (+ e d) c) b) a))