\left(\frac{1}{x + 1} - \frac{2}{x}\right) + \frac{1}{x - 1}\frac{2}{\mathsf{fma}\left(x, x, -1\right) \cdot x}double f(double x) {
double r18301107 = 1.0;
double r18301108 = x;
double r18301109 = r18301108 + r18301107;
double r18301110 = r18301107 / r18301109;
double r18301111 = 2.0;
double r18301112 = r18301111 / r18301108;
double r18301113 = r18301110 - r18301112;
double r18301114 = r18301108 - r18301107;
double r18301115 = r18301107 / r18301114;
double r18301116 = r18301113 + r18301115;
return r18301116;
}
double f(double x) {
double r18301117 = 2.0;
double r18301118 = x;
double r18301119 = -1.0;
double r18301120 = fma(r18301118, r18301118, r18301119);
double r18301121 = r18301120 * r18301118;
double r18301122 = r18301117 / r18301121;
return r18301122;
}




Bits error versus x
| Original | 9.9 |
|---|---|
| Target | 0.3 |
| Herbie | 0.3 |
Initial program 9.9
rmApplied frac-sub25.9
Applied frac-add25.1
Simplified25.5
Simplified25.5
Taylor expanded around -inf 0.3
Final simplification0.3
herbie shell --seed 2019128 +o rules:numerics
(FPCore (x)
:name "3frac (problem 3.3.3)"
:herbie-target
(/ 2 (* x (- (* x x) 1)))
(+ (- (/ 1 (+ x 1)) (/ 2 x)) (/ 1 (- x 1))))