\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 r152928 = 1.0;
double r152929 = x;
double r152930 = sqrt(r152929);
double r152931 = r152928 / r152930;
double r152932 = r152929 + r152928;
double r152933 = sqrt(r152932);
double r152934 = r152928 / r152933;
double r152935 = r152931 - r152934;
return r152935;
}
double f(double x) {
double r152936 = 1.0;
double r152937 = x;
double r152938 = r152937 + r152936;
double r152939 = sqrt(r152938);
double r152940 = sqrt(r152937);
double r152941 = r152939 + r152940;
double r152942 = r152936 / r152941;
double r152943 = r152936 * r152942;
double r152944 = r152943 / r152940;
double r152945 = r152944 / r152939;
return r152945;
}




Bits error versus x
Results
| Original | 20.1 |
|---|---|
| Target | 0.6 |
| Herbie | 0.4 |
Initial program 20.1
rmApplied frac-sub20.1
Simplified20.1
rmApplied flip--19.9
Simplified19.5
Taylor expanded around 0 0.4
rmApplied associate-/r*0.4
Final simplification0.4
herbie shell --seed 2019347
(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)))))