\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 r91290 = 1.0;
double r91291 = x;
double r91292 = r91291 + r91290;
double r91293 = r91290 / r91292;
double r91294 = 2.0;
double r91295 = r91294 / r91291;
double r91296 = r91293 - r91295;
double r91297 = r91291 - r91290;
double r91298 = r91290 / r91297;
double r91299 = r91296 + r91298;
return r91299;
}
double f(double x) {
double r91300 = 1.0;
double r91301 = x;
double r91302 = 1.0;
double r91303 = r91301 + r91302;
double r91304 = r91303 * r91301;
double r91305 = r91300 / r91304;
double r91306 = 2.0;
double r91307 = r91301 - r91302;
double r91308 = r91306 / r91307;
double r91309 = r91305 * r91308;
return r91309;
}




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