\frac{\left(1 - x\right) \cdot \left(3 - x\right)}{y \cdot 3}\frac{1 - x}{y} \cdot \left(1 - \frac{x}{3}\right)double f(double x, double y) {
double r628571 = 1.0;
double r628572 = x;
double r628573 = r628571 - r628572;
double r628574 = 3.0;
double r628575 = r628574 - r628572;
double r628576 = r628573 * r628575;
double r628577 = y;
double r628578 = r628577 * r628574;
double r628579 = r628576 / r628578;
return r628579;
}
double f(double x, double y) {
double r628580 = 1.0;
double r628581 = x;
double r628582 = r628580 - r628581;
double r628583 = y;
double r628584 = r628582 / r628583;
double r628585 = 1.0;
double r628586 = 3.0;
double r628587 = r628581 / r628586;
double r628588 = r628585 - r628587;
double r628589 = r628584 * r628588;
return r628589;
}




Bits error versus x




Bits error versus y
Results
| Original | 5.6 |
|---|---|
| Target | 0.1 |
| Herbie | 0.1 |
Initial program 5.6
rmApplied times-frac0.1
rmApplied div-sub0.1
Simplified0.1
Final simplification0.1
herbie shell --seed 2020001 +o rules:numerics
(FPCore (x y)
:name "Diagrams.TwoD.Arc:bezierFromSweepQ1 from diagrams-lib-1.3.0.3"
:precision binary64
:herbie-target
(* (/ (- 1 x) y) (/ (- 3 x) 3))
(/ (* (- 1 x) (- 3 x)) (* y 3)))