\frac{1}{\sqrt{x}} - \frac{1}{\sqrt{x + 1}}\frac{\frac{1 \cdot \frac{1}{\sqrt{x + 1} + \sqrt{x}}}{\sqrt{x}}}{\sqrt{x + 1}}double f(double x) {
double r124868 = 1.0;
double r124869 = x;
double r124870 = sqrt(r124869);
double r124871 = r124868 / r124870;
double r124872 = r124869 + r124868;
double r124873 = sqrt(r124872);
double r124874 = r124868 / r124873;
double r124875 = r124871 - r124874;
return r124875;
}
double f(double x) {
double r124876 = 1.0;
double r124877 = x;
double r124878 = r124877 + r124876;
double r124879 = sqrt(r124878);
double r124880 = sqrt(r124877);
double r124881 = r124879 + r124880;
double r124882 = r124876 / r124881;
double r124883 = r124876 * r124882;
double r124884 = r124883 / r124880;
double r124885 = r124884 / r124879;
return r124885;
}




Bits error versus x
Results
| Original | 20.1 |
|---|---|
| Target | 0.7 |
| Herbie | 0.4 |
Initial program 20.1
rmApplied frac-sub20.1
Simplified20.1
rmApplied flip--19.8
Simplified19.5
Taylor expanded around 0 0.4
rmApplied associate-/r*0.4
Final simplification0.4
herbie shell --seed 2019209
(FPCore (x)
:name "2isqrt (example 3.6)"
:precision binary64
:herbie-target
(/ 1 (+ (* (+ x 1) (sqrt x)) (* x (sqrt (+ x 1)))))
(- (/ 1 (sqrt x)) (/ 1 (sqrt (+ x 1)))))