\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}{1 + t}, 2 - \frac{2}{1 + t}, 1\right)}{\mathsf{fma}\left(2 - \frac{2}{1 + t}, 2 - \frac{2}{1 + t}, 2\right)}double f(double t) {
double r977858 = 1.0;
double r977859 = 2.0;
double r977860 = t;
double r977861 = r977859 / r977860;
double r977862 = r977858 / r977860;
double r977863 = r977858 + r977862;
double r977864 = r977861 / r977863;
double r977865 = r977859 - r977864;
double r977866 = r977865 * r977865;
double r977867 = r977858 + r977866;
double r977868 = r977859 + r977866;
double r977869 = r977867 / r977868;
return r977869;
}
double f(double t) {
double r977870 = 2.0;
double r977871 = 1.0;
double r977872 = t;
double r977873 = r977871 + r977872;
double r977874 = r977870 / r977873;
double r977875 = r977870 - r977874;
double r977876 = fma(r977875, r977875, r977871);
double r977877 = fma(r977875, r977875, r977870);
double r977878 = r977876 / r977877;
return r977878;
}



Bits error versus t
Initial program 0.0
Simplified0.0
Final simplification0.0
herbie shell --seed 2019138 +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))))))))