\left(\left(\left(e + d\right) + c\right) + b\right) + a
\log \left(e^{\log \left(\left(\left(e^{c + a} \cdot e^{b}\right) \cdot e^{d}\right) \cdot e^{e}\right)}\right)double f(double a, double b, double c, double d, double e) {
double r11224307 = e;
double r11224308 = d;
double r11224309 = r11224307 + r11224308;
double r11224310 = c;
double r11224311 = r11224309 + r11224310;
double r11224312 = b;
double r11224313 = r11224311 + r11224312;
double r11224314 = a;
double r11224315 = r11224313 + r11224314;
return r11224315;
}
double f(double a, double b, double c, double d, double e) {
double r11224316 = c;
double r11224317 = a;
double r11224318 = r11224316 + r11224317;
double r11224319 = exp(r11224318);
double r11224320 = b;
double r11224321 = exp(r11224320);
double r11224322 = r11224319 * r11224321;
double r11224323 = d;
double r11224324 = exp(r11224323);
double r11224325 = r11224322 * r11224324;
double r11224326 = e;
double r11224327 = exp(r11224326);
double r11224328 = r11224325 * r11224327;
double r11224329 = log(r11224328);
double r11224330 = exp(r11224329);
double r11224331 = log(r11224330);
return r11224331;
}




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.1 |
Initial program 0.4
rmApplied add-log-exp0.4
Applied add-log-exp0.4
Applied add-log-exp0.4
Applied add-log-exp0.4
Applied sum-log0.4
Applied sum-log0.3
Applied sum-log0.2
Simplified0.3
rmApplied add-log-exp0.3
Applied add-log-exp0.3
Applied sum-log0.3
Simplified0.2
rmApplied add-log-exp0.2
Applied add-log-exp0.2
Applied sum-log0.2
Applied add-log-exp0.2
Applied sum-log0.2
Applied add-log-exp0.2
Applied sum-log0.1
Applied rem-exp-log0.1
Final simplification0.1
herbie shell --seed 2019107
(FPCore (a b c d e)
:name "Expression 1, p15"
:pre (<= 1 a 2 b 4 c 8 d 16 e 32)
:herbie-target
(+ (+ d (+ c (+ a b))) e)
(+ (+ (+ (+ e d) c) b) a))