\left(\frac{1}{x + 1} - \frac{2}{x}\right) + \frac{1}{x - 1}\frac{\frac{\frac{2}{x + 1}}{x}}{x - 1}double f(double x) {
double r99642 = 1.0;
double r99643 = x;
double r99644 = r99643 + r99642;
double r99645 = r99642 / r99644;
double r99646 = 2.0;
double r99647 = r99646 / r99643;
double r99648 = r99645 - r99647;
double r99649 = r99643 - r99642;
double r99650 = r99642 / r99649;
double r99651 = r99648 + r99650;
return r99651;
}
double f(double x) {
double r99652 = 2.0;
double r99653 = x;
double r99654 = 1.0;
double r99655 = r99653 + r99654;
double r99656 = r99652 / r99655;
double r99657 = r99656 / r99653;
double r99658 = r99653 - r99654;
double r99659 = r99657 / r99658;
return r99659;
}




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