\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 r5713524 = 1.0;
double r5713525 = x;
double r5713526 = r5713525 + r5713524;
double r5713527 = r5713524 / r5713526;
double r5713528 = 2.0;
double r5713529 = r5713528 / r5713525;
double r5713530 = r5713527 - r5713529;
double r5713531 = r5713525 - r5713524;
double r5713532 = r5713524 / r5713531;
double r5713533 = r5713530 + r5713532;
return r5713533;
}
double f(double x) {
double r5713534 = 2.0;
double r5713535 = x;
double r5713536 = 1.0;
double r5713537 = r5713535 + r5713536;
double r5713538 = r5713537 * r5713535;
double r5713539 = r5713534 / r5713538;
double r5713540 = r5713535 - r5713536;
double r5713541 = r5713539 / r5713540;
return r5713541;
}




Bits error versus x
Results
| Original | 10.0 |
|---|---|
| Target | 0.2 |
| Herbie | 0.1 |
Initial program 10.0
rmApplied frac-sub26.2
Applied frac-add25.7
Taylor expanded around 0 0.3
rmApplied associate-/r*0.1
Final simplification0.1
herbie shell --seed 2019168 +o rules:numerics
(FPCore (x)
:name "3frac (problem 3.3.3)"
:herbie-target
(/ 2.0 (* x (- (* x x) 1.0)))
(+ (- (/ 1.0 (+ x 1.0)) (/ 2.0 x)) (/ 1.0 (- x 1.0))))