\frac{1}{\sqrt{x}} - \frac{1}{\sqrt{x + 1}}\frac{1 \cdot \frac{1}{\sqrt{x + 1} + \sqrt{x}}}{\left(\sqrt{x} \cdot \left|\sqrt[3]{x + 1}\right|\right) \cdot \sqrt{\sqrt[3]{x + 1}}}double f(double x) {
double r131056 = 1.0;
double r131057 = x;
double r131058 = sqrt(r131057);
double r131059 = r131056 / r131058;
double r131060 = r131057 + r131056;
double r131061 = sqrt(r131060);
double r131062 = r131056 / r131061;
double r131063 = r131059 - r131062;
return r131063;
}
double f(double x) {
double r131064 = 1.0;
double r131065 = x;
double r131066 = r131065 + r131064;
double r131067 = sqrt(r131066);
double r131068 = sqrt(r131065);
double r131069 = r131067 + r131068;
double r131070 = r131064 / r131069;
double r131071 = r131064 * r131070;
double r131072 = cbrt(r131066);
double r131073 = fabs(r131072);
double r131074 = r131068 * r131073;
double r131075 = sqrt(r131072);
double r131076 = r131074 * r131075;
double r131077 = r131071 / r131076;
return r131077;
}




Bits error versus x
Results
| Original | 20.0 |
|---|---|
| Target | 0.7 |
| Herbie | 0.5 |
Initial program 20.0
rmApplied frac-sub20.0
Simplified20.0
rmApplied flip--19.8
Simplified19.4
Taylor expanded around 0 0.4
rmApplied add-cube-cbrt0.5
Applied sqrt-prod0.5
Applied associate-*r*0.5
Simplified0.5
Final simplification0.5
herbie shell --seed 2020042
(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)))))