\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 r68822 = 1.0;
double r68823 = 2.0;
double r68824 = t;
double r68825 = r68823 * r68824;
double r68826 = r68822 + r68824;
double r68827 = r68825 / r68826;
double r68828 = r68827 * r68827;
double r68829 = r68822 + r68828;
double r68830 = r68823 + r68828;
double r68831 = r68829 / r68830;
return r68831;
}
double f(double t) {
double r68832 = 1.0;
double r68833 = 2.0;
double r68834 = t;
double r68835 = r68833 * r68834;
double r68836 = r68832 + r68834;
double r68837 = r68835 / r68836;
double r68838 = r68837 * r68837;
double r68839 = r68832 + r68838;
double r68840 = r68833 + r68838;
double r68841 = r68839 / r68840;
return r68841;
}



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