\left(\frac{1}{x + 1} - \frac{2}{x}\right) + \frac{1}{x - 1}\frac{\frac{2}{\left(x + 1\right) \cdot x}}{x - 1}double f(double x) {
double r466 = 1.0;
double r467 = x;
double r468 = r467 + r466;
double r469 = r466 / r468;
double r470 = 2.0;
double r471 = r470 / r467;
double r472 = r469 - r471;
double r473 = r467 - r466;
double r474 = r466 / r473;
double r475 = r472 + r474;
return r475;
}
double f(double x) {
double r476 = 2.0;
double r477 = x;
double r478 = 1.0;
double r479 = r477 + r478;
double r480 = r479 * r477;
double r481 = r476 / r480;
double r482 = r477 - r478;
double r483 = r481 / r482;
return r483;
}




Bits error versus x
Results
| Original | 10.2 |
|---|---|
| Target | 0.3 |
| Herbie | 0.1 |
Initial program 10.2
rmApplied frac-sub26.6
Applied frac-add26.1
Taylor expanded around 0 0.3
rmApplied associate-/r*0.1
Final simplification0.1
herbie shell --seed 2020025
(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))))