1 - \frac{1}{2 + \left(2 - \frac{\frac{2}{t}}{1 + \frac{1}{t}}\right) \cdot \left(2 - \frac{\frac{2}{t}}{1 + \frac{1}{t}}\right)}1 - \mathsf{expm1}\left(\left(\mathsf{log1p}\left(\left(\frac{1}{\mathsf{fma}\left(\left(2 - \frac{2}{1 + t}\right), \left(2 - \frac{2}{1 + t}\right), 2\right)}\right)\right)\right)\right)double f(double t) {
double r668068 = 1.0;
double r668069 = 2.0;
double r668070 = t;
double r668071 = r668069 / r668070;
double r668072 = r668068 / r668070;
double r668073 = r668068 + r668072;
double r668074 = r668071 / r668073;
double r668075 = r668069 - r668074;
double r668076 = r668075 * r668075;
double r668077 = r668069 + r668076;
double r668078 = r668068 / r668077;
double r668079 = r668068 - r668078;
return r668079;
}
double f(double t) {
double r668080 = 1.0;
double r668081 = 2.0;
double r668082 = t;
double r668083 = r668080 + r668082;
double r668084 = r668081 / r668083;
double r668085 = r668081 - r668084;
double r668086 = fma(r668085, r668085, r668081);
double r668087 = r668080 / r668086;
double r668088 = log1p(r668087);
double r668089 = expm1(r668088);
double r668090 = r668080 - r668089;
return r668090;
}



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