\frac{1 + \frac{2 \cdot t}{1 + t} \cdot \frac{2 \cdot t}{1 + t}}{2 + \frac{2 \cdot t}{1 + t} \cdot \frac{2 \cdot t}{1 + t}}\frac{1 + \frac{2 \cdot t}{1 + t} \cdot \frac{2 \cdot t}{1 + t}}{2 + \frac{2 \cdot t}{1 + t} \cdot \frac{2 \cdot t}{1 + t}}double f(double t) {
double r32069 = 1.0;
double r32070 = 2.0;
double r32071 = t;
double r32072 = r32070 * r32071;
double r32073 = r32069 + r32071;
double r32074 = r32072 / r32073;
double r32075 = r32074 * r32074;
double r32076 = r32069 + r32075;
double r32077 = r32070 + r32075;
double r32078 = r32076 / r32077;
return r32078;
}
double f(double t) {
double r32079 = 1.0;
double r32080 = 2.0;
double r32081 = t;
double r32082 = r32080 * r32081;
double r32083 = r32079 + r32081;
double r32084 = r32082 / r32083;
double r32085 = r32084 * r32084;
double r32086 = r32079 + r32085;
double r32087 = r32080 + r32085;
double r32088 = r32086 / r32087;
return r32088;
}



Bits error versus t
Results
Initial program 0.0
Final simplification0.0
herbie shell --seed 2019291
(FPCore (t)
:name "Kahan p13 Example 1"
:precision binary64
(/ (+ 1 (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t)))) (+ 2 (* (/ (* 2 t) (+ 1 t)) (/ (* 2 t) (+ 1 t))))))