\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 r15724146 = 1.0;
double r15724147 = x;
double r15724148 = r15724147 + r15724146;
double r15724149 = r15724146 / r15724148;
double r15724150 = 2.0;
double r15724151 = r15724150 / r15724147;
double r15724152 = r15724149 - r15724151;
double r15724153 = r15724147 - r15724146;
double r15724154 = r15724146 / r15724153;
double r15724155 = r15724152 + r15724154;
return r15724155;
}
double f(double x) {
double r15724156 = 2.0;
double r15724157 = x;
double r15724158 = -1.0;
double r15724159 = fma(r15724157, r15724157, r15724158);
double r15724160 = r15724159 * r15724157;
double r15724161 = r15724156 / r15724160;
return r15724161;
}




Bits error versus x
| Original | 9.9 |
|---|---|
| Target | 0.3 |
| Herbie | 0.3 |
Initial program 9.9
rmApplied frac-sub26.1
Applied frac-add25.4
Simplified25.8
Simplified25.8
Taylor expanded around inf 0.3
Final simplification0.3
herbie shell --seed 2019120 +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))))