\frac{x}{x \cdot x + 1}\begin{array}{l}
\mathbf{if}\;x \le -1.3559032781469798 \cdot 10^{+154}:\\
\;\;\;\;\left(\frac{1}{{x}^{5}} + \frac{1}{x}\right) - \frac{1}{\left(x \cdot x\right) \cdot x}\\
\mathbf{elif}\;x \le 423.7918602723902:\\
\;\;\;\;\frac{\frac{x}{\sqrt{1 + x \cdot x}}}{\sqrt{1 + x \cdot x}}\\
\mathbf{else}:\\
\;\;\;\;\left(\frac{1}{{x}^{5}} + \frac{1}{x}\right) - \frac{1}{\left(x \cdot x\right) \cdot x}\\
\end{array}double f(double x) {
double r5543879 = x;
double r5543880 = r5543879 * r5543879;
double r5543881 = 1.0;
double r5543882 = r5543880 + r5543881;
double r5543883 = r5543879 / r5543882;
return r5543883;
}
double f(double x) {
double r5543884 = x;
double r5543885 = -1.3559032781469798e+154;
bool r5543886 = r5543884 <= r5543885;
double r5543887 = 1.0;
double r5543888 = 5.0;
double r5543889 = pow(r5543884, r5543888);
double r5543890 = r5543887 / r5543889;
double r5543891 = r5543887 / r5543884;
double r5543892 = r5543890 + r5543891;
double r5543893 = r5543884 * r5543884;
double r5543894 = r5543893 * r5543884;
double r5543895 = r5543887 / r5543894;
double r5543896 = r5543892 - r5543895;
double r5543897 = 423.7918602723902;
bool r5543898 = r5543884 <= r5543897;
double r5543899 = r5543887 + r5543893;
double r5543900 = sqrt(r5543899);
double r5543901 = r5543884 / r5543900;
double r5543902 = r5543901 / r5543900;
double r5543903 = r5543898 ? r5543902 : r5543896;
double r5543904 = r5543886 ? r5543896 : r5543903;
return r5543904;
}




Bits error versus x
Results
| Original | 15.1 |
|---|---|
| Target | 0.1 |
| Herbie | 0.0 |
if x < -1.3559032781469798e+154 or 423.7918602723902 < x Initial program 39.9
Taylor expanded around -inf 0.0
Simplified0.0
if -1.3559032781469798e+154 < x < 423.7918602723902Initial program 0.1
rmApplied add-sqr-sqrt0.1
Applied associate-/r*0.0
Final simplification0.0
herbie shell --seed 2019121
(FPCore (x)
:name "x / (x^2 + 1)"
:herbie-target
(/ 1 (+ x (/ 1 x)))
(/ x (+ (* x x) 1)))