\left(\left(\left(e + d\right) + c\right) + b\right) + a
e + \left(d + \left(a + \left(b + c\right)\right)\right)
double f(double a, double b, double c, double d, double e) {
double r101112 = e;
double r101113 = d;
double r101114 = r101112 + r101113;
double r101115 = c;
double r101116 = r101114 + r101115;
double r101117 = b;
double r101118 = r101116 + r101117;
double r101119 = a;
double r101120 = r101118 + r101119;
return r101120;
}
double f(double a, double b, double c, double d, double e) {
double r101121 = e;
double r101122 = d;
double r101123 = a;
double r101124 = b;
double r101125 = c;
double r101126 = r101124 + r101125;
double r101127 = r101123 + r101126;
double r101128 = r101122 + r101127;
double r101129 = r101121 + r101128;
return r101129;
}




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.2 |
Initial program 0.4
rmApplied associate-+l+0.3
rmApplied associate-+l+0.3
Simplified0.3
rmApplied associate-+l+0.2
Final simplification0.2
herbie shell --seed 2020002 +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))