\frac{x}{x \cdot x + 1}\begin{array}{l}
\mathbf{if}\;x \le -1.337062526028986 \cdot 10^{154} \lor \neg \left(x \le 438.67577561485041\right):\\
\;\;\;\;\mathsf{fma}\left(1, \frac{1}{{x}^{5}} - \frac{1}{{x}^{3}}, \frac{1}{x}\right)\\
\mathbf{else}:\\
\;\;\;\;\frac{\frac{x}{\sqrt{x \cdot x + 1}}}{\sqrt{x \cdot x + 1}}\\
\end{array}double code(double x) {
return (x / ((x * x) + 1.0));
}
double code(double x) {
double VAR;
if (((x <= -1.337062526028986e+154) || !(x <= 438.6757756148504))) {
VAR = fma(1.0, ((1.0 / pow(x, 5.0)) - (1.0 / pow(x, 3.0))), (1.0 / x));
} else {
VAR = ((x / sqrt(((x * x) + 1.0))) / sqrt(((x * x) + 1.0)));
}
return VAR;
}




Bits error versus x
Results
| Original | 15.4 |
|---|---|
| Target | 0.1 |
| Herbie | 0.0 |
if x < -1.337062526028986e+154 or 438.6757756148504 < x Initial program 40.2
Taylor expanded around inf 0.0
Simplified0.0
if -1.337062526028986e+154 < x < 438.6757756148504Initial program 0.1
rmApplied add-sqr-sqrt0.1
Applied associate-/r*0.0
Final simplification0.0
herbie shell --seed 2020102 +o rules:numerics
(FPCore (x)
:name "x / (x^2 + 1)"
:precision binary64
:herbie-target
(/ 1 (+ x (/ 1 x)))
(/ x (+ (* x x) 1)))