\left(d1 \cdot 3 + d1 \cdot d2\right) + d1 \cdot d3
\left(\left(3 + d2\right) + d3\right) \cdot d1
double f(double d1, double d2, double d3) {
double r131753 = d1;
double r131754 = 3.0;
double r131755 = r131753 * r131754;
double r131756 = d2;
double r131757 = r131753 * r131756;
double r131758 = r131755 + r131757;
double r131759 = d3;
double r131760 = r131753 * r131759;
double r131761 = r131758 + r131760;
return r131761;
}
double f(double d1, double d2, double d3) {
double r131762 = 3.0;
double r131763 = d2;
double r131764 = r131762 + r131763;
double r131765 = d3;
double r131766 = r131764 + r131765;
double r131767 = d1;
double r131768 = r131766 * r131767;
return r131768;
}




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
rmApplied *-commutative0.1
Final simplification0.1
herbie shell --seed 2019325
(FPCore (d1 d2 d3)
:name "FastMath test3"
:precision binary64
:herbie-target
(* d1 (+ (+ 3 d2) d3))
(+ (+ (* d1 3) (* d1 d2)) (* d1 d3)))