\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 r57537 = 1.0;
double r57538 = 2.0;
double r57539 = t;
double r57540 = r57538 * r57539;
double r57541 = r57537 + r57539;
double r57542 = r57540 / r57541;
double r57543 = r57542 * r57542;
double r57544 = r57537 + r57543;
double r57545 = r57538 + r57543;
double r57546 = r57544 / r57545;
return r57546;
}
double f(double t) {
double r57547 = 1.0;
double r57548 = 2.0;
double r57549 = t;
double r57550 = r57548 * r57549;
double r57551 = r57547 + r57549;
double r57552 = r57550 / r57551;
double r57553 = r57552 * r57552;
double r57554 = r57547 + r57553;
double r57555 = r57548 + r57553;
double r57556 = r57554 / r57555;
return r57556;
}



Bits error versus t
Results
Initial program 0.1
Final simplification0.1
herbie shell --seed 2020064
(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))))))