\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 r91899 = 1.0;
double r91900 = x;
double r91901 = r91900 + r91899;
double r91902 = r91899 / r91901;
double r91903 = 2.0;
double r91904 = r91903 / r91900;
double r91905 = r91902 - r91904;
double r91906 = r91900 - r91899;
double r91907 = r91899 / r91906;
double r91908 = r91905 + r91907;
return r91908;
}
double f(double x) {
double r91909 = 2.0;
double r91910 = x;
double r91911 = 1.0;
double r91912 = r91910 + r91911;
double r91913 = r91912 * r91910;
double r91914 = r91909 / r91913;
double r91915 = r91910 - r91911;
double r91916 = r91914 / r91915;
return r91916;
}




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