\frac{x}{x \cdot x + 1}\begin{array}{l}
\mathbf{if}\;x \le -955471611474.0786:\\
\;\;\;\;\frac{1}{x} - \left(\frac{\frac{1}{x}}{x \cdot x} - \frac{1}{\left(\left(x \cdot x\right) \cdot x\right) \cdot \left(x \cdot x\right)}\right)\\
\mathbf{elif}\;x \le 129599.43046274735:\\
\;\;\;\;\frac{x}{1 + x \cdot x}\\
\mathbf{else}:\\
\;\;\;\;\frac{1}{x} - \left(\frac{\frac{1}{x}}{x \cdot x} - \frac{1}{\left(\left(x \cdot x\right) \cdot x\right) \cdot \left(x \cdot x\right)}\right)\\
\end{array}double f(double x) {
double r1626875 = x;
double r1626876 = r1626875 * r1626875;
double r1626877 = 1.0;
double r1626878 = r1626876 + r1626877;
double r1626879 = r1626875 / r1626878;
return r1626879;
}
double f(double x) {
double r1626880 = x;
double r1626881 = -955471611474.0786;
bool r1626882 = r1626880 <= r1626881;
double r1626883 = 1.0;
double r1626884 = r1626883 / r1626880;
double r1626885 = r1626880 * r1626880;
double r1626886 = r1626884 / r1626885;
double r1626887 = r1626885 * r1626880;
double r1626888 = r1626887 * r1626885;
double r1626889 = r1626883 / r1626888;
double r1626890 = r1626886 - r1626889;
double r1626891 = r1626884 - r1626890;
double r1626892 = 129599.43046274735;
bool r1626893 = r1626880 <= r1626892;
double r1626894 = r1626883 + r1626885;
double r1626895 = r1626880 / r1626894;
double r1626896 = r1626893 ? r1626895 : r1626891;
double r1626897 = r1626882 ? r1626891 : r1626896;
return r1626897;
}




Bits error versus x
Results
| Original | 15.2 |
|---|---|
| Target | 0.1 |
| Herbie | 0.0 |
if x < -955471611474.0786 or 129599.43046274735 < x Initial program 30.7
Taylor expanded around inf 0.0
Simplified0.0
if -955471611474.0786 < x < 129599.43046274735Initial program 0.0
Final simplification0.0
herbie shell --seed 2019135
(FPCore (x)
:name "x / (x^2 + 1)"
:herbie-target
(/ 1 (+ x (/ 1 x)))
(/ x (+ (* x x) 1)))