\left(\frac{\left(1\right)}{\left(\sqrt{x}\right)}\right) - \left(\frac{\left(1\right)}{\left(\sqrt{\left(\frac{x}{\left(1\right)}\right)}\right)}\right)\frac{\left(\frac{1}{\sqrt{x}} + \frac{1}{\sqrt{x + 1}}\right) \cdot \left(\frac{1}{\sqrt{x}} - \frac{1}{\sqrt{x + 1}}\right)}{\frac{1}{\sqrt{x}} + \frac{1}{\sqrt{x + 1}}}double f(double x) {
double r6413595 = 1.0;
double r6413596 = /* ERROR: no posit support in C */;
double r6413597 = x;
double r6413598 = sqrt(r6413597);
double r6413599 = r6413596 / r6413598;
double r6413600 = r6413597 + r6413596;
double r6413601 = sqrt(r6413600);
double r6413602 = r6413596 / r6413601;
double r6413603 = r6413599 - r6413602;
return r6413603;
}
double f(double x) {
double r6413604 = 1.0;
double r6413605 = x;
double r6413606 = sqrt(r6413605);
double r6413607 = r6413604 / r6413606;
double r6413608 = r6413605 + r6413604;
double r6413609 = sqrt(r6413608);
double r6413610 = r6413604 / r6413609;
double r6413611 = r6413607 + r6413610;
double r6413612 = r6413607 - r6413610;
double r6413613 = r6413611 * r6413612;
double r6413614 = r6413613 / r6413611;
return r6413614;
}



Bits error versus x
Initial program 0.5
rmApplied p16-flip--0.7
rmApplied difference-of-squares0.6
Final simplification0.6
herbie shell --seed 2019128 +o rules:numerics
(FPCore (x)
:name "2isqrt (example 3.6)"
(-.p16 (/.p16 (real->posit16 1) (sqrt.p16 x)) (/.p16 (real->posit16 1) (sqrt.p16 (+.p16 x (real->posit16 1))))))