\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 r109086 = 1.0;
double r109087 = x;
double r109088 = r109087 + r109086;
double r109089 = r109086 / r109088;
double r109090 = 2.0;
double r109091 = r109090 / r109087;
double r109092 = r109089 - r109091;
double r109093 = r109087 - r109086;
double r109094 = r109086 / r109093;
double r109095 = r109092 + r109094;
return r109095;
}
double f(double x) {
double r109096 = 2.0;
double r109097 = x;
double r109098 = 1.0;
double r109099 = r109097 + r109098;
double r109100 = r109099 * r109097;
double r109101 = r109096 / r109100;
double r109102 = r109097 - r109098;
double r109103 = r109101 / r109102;
return r109103;
}




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