\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 r6817580 = 1.0;
double r6817581 = x;
double r6817582 = sqrt(r6817581);
double r6817583 = r6817580 / r6817582;
double r6817584 = r6817581 + r6817580;
double r6817585 = sqrt(r6817584);
double r6817586 = r6817580 / r6817585;
double r6817587 = r6817583 - r6817586;
return r6817587;
}
double f(double x) {
double r6817588 = 1.0;
double r6817589 = cbrt(r6817588);
double r6817590 = r6817589 * r6817589;
double r6817591 = x;
double r6817592 = sqrt(r6817591);
double r6817593 = r6817590 / r6817592;
double r6817594 = r6817591 + r6817588;
double r6817595 = sqrt(r6817594);
double r6817596 = r6817592 * r6817588;
double r6817597 = r6817588 * r6817594;
double r6817598 = fma(r6817595, r6817596, r6817597);
double r6817599 = r6817589 / r6817598;
double r6817600 = r6817593 * r6817599;
return r6817600;
}




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)))))