\frac{\left(1 - x\right) \cdot \left(3 - x\right)}{y \cdot 3}\frac{3 - x}{3} \cdot \frac{1 - x}{y}double f(double x, double y) {
double r555523 = 1.0;
double r555524 = x;
double r555525 = r555523 - r555524;
double r555526 = 3.0;
double r555527 = r555526 - r555524;
double r555528 = r555525 * r555527;
double r555529 = y;
double r555530 = r555529 * r555526;
double r555531 = r555528 / r555530;
return r555531;
}
double f(double x, double y) {
double r555532 = 3.0;
double r555533 = x;
double r555534 = r555532 - r555533;
double r555535 = r555534 / r555532;
double r555536 = 1.0;
double r555537 = r555536 - r555533;
double r555538 = y;
double r555539 = r555537 / r555538;
double r555540 = r555535 * r555539;
return r555540;
}




Bits error versus x




Bits error versus y
Results
| Original | 5.5 |
|---|---|
| Target | 0.1 |
| Herbie | 0.1 |
Initial program 5.5
Simplified0.1
Final simplification0.1
herbie shell --seed 2019196 +o rules:numerics
(FPCore (x y)
:name "Diagrams.TwoD.Arc:bezierFromSweepQ1 from diagrams-lib-1.3.0.3"
:herbie-target
(* (/ (- 1.0 x) y) (/ (- 3.0 x) 3.0))
(/ (* (- 1.0 x) (- 3.0 x)) (* y 3.0)))