\left(\frac{1}{x + 1} - \frac{2}{x}\right) + \frac{1}{x - 1}\frac{2}{{x}^{3} - 1 \cdot x}double f(double x) {
double r132000 = 1.0;
double r132001 = x;
double r132002 = r132001 + r132000;
double r132003 = r132000 / r132002;
double r132004 = 2.0;
double r132005 = r132004 / r132001;
double r132006 = r132003 - r132005;
double r132007 = r132001 - r132000;
double r132008 = r132000 / r132007;
double r132009 = r132006 + r132008;
return r132009;
}
double f(double x) {
double r132010 = 2.0;
double r132011 = x;
double r132012 = 3.0;
double r132013 = pow(r132011, r132012);
double r132014 = 1.0;
double r132015 = r132014 * r132011;
double r132016 = r132013 - r132015;
double r132017 = r132010 / r132016;
return r132017;
}




Bits error versus x
Results
| Original | 10.1 |
|---|---|
| Target | 0.3 |
| Herbie | 0.3 |
Initial program 10.1
rmApplied frac-sub26.4
Applied frac-add25.9
Simplified26.3
Taylor expanded around 0 0.3
Taylor expanded around 0 0.3
Final simplification0.3
herbie shell --seed 2020057 +o rules:numerics
(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))))