\left(a + \left(b + \left(c + d\right)\right)\right) \cdot 2
\sqrt[3]{\left(\log \left(e^{d + \left(\left(a + c\right) + b\right)}\right) \cdot \left(d + \left(\left(b + c\right) + a\right)\right)\right) \cdot \left(\left(\left(b + c\right) + d\right) + a\right)} \cdot 2double f(double a, double b, double c, double d) {
double r2890105 = a;
double r2890106 = b;
double r2890107 = c;
double r2890108 = d;
double r2890109 = r2890107 + r2890108;
double r2890110 = r2890106 + r2890109;
double r2890111 = r2890105 + r2890110;
double r2890112 = 2.0;
double r2890113 = r2890111 * r2890112;
return r2890113;
}
double f(double a, double b, double c, double d) {
double r2890114 = d;
double r2890115 = a;
double r2890116 = c;
double r2890117 = r2890115 + r2890116;
double r2890118 = b;
double r2890119 = r2890117 + r2890118;
double r2890120 = r2890114 + r2890119;
double r2890121 = exp(r2890120);
double r2890122 = log(r2890121);
double r2890123 = r2890118 + r2890116;
double r2890124 = r2890123 + r2890115;
double r2890125 = r2890114 + r2890124;
double r2890126 = r2890122 * r2890125;
double r2890127 = r2890123 + r2890114;
double r2890128 = r2890127 + r2890115;
double r2890129 = r2890126 * r2890128;
double r2890130 = cbrt(r2890129);
double r2890131 = 2.0;
double r2890132 = r2890130 * r2890131;
return r2890132;
}




Bits error versus a




Bits error versus b




Bits error versus c




Bits error versus d
Results
| Original | 3.7 |
|---|---|
| Target | 3.9 |
| Herbie | 2.7 |
Initial program 3.7
rmApplied associate-+r+2.8
rmApplied add-cbrt-cube2.9
rmApplied add-log-exp2.9
Applied add-log-exp2.9
Applied add-log-exp2.9
Applied sum-log2.9
Applied sum-log2.8
Applied add-log-exp2.8
Applied sum-log2.6
Simplified2.7
rmApplied associate-+r+2.7
Final simplification2.7
herbie shell --seed 2019135
(FPCore (a b c d)
:name "Expression, p6"
: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))