\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 r4874140 = 1.0;
double r4874141 = x;
double r4874142 = r4874141 + r4874140;
double r4874143 = r4874140 / r4874142;
double r4874144 = 2.0;
double r4874145 = r4874144 / r4874141;
double r4874146 = r4874143 - r4874145;
double r4874147 = r4874141 - r4874140;
double r4874148 = r4874140 / r4874147;
double r4874149 = r4874146 + r4874148;
return r4874149;
}
double f(double x) {
double r4874150 = 2.0;
double r4874151 = x;
double r4874152 = 1.0;
double r4874153 = r4874151 + r4874152;
double r4874154 = r4874150 / r4874153;
double r4874155 = r4874154 / r4874151;
double r4874156 = r4874151 - r4874152;
double r4874157 = r4874155 / r4874156;
return r4874157;
}




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