\left(\frac{1}{x + 1} - \frac{2}{x}\right) + \frac{1}{x - 1}\begin{array}{l}
\mathbf{if}\;\left(\frac{1}{x + 1} - \frac{2}{x}\right) + \frac{1}{x - 1} \le -648.3628771614285142277367413043975830078:\\
\;\;\;\;\frac{1 \cdot x - \left(x + 1\right) \cdot 2}{\left(x + 1\right) \cdot x} + \frac{1}{x - 1}\\
\mathbf{elif}\;\left(\frac{1}{x + 1} - \frac{2}{x}\right) + \frac{1}{x - 1} \le 1.063446409383349278154895500847487710416 \cdot 10^{-11}:\\
\;\;\;\;\frac{2}{{x}^{7}} + \left(\frac{2}{{x}^{5}} + \frac{\frac{\frac{2}{x}}{x}}{x}\right)\\
\mathbf{else}:\\
\;\;\;\;\left(\frac{1}{x + 1} - \frac{2}{x}\right) + \frac{1}{x - 1}\\
\end{array}double f(double x) {
double r103454 = 1.0;
double r103455 = x;
double r103456 = r103455 + r103454;
double r103457 = r103454 / r103456;
double r103458 = 2.0;
double r103459 = r103458 / r103455;
double r103460 = r103457 - r103459;
double r103461 = r103455 - r103454;
double r103462 = r103454 / r103461;
double r103463 = r103460 + r103462;
return r103463;
}
double f(double x) {
double r103464 = 1.0;
double r103465 = x;
double r103466 = r103465 + r103464;
double r103467 = r103464 / r103466;
double r103468 = 2.0;
double r103469 = r103468 / r103465;
double r103470 = r103467 - r103469;
double r103471 = r103465 - r103464;
double r103472 = r103464 / r103471;
double r103473 = r103470 + r103472;
double r103474 = -648.3628771614285;
bool r103475 = r103473 <= r103474;
double r103476 = r103464 * r103465;
double r103477 = r103466 * r103468;
double r103478 = r103476 - r103477;
double r103479 = r103466 * r103465;
double r103480 = r103478 / r103479;
double r103481 = r103480 + r103472;
double r103482 = 1.0634464093833493e-11;
bool r103483 = r103473 <= r103482;
double r103484 = 7.0;
double r103485 = pow(r103465, r103484);
double r103486 = r103468 / r103485;
double r103487 = 5.0;
double r103488 = pow(r103465, r103487);
double r103489 = r103468 / r103488;
double r103490 = r103469 / r103465;
double r103491 = r103490 / r103465;
double r103492 = r103489 + r103491;
double r103493 = r103486 + r103492;
double r103494 = r103483 ? r103493 : r103473;
double r103495 = r103475 ? r103481 : r103494;
return r103495;
}




Bits error versus x
Results
| Original | 9.6 |
|---|---|
| Target | 0.2 |
| Herbie | 0.4 |
if (+ (- (/ 1.0 (+ x 1.0)) (/ 2.0 x)) (/ 1.0 (- x 1.0))) < -648.3628771614285Initial program 0.0
rmApplied frac-sub0.0
if -648.3628771614285 < (+ (- (/ 1.0 (+ x 1.0)) (/ 2.0 x)) (/ 1.0 (- x 1.0))) < 1.0634464093833493e-11Initial program 19.3
Taylor expanded around inf 1.0
Simplified1.0
rmApplied unpow31.0
Applied associate-/r*0.6
Simplified0.6
if 1.0634464093833493e-11 < (+ (- (/ 1.0 (+ x 1.0)) (/ 2.0 x)) (/ 1.0 (- x 1.0))) Initial program 0.2
rmApplied frac-sub0.2
rmApplied *-un-lft-identity0.2
Applied *-un-lft-identity0.2
Applied distribute-lft-out0.2
Simplified0.2
Final simplification0.4
herbie shell --seed 2019306
(FPCore (x)
:name "3frac (problem 3.3.3)"
:precision binary64
:herbie-target
(/ 2 (* x (- (* x x) 1)))
(+ (- (/ 1 (+ x 1)) (/ 2 x)) (/ 1 (- x 1))))