double f(double t) {
double r3942009 = 1.0;
double r3942010 = 2.0;
double r3942011 = t;
double r3942012 = r3942010 * r3942011;
double r3942013 = r3942009 + r3942011;
double r3942014 = r3942012 / r3942013;
double r3942015 = r3942014 * r3942014;
double r3942016 = r3942009 + r3942015;
double r3942017 = r3942010 + r3942015;
double r3942018 = r3942016 / r3942017;
return r3942018;
}
double f(double t) {
double r3942019 = t;
double r3942020 = 2.0;
double r3942021 = r3942019 * r3942020;
double r3942022 = 1.0;
double r3942023 = r3942022 + r3942019;
double r3942024 = r3942021 / r3942023;
double r3942025 = fma(r3942024, r3942024, r3942022);
double r3942026 = fma(r3942024, r3942024, r3942020);
double r3942027 = r3942025 / r3942026;
return r3942027;
}
\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{(\left(\frac{t \cdot 2}{1 + t}\right) \cdot \left(\frac{t \cdot 2}{1 + t}\right) + 1)_*}{(\left(\frac{t \cdot 2}{1 + t}\right) \cdot \left(\frac{t \cdot 2}{1 + t}\right) + 2)_*}


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