\frac{\left(x \cdot 2\right) \cdot y}{x - y}\begin{array}{l}
\mathbf{if}\;y \le -7.11960665332501271 \cdot 10^{35} \lor \neg \left(y \le 4.5875694303008083 \cdot 10^{-84}\right):\\
\;\;\;\;\left(x \cdot 2\right) \cdot \mathsf{log1p}\left(\mathsf{expm1}\left(\frac{y}{x - y}\right)\right)\\
\mathbf{else}:\\
\;\;\;\;\frac{x \cdot 2}{x - y} \cdot y\\
\end{array}double code(double x, double y) {
return (((x * 2.0) * y) / (x - y));
}
double code(double x, double y) {
double temp;
if (((y <= -7.119606653325013e+35) || !(y <= 4.587569430300808e-84))) {
temp = ((x * 2.0) * log1p(expm1((y / (x - y)))));
} else {
temp = (((x * 2.0) / (x - y)) * y);
}
return temp;
}




Bits error versus x




Bits error versus y
Results
| Original | 14.6 |
|---|---|
| Target | 0.3 |
| Herbie | 0.4 |
if y < -7.119606653325013e+35 or 4.587569430300808e-84 < y Initial program 14.3
rmApplied *-un-lft-identity14.3
Applied times-frac0.6
Simplified0.6
rmApplied log1p-expm1-u0.6
if -7.119606653325013e+35 < y < 4.587569430300808e-84Initial program 15.0
rmApplied associate-/l*16.0
rmApplied associate-/r/0.1
Final simplification0.4
herbie shell --seed 2020066 +o rules:numerics
(FPCore (x y)
:name "Linear.Projection:perspective from linear-1.19.1.3, B"
:precision binary64
:herbie-target
(if (< x -1.7210442634149447e+81) (* (/ (* 2 x) (- x y)) y) (if (< x 83645045635564432) (/ (* x 2) (/ (- x y) y)) (* (/ (* 2 x) (- x y)) y)))
(/ (* (* x 2) y) (- x y)))