\frac{x}{x \cdot x + 1}\begin{array}{l}
\mathbf{if}\;x \leq -495675560.2626342 \lor \neg \left(x \leq 439.8864172703267\right):\\
\;\;\;\;\left(\frac{1}{x} + \frac{1}{{x}^{5}}\right) - \frac{1}{{x}^{3}}\\
\mathbf{else}:\\
\;\;\;\;x \cdot \frac{1}{1 + x \cdot x}\\
\end{array}(FPCore (x) :precision binary64 (/ x (+ (* x x) 1.0)))
(FPCore (x) :precision binary64 (if (or (<= x -495675560.2626342) (not (<= x 439.8864172703267))) (- (+ (/ 1.0 x) (/ 1.0 (pow x 5.0))) (/ 1.0 (pow x 3.0))) (* x (/ 1.0 (+ 1.0 (* x x))))))
double code(double x) {
return x / ((x * x) + 1.0);
}
double code(double x) {
double tmp;
if ((x <= -495675560.2626342) || !(x <= 439.8864172703267)) {
tmp = ((1.0 / x) + (1.0 / pow(x, 5.0))) - (1.0 / pow(x, 3.0));
} else {
tmp = x * (1.0 / (1.0 + (x * x)));
}
return tmp;
}







Bits error versus x
Results
| Original | 15.0 |
|---|---|
| Target | 0.1 |
| Herbie | 0.0 |
| Alternative 1 | |
|---|---|
| Accuracy | 0.0 |
| Cost | 2052 |
| Alternative 2 | |
|---|---|
| Accuracy | 15.0 |
| Cost | 960 |
| Alternative 3 | |
|---|---|
| Accuracy | 15.1 |
| Cost | 576 |
if x < -495675560.262634218 or 439.886417270326717 < x Initial program 30.5
rmApplied add-sqr-sqrt_binary64_44130.5
Applied associate-/r*_binary64_36330.4
Taylor expanded around inf 0.0
if -495675560.262634218 < x < 439.886417270326717Initial program 0.0
rmApplied div-inv_binary64_4160.0
Final simplification0.0
herbie shell --seed 2020322
(FPCore (x)
:name "x / (x^2 + 1)"
:precision binary64
:herbie-target
(/ 1.0 (+ x (/ 1.0 x)))
(/ x (+ (* x x) 1.0)))