\sqrt{x + 1} - \sqrt{x}\frac{1}{\sqrt{x + 1} + \sqrt{x}}double f(double x) {
double r2122696 = x;
double r2122697 = 1.0;
double r2122698 = r2122696 + r2122697;
double r2122699 = sqrt(r2122698);
double r2122700 = sqrt(r2122696);
double r2122701 = r2122699 - r2122700;
return r2122701;
}
double f(double x) {
double r2122702 = 1.0;
double r2122703 = x;
double r2122704 = r2122703 + r2122702;
double r2122705 = sqrt(r2122704);
double r2122706 = sqrt(r2122703);
double r2122707 = r2122705 + r2122706;
double r2122708 = r2122702 / r2122707;
return r2122708;
}




Bits error versus x
Results
| Original | 29.4 |
|---|---|
| Target | 0.2 |
| Herbie | 0.2 |
Initial program 29.4
rmApplied flip--29.2
Simplified28.8
Taylor expanded around 0 0.2
Final simplification0.2
herbie shell --seed 2019153
(FPCore (x)
:name "2sqrt (example 3.1)"
:herbie-target
(/ 1 (+ (sqrt (+ x 1)) (sqrt x)))
(- (sqrt (+ x 1)) (sqrt x)))