double f(double a, double b, double c, double d) {
double r15197048 = a;
double r15197049 = b;
double r15197050 = c;
double r15197051 = d;
double r15197052 = r15197050 + r15197051;
double r15197053 = r15197049 + r15197052;
double r15197054 = r15197048 + r15197053;
double r15197055 = 2.0;
double r15197056 = r15197054 * r15197055;
return r15197056;
}
double f(double a, double b, double c, double d) {
double r15197057 = b;
double r15197058 = a;
double r15197059 = c;
double r15197060 = d;
double r15197061 = r15197059 + r15197060;
double r15197062 = r15197058 + r15197061;
double r15197063 = r15197057 + r15197062;
double r15197064 = exp(r15197063);
double r15197065 = log(r15197064);
double r15197066 = r15197057 + r15197059;
double r15197067 = r15197066 + r15197060;
double r15197068 = r15197067 + r15197058;
double r15197069 = r15197065 * r15197068;
double r15197070 = r15197066 + r15197058;
double r15197071 = r15197060 + r15197070;
double r15197072 = r15197069 * r15197071;
double r15197073 = cbrt(r15197072);
double r15197074 = 2.0;
double r15197075 = r15197073 * r15197074;
return r15197075;
}
\left(a + \left(b + \left(c + d\right)\right)\right) \cdot 2
\sqrt[3]{\left(\log \left(e^{b + \left(a + \left(c + d\right)\right)}\right) \cdot \left(\left(\left(b + c\right) + d\right) + a\right)\right) \cdot \left(d + \left(\left(b + c\right) + a\right)\right)} \cdot 2



Bits error versus a




Bits error versus b




Bits error versus c




Bits error versus d
| Original | 3.7 |
|---|---|
| Target | 3.9 |
| Herbie | 2.8 |
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 sum-log2.8
Applied add-log-exp2.8
Applied sum-log2.6
Simplified2.9
rmApplied associate-+r+2.8
Final simplification2.8
herbie shell --seed 2019102
(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))