1 - \frac{\left(1 - x\right) \cdot y}{y + 1}
\begin{array}{l}
t_0 := \mathsf{fma}\left(x, \frac{y}{1 + y}, 1\right)\\
t_1 := \frac{\left(1 - x\right) \cdot y}{1 + y}\\
t_2 := \frac{y}{1 - y \cdot y}\\
t_3 := \mathsf{fma}\left(y + -1, t_2, \left(1 - y\right) \cdot t_2\right)\\
\mathbf{if}\;t_1 \leq 0.9997523214764116:\\
\;\;\;\;\left(\frac{y + -1}{\frac{1}{y} - y} + t_0\right) + t_3\\
\mathbf{elif}\;t_1 \leq 1.0000146328459205:\\
\;\;\;\;\left(\left(x + \frac{x}{y \cdot y}\right) + \frac{1}{{y}^{3}}\right) - \left(\frac{x}{{y}^{3}} + \left(\frac{1}{y \cdot y} + \frac{x + -1}{y}\right)\right)\\
\mathbf{else}:\\
\;\;\;\;t_3 + \left(t_0 + \left(y + -1\right) \cdot t_2\right)\\
\end{array}
(FPCore (x y) :precision binary64 (- 1.0 (/ (* (- 1.0 x) y) (+ y 1.0))))
(FPCore (x y)
:precision binary64
(let* ((t_0 (fma x (/ y (+ 1.0 y)) 1.0))
(t_1 (/ (* (- 1.0 x) y) (+ 1.0 y)))
(t_2 (/ y (- 1.0 (* y y))))
(t_3 (fma (+ y -1.0) t_2 (* (- 1.0 y) t_2))))
(if (<= t_1 0.9997523214764116)
(+ (+ (/ (+ y -1.0) (- (/ 1.0 y) y)) t_0) t_3)
(if (<= t_1 1.0000146328459205)
(-
(+ (+ x (/ x (* y y))) (/ 1.0 (pow y 3.0)))
(+ (/ x (pow y 3.0)) (+ (/ 1.0 (* y y)) (/ (+ x -1.0) y))))
(+ t_3 (+ t_0 (* (+ y -1.0) t_2)))))))double code(double x, double y) {
return 1.0 - (((1.0 - x) * y) / (y + 1.0));
}
double code(double x, double y) {
double t_0 = fma(x, (y / (1.0 + y)), 1.0);
double t_1 = ((1.0 - x) * y) / (1.0 + y);
double t_2 = y / (1.0 - (y * y));
double t_3 = fma((y + -1.0), t_2, ((1.0 - y) * t_2));
double tmp;
if (t_1 <= 0.9997523214764116) {
tmp = (((y + -1.0) / ((1.0 / y) - y)) + t_0) + t_3;
} else if (t_1 <= 1.0000146328459205) {
tmp = ((x + (x / (y * y))) + (1.0 / pow(y, 3.0))) - ((x / pow(y, 3.0)) + ((1.0 / (y * y)) + ((x + -1.0) / y)));
} else {
tmp = t_3 + (t_0 + ((y + -1.0) * t_2));
}
return tmp;
}




Bits error versus x




Bits error versus y
| Original | 22.1 |
|---|---|
| Target | 0.2 |
| Herbie | 0.2 |
if (/.f64 (*.f64 (-.f64 1 x) y) (+.f64 y 1)) < 0.999752321476411576Initial program 7.1
Simplified0.0
Taylor expanded in x around 0 7.1
Simplified0.0
Applied flip-+_binary640.2
Applied associate-/r/_binary640.2
Applied *-un-lft-identity_binary640.2
Applied prod-diff_binary640.2
Applied add-cbrt-cube_binary6412.9
Simplified12.7
Applied rem-cbrt-cube_binary640.0
if 0.999752321476411576 < (/.f64 (*.f64 (-.f64 1 x) y) (+.f64 y 1)) < 1.00001463284592051Initial program 59.2
Simplified59.2
Taylor expanded in y around inf 0.1
Simplified0.1
if 1.00001463284592051 < (/.f64 (*.f64 (-.f64 1 x) y) (+.f64 y 1)) Initial program 20.7
Simplified0.2
Taylor expanded in x around 0 20.7
Simplified0.1
Applied flip-+_binary640.8
Applied associate-/r/_binary640.8
Applied *-un-lft-identity_binary640.8
Applied prod-diff_binary640.8
Applied fma-udef_binary640.8
Simplified0.8
Final simplification0.2
herbie shell --seed 2022095
(FPCore (x y)
:name "Diagrams.Trail:splitAtParam from diagrams-lib-1.3.0.3, D"
:precision binary64
:herbie-target
(if (< y -3693.8482788297247) (- (/ 1.0 y) (- (/ x y) x)) (if (< y 6799310503.41891) (- 1.0 (/ (* (- 1.0 x) y) (+ y 1.0))) (- (/ 1.0 y) (- (/ x y) x))))
(- 1.0 (/ (* (- 1.0 x) y) (+ y 1.0))))