\frac{1 + \left(2 - \frac{\frac{2}{t}}{1 + \frac{1}{t}}\right) \cdot \left(2 - \frac{\frac{2}{t}}{1 + \frac{1}{t}}\right)}{2 + \left(2 - \frac{\frac{2}{t}}{1 + \frac{1}{t}}\right) \cdot \left(2 - \frac{\frac{2}{t}}{1 + \frac{1}{t}}\right)}\frac{\mathsf{fma}\left(2 - \frac{2}{t + 1}, 2 - \frac{2}{t + 1}, 1\right)}{\mathsf{fma}\left(2 - \frac{2}{t + 1}, 2 - \frac{2}{t + 1}, 2\right)}double f(double t) {
double r607434 = 1.0;
double r607435 = 2.0;
double r607436 = t;
double r607437 = r607435 / r607436;
double r607438 = r607434 / r607436;
double r607439 = r607434 + r607438;
double r607440 = r607437 / r607439;
double r607441 = r607435 - r607440;
double r607442 = r607441 * r607441;
double r607443 = r607434 + r607442;
double r607444 = r607435 + r607442;
double r607445 = r607443 / r607444;
return r607445;
}
double f(double t) {
double r607446 = 2.0;
double r607447 = t;
double r607448 = 1.0;
double r607449 = r607447 + r607448;
double r607450 = r607446 / r607449;
double r607451 = r607446 - r607450;
double r607452 = fma(r607451, r607451, r607448);
double r607453 = fma(r607451, r607451, r607446);
double r607454 = r607452 / r607453;
return r607454;
}



Bits error versus t
Initial program 0.0
Simplified0.0
Final simplification0.0
herbie shell --seed 2019151 +o rules:numerics
(FPCore (t)
:name "Kahan p13 Example 2"
(/ (+ 1 (* (- 2 (/ (/ 2 t) (+ 1 (/ 1 t)))) (- 2 (/ (/ 2 t) (+ 1 (/ 1 t)))))) (+ 2 (* (- 2 (/ (/ 2 t) (+ 1 (/ 1 t)))) (- 2 (/ (/ 2 t) (+ 1 (/ 1 t))))))))