\frac{x \cdot y}{y + 1}\frac{x}{\mathsf{fma}\left(1, \frac{1}{y}, 1\right)}double code(double x, double y) {
return ((x * y) / (y + 1.0));
}
double code(double x, double y) {
return (x / fma(1.0, (1.0 / y), 1.0));
}




Bits error versus x




Bits error versus y
Results
| Original | 8.3 |
|---|---|
| Target | 0.0 |
| Herbie | 0.1 |
Initial program 8.3
rmApplied associate-/l*0.1
Taylor expanded around 0 0.1
Simplified0.1
Final simplification0.1
herbie shell --seed 2020078 +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)))