\sqrt{x + 1} - \sqrt{x}\frac{1}{\sqrt{x} + \left|\sqrt{x + 1}\right|}double f(double x) {
double r528830 = x;
double r528831 = 1.0;
double r528832 = r528830 + r528831;
double r528833 = sqrt(r528832);
double r528834 = sqrt(r528830);
double r528835 = r528833 - r528834;
return r528835;
}
double f(double x) {
double r528836 = 1.0;
double r528837 = x;
double r528838 = sqrt(r528837);
double r528839 = r528837 + r528836;
double r528840 = sqrt(r528839);
double r528841 = fabs(r528840);
double r528842 = r528838 + r528841;
double r528843 = r528836 / r528842;
return r528843;
}




Bits error versus x
Results
| Original | 30.1 |
|---|---|
| Target | 0.2 |
| Herbie | 0.2 |
Initial program 30.1
rmApplied flip--29.8
Simplified0.2
Simplified0.2
rmApplied add-sqr-sqrt0.2
Applied rem-sqrt-square0.2
Final simplification0.2
herbie shell --seed 2020043 +o rules:numerics
(FPCore (x)
:name "Main:bigenough3 from C"
:precision binary64
:herbie-target
(/ 1 (+ (sqrt (+ x 1)) (sqrt x)))
(- (sqrt (+ x 1)) (sqrt x)))