\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 r112705 = d1;
double r112706 = 3.0;
double r112707 = r112705 * r112706;
double r112708 = d2;
double r112709 = r112705 * r112708;
double r112710 = r112707 + r112709;
double r112711 = d3;
double r112712 = r112705 * r112711;
double r112713 = r112710 + r112712;
return r112713;
}
double f(double d1, double d2, double d3) {
double r112714 = d2;
double r112715 = d3;
double r112716 = 3.0;
double r112717 = r112715 + r112716;
double r112718 = r112714 + r112717;
double r112719 = d1;
double r112720 = r112718 * r112719;
return r112720;
}




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 2019195 +o rules:numerics
(FPCore (d1 d2 d3)
:name "FastMath test3"
:herbie-target
(* d1 (+ (+ 3.0 d2) d3))
(+ (+ (* d1 3.0) (* d1 d2)) (* d1 d3)))