\left(d1 \cdot 3 + d1 \cdot d2\right) + d1 \cdot d3
d1 \cdot \left(d3 + \left(3 + d2\right)\right)
double f(double d1, double d2, double d3) {
double r205447 = d1;
double r205448 = 3.0;
double r205449 = r205447 * r205448;
double r205450 = d2;
double r205451 = r205447 * r205450;
double r205452 = r205449 + r205451;
double r205453 = d3;
double r205454 = r205447 * r205453;
double r205455 = r205452 + r205454;
return r205455;
}
double f(double d1, double d2, double d3) {
double r205456 = d1;
double r205457 = d3;
double r205458 = 3.0;
double r205459 = d2;
double r205460 = r205458 + r205459;
double r205461 = r205457 + r205460;
double r205462 = r205456 * r205461;
return r205462;
}




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