\frac{x}{x \cdot x + 1}\begin{array}{l}
\mathbf{if}\;x \le -2125041.416232987:\\
\;\;\;\;\left(\frac{1}{{x}^{5}} + \frac{1}{x}\right) - \frac{1}{\left(x \cdot x\right) \cdot x}\\
\mathbf{elif}\;x \le 406.12657832258094:\\
\;\;\;\;\frac{x}{\left(x \cdot x\right) \cdot \left(x \cdot x\right) - 1} \cdot \left(x \cdot x - 1\right)\\
\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 r6040467 = x;
double r6040468 = r6040467 * r6040467;
double r6040469 = 1.0;
double r6040470 = r6040468 + r6040469;
double r6040471 = r6040467 / r6040470;
return r6040471;
}
double f(double x) {
double r6040472 = x;
double r6040473 = -2125041.416232987;
bool r6040474 = r6040472 <= r6040473;
double r6040475 = 1.0;
double r6040476 = 5.0;
double r6040477 = pow(r6040472, r6040476);
double r6040478 = r6040475 / r6040477;
double r6040479 = r6040475 / r6040472;
double r6040480 = r6040478 + r6040479;
double r6040481 = r6040472 * r6040472;
double r6040482 = r6040481 * r6040472;
double r6040483 = r6040475 / r6040482;
double r6040484 = r6040480 - r6040483;
double r6040485 = 406.12657832258094;
bool r6040486 = r6040472 <= r6040485;
double r6040487 = r6040481 * r6040481;
double r6040488 = r6040487 - r6040475;
double r6040489 = r6040472 / r6040488;
double r6040490 = r6040481 - r6040475;
double r6040491 = r6040489 * r6040490;
double r6040492 = r6040486 ? r6040491 : r6040484;
double r6040493 = r6040474 ? r6040484 : r6040492;
return r6040493;
}




Bits error versus x
Results
| Original | 15.1 |
|---|---|
| Target | 0.1 |
| Herbie | 0.0 |
if x < -2125041.416232987 or 406.12657832258094 < x Initial program 30.5
Taylor expanded around -inf 0.0
Simplified0.0
if -2125041.416232987 < x < 406.12657832258094Initial program 0.0
rmApplied flip-+0.0
Applied associate-/r/0.0
Final simplification0.0
herbie shell --seed 2019104
(FPCore (x)
:name "x / (x^2 + 1)"
:herbie-target
(/ 1 (+ x (/ 1 x)))
(/ x (+ (* x x) 1)))