\frac{1}{\sqrt{x}} - \frac{1}{\sqrt{x + 1}}\frac{1}{\sqrt{x}} \cdot \frac{1}{\mathsf{fma}\left(\sqrt{x + 1}, \sqrt{x}, x + 1\right)}double f(double x) {
double r178448 = 1.0;
double r178449 = x;
double r178450 = sqrt(r178449);
double r178451 = r178448 / r178450;
double r178452 = r178449 + r178448;
double r178453 = sqrt(r178452);
double r178454 = r178448 / r178453;
double r178455 = r178451 - r178454;
return r178455;
}
double f(double x) {
double r178456 = 1.0;
double r178457 = x;
double r178458 = sqrt(r178457);
double r178459 = r178456 / r178458;
double r178460 = r178457 + r178456;
double r178461 = sqrt(r178460);
double r178462 = fma(r178461, r178458, r178460);
double r178463 = r178456 / r178462;
double r178464 = r178459 * r178463;
return r178464;
}




Bits error versus x
| Original | 19.5 |
|---|---|
| Target | 0.7 |
| Herbie | 0.3 |
Initial program 19.5
rmApplied frac-sub19.5
Simplified19.5
rmApplied flip--19.3
Simplified18.9
Taylor expanded around 0 0.4
rmApplied times-frac0.4
Simplified0.3
Final simplification0.3
herbie shell --seed 2020089 +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)))))