\frac{1}{\sqrt{x}} - \frac{1}{\sqrt{x + 1}}\frac{\sqrt{\frac{1}{\sqrt{x + 1} + \sqrt{x}}}}{\sqrt{x}} \cdot \frac{\sqrt{\frac{1}{\sqrt{x + 1} + \sqrt{x}}}}{\sqrt{x + 1}}double f(double x) {
double r157532 = 1.0;
double r157533 = x;
double r157534 = sqrt(r157533);
double r157535 = r157532 / r157534;
double r157536 = r157533 + r157532;
double r157537 = sqrt(r157536);
double r157538 = r157532 / r157537;
double r157539 = r157535 - r157538;
return r157539;
}
double f(double x) {
double r157540 = 1.0;
double r157541 = x;
double r157542 = 1.0;
double r157543 = r157541 + r157542;
double r157544 = sqrt(r157543);
double r157545 = sqrt(r157541);
double r157546 = r157544 + r157545;
double r157547 = r157540 / r157546;
double r157548 = sqrt(r157547);
double r157549 = r157548 / r157545;
double r157550 = r157548 / r157544;
double r157551 = r157549 * r157550;
return r157551;
}




Bits error versus x
Results
| Original | 19.6 |
|---|---|
| Target | 0.6 |
| Herbie | 0.4 |
Initial program 19.6
rmApplied frac-sub19.6
rmApplied flip--19.4
Simplified18.9
Simplified18.9
Taylor expanded around 0 0.4
rmApplied add-sqr-sqrt0.4
Applied times-frac0.4
Simplified0.4
Simplified0.4
Final simplification0.4
herbie shell --seed 2019351 +o rules:numerics
(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)))))