\sqrt{x + 1} - \sqrt{x}\sqrt{\frac{1 \cdot 1}{\left(\sqrt{x} + \sqrt{x + 1}\right) \cdot \left(\sqrt{x} + \sqrt{x + 1}\right)}}double f(double x) {
double r421918 = x;
double r421919 = 1.0;
double r421920 = r421918 + r421919;
double r421921 = sqrt(r421920);
double r421922 = sqrt(r421918);
double r421923 = r421921 - r421922;
return r421923;
}
double f(double x) {
double r421924 = 1.0;
double r421925 = r421924 * r421924;
double r421926 = x;
double r421927 = sqrt(r421926);
double r421928 = r421926 + r421924;
double r421929 = sqrt(r421928);
double r421930 = r421927 + r421929;
double r421931 = r421930 * r421930;
double r421932 = r421925 / r421931;
double r421933 = sqrt(r421932);
return r421933;
}




Bits error versus x
Results
| Original | 29.5 |
|---|---|
| Target | 0.2 |
| Herbie | 0.3 |
Initial program 29.5
rmApplied flip--29.4
Simplified0.2
Simplified0.2
rmApplied add-sqr-sqrt0.3
Simplified0.3
Simplified0.3
rmApplied sqrt-unprod0.2
Simplified0.3
Final simplification0.3
herbie shell --seed 2020046 +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)))