double f(double x) {
double r2793946 = 1.0;
double r2793947 = x;
double r2793948 = r2793947 + r2793946;
double r2793949 = r2793946 / r2793948;
double r2793950 = r2793946 / r2793947;
double r2793951 = r2793949 - r2793950;
return r2793951;
}
double f(double x) {
double r2793952 = 1.0;
double r2793953 = x;
double r2793954 = r2793953 + r2793952;
double r2793955 = r2793952 / r2793954;
double r2793956 = r2793952 / r2793953;
double r2793957 = r2793955 + r2793956;
double r2793958 = r2793955 - r2793956;
double r2793959 = r2793957 / r2793958;
double r2793960 = r2793957 / r2793959;
return r2793960;
}
\frac{1}{x + 1} - \frac{1}{x}\frac{\frac{1}{x + 1} + \frac{1}{x}}{\frac{\frac{1}{x + 1} + \frac{1}{x}}{\frac{1}{x + 1} - \frac{1}{x}}}


Bits error versus x
Initial program 0.6
rmApplied p16-flip--1.3
rmApplied difference-of-squares1.0
Applied associate-/l*0.9
Final simplification0.9
herbie shell --seed 2019102 +o rules:numerics
(FPCore (x)
:name "2frac (problem 3.3.1)"
(-.p16 (/.p16 (real->posit16 1) (+.p16 x (real->posit16 1))) (/.p16 (real->posit16 1) x)))