\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 r86857 = 1.0;
double r86858 = x;
double r86859 = r86858 + r86857;
double r86860 = r86857 / r86859;
double r86861 = 2.0;
double r86862 = r86861 / r86858;
double r86863 = r86860 - r86862;
double r86864 = r86858 - r86857;
double r86865 = r86857 / r86864;
double r86866 = r86863 + r86865;
return r86866;
}
double f(double x) {
double r86867 = 2.0;
double r86868 = x;
double r86869 = 1.0;
double r86870 = r86868 + r86869;
double r86871 = r86870 * r86868;
double r86872 = r86867 / r86871;
double r86873 = r86868 - r86869;
double r86874 = r86872 / r86873;
return r86874;
}




Bits error versus x
Results
| Original | 9.5 |
|---|---|
| Target | 0.3 |
| Herbie | 0.1 |
Initial program 9.5
rmApplied frac-sub25.9
Applied frac-add25.5
Taylor expanded around 0 0.3
rmApplied associate-/r*0.1
Final simplification0.1
herbie shell --seed 2020083
(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))))