\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 r54948 = 1.0;
double r54949 = 2.0;
double r54950 = t;
double r54951 = r54949 * r54950;
double r54952 = r54948 + r54950;
double r54953 = r54951 / r54952;
double r54954 = r54953 * r54953;
double r54955 = r54948 + r54954;
double r54956 = r54949 + r54954;
double r54957 = r54955 / r54956;
return r54957;
}
double f(double t) {
double r54958 = 1.0;
double r54959 = 2.0;
double r54960 = t;
double r54961 = r54959 * r54960;
double r54962 = r54958 + r54960;
double r54963 = r54961 / r54962;
double r54964 = r54963 * r54963;
double r54965 = r54958 + r54964;
double r54966 = r54959 + r54964;
double r54967 = r54965 / r54966;
return r54967;
}



Bits error versus t
Results
Initial program 0.0
Final simplification0.0
herbie shell --seed 2020045
(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))))))