\frac{x}{x \cdot x + 1}\begin{array}{l}
\mathbf{if}\;x \le -6258382897202.597:\\
\;\;\;\;\frac{1}{\left(\left(x \cdot x\right) \cdot \left(x \cdot x\right)\right) \cdot x} + \left(\frac{1}{x} - \frac{\frac{\frac{1}{x}}{x}}{x}\right)\\
\mathbf{elif}\;x \le 580.2919375789389:\\
\;\;\;\;\left(x \cdot x - 1\right) \cdot \frac{x}{\mathsf{fma}\left(x \cdot x, x \cdot x, -1\right)}\\
\mathbf{else}:\\
\;\;\;\;\frac{1}{\left(\left(x \cdot x\right) \cdot \left(x \cdot x\right)\right) \cdot x} + \left(\frac{1}{x} - \frac{\frac{\frac{1}{x}}{x}}{x}\right)\\
\end{array}double f(double x) {
double r1774393 = x;
double r1774394 = r1774393 * r1774393;
double r1774395 = 1.0;
double r1774396 = r1774394 + r1774395;
double r1774397 = r1774393 / r1774396;
return r1774397;
}
double f(double x) {
double r1774398 = x;
double r1774399 = -6258382897202.597;
bool r1774400 = r1774398 <= r1774399;
double r1774401 = 1.0;
double r1774402 = r1774398 * r1774398;
double r1774403 = r1774402 * r1774402;
double r1774404 = r1774403 * r1774398;
double r1774405 = r1774401 / r1774404;
double r1774406 = r1774401 / r1774398;
double r1774407 = r1774406 / r1774398;
double r1774408 = r1774407 / r1774398;
double r1774409 = r1774406 - r1774408;
double r1774410 = r1774405 + r1774409;
double r1774411 = 580.2919375789389;
bool r1774412 = r1774398 <= r1774411;
double r1774413 = r1774402 - r1774401;
double r1774414 = -1.0;
double r1774415 = fma(r1774402, r1774402, r1774414);
double r1774416 = r1774398 / r1774415;
double r1774417 = r1774413 * r1774416;
double r1774418 = r1774412 ? r1774417 : r1774410;
double r1774419 = r1774400 ? r1774410 : r1774418;
return r1774419;
}




Bits error versus x
| Original | 15.2 |
|---|---|
| Target | 0.1 |
| Herbie | 0.0 |
if x < -6258382897202.597 or 580.2919375789389 < x Initial program 30.6
Taylor expanded around -inf 0.0
Simplified0.0
if -6258382897202.597 < x < 580.2919375789389Initial program 0.0
rmApplied flip-+0.0
Applied associate-/r/0.0
Simplified0.0
Final simplification0.0
herbie shell --seed 2019143 +o rules:numerics
(FPCore (x)
:name "x / (x^2 + 1)"
:herbie-target
(/ 1 (+ x (/ 1 x)))
(/ x (+ (* x x) 1)))