\left(\left(\left(e + d\right) + c\right) + b\right) + a
\left(e + \left(d + \left(b + c\right)\right)\right) + a
double f(double a, double b, double c, double d, double e) {
double r103268 = e;
double r103269 = d;
double r103270 = r103268 + r103269;
double r103271 = c;
double r103272 = r103270 + r103271;
double r103273 = b;
double r103274 = r103272 + r103273;
double r103275 = a;
double r103276 = r103274 + r103275;
return r103276;
}
double f(double a, double b, double c, double d, double e) {
double r103277 = e;
double r103278 = d;
double r103279 = b;
double r103280 = c;
double r103281 = r103279 + r103280;
double r103282 = r103278 + r103281;
double r103283 = r103277 + r103282;
double r103284 = a;
double r103285 = r103283 + r103284;
return r103285;
}




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
Simplified0.3
Final simplification0.3
herbie shell --seed 2020060 +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))