\left(\frac{1}{x + 1} - \frac{2}{x}\right) + \frac{1}{x - 1}\frac{1}{\left(x + 1\right) \cdot x} \cdot \frac{2}{x - 1}double f(double x) {
double r106748 = 1.0;
double r106749 = x;
double r106750 = r106749 + r106748;
double r106751 = r106748 / r106750;
double r106752 = 2.0;
double r106753 = r106752 / r106749;
double r106754 = r106751 - r106753;
double r106755 = r106749 - r106748;
double r106756 = r106748 / r106755;
double r106757 = r106754 + r106756;
return r106757;
}
double f(double x) {
double r106758 = 1.0;
double r106759 = x;
double r106760 = 1.0;
double r106761 = r106759 + r106760;
double r106762 = r106761 * r106759;
double r106763 = r106758 / r106762;
double r106764 = 2.0;
double r106765 = r106759 - r106760;
double r106766 = r106764 / r106765;
double r106767 = r106763 * r106766;
return r106767;
}




Bits error versus x
Results
| Original | 10.6 |
|---|---|
| Target | 0.3 |
| Herbie | 0.1 |
Initial program 10.6
rmApplied frac-sub26.2
Applied frac-add25.6
Taylor expanded around 0 0.3
rmApplied *-un-lft-identity0.3
Applied times-frac0.1
Final simplification0.1
herbie shell --seed 2020045
(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))))