\frac{\left(\frac{\left(\left(i \cdot i\right) \cdot \left(i \cdot i\right)\right)}{\left(\left(\left(2\right) \cdot i\right) \cdot \left(\left(2\right) \cdot i\right)\right)}\right)}{\left(\left(\left(\left(2\right) \cdot i\right) \cdot \left(\left(2\right) \cdot i\right)\right) - \left(1.0\right)\right)}\frac{\frac{i}{2}}{i \cdot 2 + 1.0} \cdot \frac{\frac{i}{2}}{i \cdot 2 - 1.0}double f(double i) {
double r2093423 = i;
double r2093424 = r2093423 * r2093423;
double r2093425 = r2093424 * r2093424;
double r2093426 = 2.0;
double r2093427 = /* ERROR: no posit support in C */;
double r2093428 = r2093427 * r2093423;
double r2093429 = r2093428 * r2093428;
double r2093430 = r2093425 / r2093429;
double r2093431 = 1.0;
double r2093432 = /* ERROR: no posit support in C */;
double r2093433 = r2093429 - r2093432;
double r2093434 = r2093430 / r2093433;
return r2093434;
}
double f(double i) {
double r2093435 = i;
double r2093436 = 2.0;
double r2093437 = r2093435 / r2093436;
double r2093438 = r2093435 * r2093436;
double r2093439 = 1.0;
double r2093440 = r2093438 + r2093439;
double r2093441 = r2093437 / r2093440;
double r2093442 = r2093438 - r2093439;
double r2093443 = r2093437 / r2093442;
double r2093444 = r2093441 * r2093443;
return r2093444;
}



Bits error versus i
Initial program 2.3
Simplified2.4
rmApplied p16-times-frac1.2
rmApplied associate-*r/1.2
Applied associate-*l/1.1
Simplified0.9
rmApplied difference-of-sqr-10.8
Applied p16-times-frac0.4
Final simplification0.4
herbie shell --seed 2019104 +o rules:numerics
(FPCore (i)
:name "Octave 3.8, jcobi/4, as called"
:pre (and (>.p16 i (real->posit16 0)))
(/.p16 (/.p16 (*.p16 (*.p16 i i) (*.p16 i i)) (*.p16 (*.p16 (real->posit16 2) i) (*.p16 (real->posit16 2) i))) (-.p16 (*.p16 (*.p16 (real->posit16 2) i) (*.p16 (real->posit16 2) i)) (real->posit16 1.0))))