\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 r262217 = 1.0;
double r262218 = x;
double r262219 = r262218 + r262217;
double r262220 = r262217 / r262219;
double r262221 = 2.0;
double r262222 = r262221 / r262218;
double r262223 = r262220 - r262222;
double r262224 = r262218 - r262217;
double r262225 = r262217 / r262224;
double r262226 = r262223 + r262225;
return r262226;
}
double f(double x) {
double r262227 = 2.0;
double r262228 = x;
double r262229 = 1.0;
double r262230 = r262228 + r262229;
double r262231 = r262230 * r262228;
double r262232 = r262227 / r262231;
double r262233 = r262228 - r262229;
double r262234 = r262232 / r262233;
return r262234;
}




Bits error versus x
Results
| Original | 9.4 |
|---|---|
| Target | 0.3 |
| Herbie | 0.1 |
Initial program 9.4
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 2019291
(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))))