\frac{x \cdot y}{y + 1}\frac{x}{\mathsf{fma}\left(1, \frac{1}{y}, 1\right)}double f(double x, double y) {
double r636684 = x;
double r636685 = y;
double r636686 = r636684 * r636685;
double r636687 = 1.0;
double r636688 = r636685 + r636687;
double r636689 = r636686 / r636688;
return r636689;
}
double f(double x, double y) {
double r636690 = x;
double r636691 = 1.0;
double r636692 = 1.0;
double r636693 = y;
double r636694 = r636692 / r636693;
double r636695 = fma(r636691, r636694, r636692);
double r636696 = r636690 / r636695;
return r636696;
}




Bits error versus x




Bits error versus y
| Original | 8.2 |
|---|---|
| Target | 0.0 |
| Herbie | 0.1 |
Initial program 8.2
rmApplied associate-/l*0.1
Taylor expanded around 0 0.1
Simplified0.1
Final simplification0.1
herbie shell --seed 2019354 +o rules:numerics
(FPCore (x y)
:name "Diagrams.Trail:splitAtParam from diagrams-lib-1.3.0.3, B"
:precision binary64
:herbie-target
(if (< y -3693.8482788297247) (- (/ x (* y y)) (- (/ x y) x)) (if (< y 6799310503.41891) (/ (* x y) (+ y 1)) (- (/ x (* y y)) (- (/ x y) x))))
(/ (* x y) (+ y 1)))