\frac{1}{\sqrt{x}} - \frac{1}{\sqrt{x + 1}}\frac{\sqrt{\frac{1}{\sqrt{x + 1} + \sqrt{x}}}}{\frac{\sqrt{x + 1} \cdot \sqrt{x}}{\sqrt{\sqrt[3]{\frac{\frac{1}{\left(\sqrt{x + 1} + \sqrt{x}\right) \cdot \left(\sqrt{x + 1} + \sqrt{x}\right)}}{\sqrt{x + 1} + \sqrt{x}}}}}}double f(double x) {
double r6542244 = 1.0;
double r6542245 = x;
double r6542246 = sqrt(r6542245);
double r6542247 = r6542244 / r6542246;
double r6542248 = r6542245 + r6542244;
double r6542249 = sqrt(r6542248);
double r6542250 = r6542244 / r6542249;
double r6542251 = r6542247 - r6542250;
return r6542251;
}
double f(double x) {
double r6542252 = 1.0;
double r6542253 = x;
double r6542254 = r6542253 + r6542252;
double r6542255 = sqrt(r6542254);
double r6542256 = sqrt(r6542253);
double r6542257 = r6542255 + r6542256;
double r6542258 = r6542252 / r6542257;
double r6542259 = sqrt(r6542258);
double r6542260 = r6542255 * r6542256;
double r6542261 = r6542257 * r6542257;
double r6542262 = r6542252 / r6542261;
double r6542263 = r6542262 / r6542257;
double r6542264 = cbrt(r6542263);
double r6542265 = sqrt(r6542264);
double r6542266 = r6542260 / r6542265;
double r6542267 = r6542259 / r6542266;
return r6542267;
}




Bits error versus x
Results
| Original | 19.8 |
|---|---|
| Target | 0.7 |
| Herbie | 0.4 |
Initial program 19.8
rmApplied frac-sub19.8
Simplified19.8
rmApplied flip--19.6
Simplified0.4
rmApplied add-sqr-sqrt0.4
Applied associate-/l*0.4
rmApplied add-cbrt-cube0.9
Applied add-cbrt-cube0.9
Applied cbrt-undiv0.9
Simplified0.4
Final simplification0.4
herbie shell --seed 2019149
(FPCore (x)
:name "2isqrt (example 3.6)"
:herbie-target
(/ 1 (+ (* (+ x 1) (sqrt x)) (* x (sqrt (+ x 1)))))
(- (/ 1 (sqrt x)) (/ 1 (sqrt (+ x 1)))))