\frac{1}{\sqrt{x}} - \frac{1}{\sqrt{x + 1}}\frac{\sqrt[3]{1} \cdot \sqrt[3]{1}}{\sqrt{x}} \cdot \frac{\sqrt[3]{1}}{\mathsf{fma}\left(\sqrt{x + 1}, \sqrt{x} \cdot 1, 1 \cdot \left(x + 1\right)\right)}double f(double x) {
double r6817583 = 1.0;
double r6817584 = x;
double r6817585 = sqrt(r6817584);
double r6817586 = r6817583 / r6817585;
double r6817587 = r6817584 + r6817583;
double r6817588 = sqrt(r6817587);
double r6817589 = r6817583 / r6817588;
double r6817590 = r6817586 - r6817589;
return r6817590;
}
double f(double x) {
double r6817591 = 1.0;
double r6817592 = cbrt(r6817591);
double r6817593 = r6817592 * r6817592;
double r6817594 = x;
double r6817595 = sqrt(r6817594);
double r6817596 = r6817593 / r6817595;
double r6817597 = r6817594 + r6817591;
double r6817598 = sqrt(r6817597);
double r6817599 = r6817595 * r6817591;
double r6817600 = r6817591 * r6817597;
double r6817601 = fma(r6817598, r6817599, r6817600);
double r6817602 = r6817592 / r6817601;
double r6817603 = r6817596 * r6817602;
return r6817603;
}




Bits error versus x
| Original | 20.0 |
|---|---|
| Target | 0.8 |
| Herbie | 0.3 |
Initial program 20.0
rmApplied frac-sub20.0
rmApplied flip--19.8
Taylor expanded around 0 0.4
rmApplied *-un-lft-identity0.4
Applied add-cube-cbrt0.4
Applied times-frac0.4
Applied times-frac0.4
Simplified0.4
Simplified0.3
Final simplification0.3
herbie shell --seed 2019172 +o rules:numerics
(FPCore (x)
:name "2isqrt (example 3.6)"
:herbie-target
(/ 1.0 (+ (* (+ x 1.0) (sqrt x)) (* x (sqrt (+ x 1.0)))))
(- (/ 1.0 (sqrt x)) (/ 1.0 (sqrt (+ x 1.0)))))