\left(d1 \cdot 3 + d1 \cdot d2\right) + d1 \cdot d3
\left(d2 + \left(d3 + 3\right)\right) \cdot d1
double f(double d1, double d2, double d3) {
double r151993 = d1;
double r151994 = 3.0;
double r151995 = r151993 * r151994;
double r151996 = d2;
double r151997 = r151993 * r151996;
double r151998 = r151995 + r151997;
double r151999 = d3;
double r152000 = r151993 * r151999;
double r152001 = r151998 + r152000;
return r152001;
}
double f(double d1, double d2, double d3) {
double r152002 = d2;
double r152003 = d3;
double r152004 = 3.0;
double r152005 = r152003 + r152004;
double r152006 = r152002 + r152005;
double r152007 = d1;
double r152008 = r152006 * r152007;
return r152008;
}




Bits error versus d1




Bits error versus d2




Bits error versus d3
Results
| Original | 0.1 |
|---|---|
| Target | 0.1 |
| Herbie | 0.1 |
Initial program 0.1
Simplified0.1
Final simplification0.1
herbie shell --seed 2019179 +o rules:numerics
(FPCore (d1 d2 d3)
:name "FastMath test3"
:herbie-target
(* d1 (+ (+ 3.0 d2) d3))
(+ (+ (* d1 3.0) (* d1 d2)) (* d1 d3)))