\sqrt{x + 1} - \sqrt{x}-\frac{1}{-\left(\sqrt{x + 1} + \sqrt{x}\right)}double f(double x) {
double r127242 = x;
double r127243 = 1.0;
double r127244 = r127242 + r127243;
double r127245 = sqrt(r127244);
double r127246 = sqrt(r127242);
double r127247 = r127245 - r127246;
return r127247;
}
double f(double x) {
double r127248 = 1.0;
double r127249 = x;
double r127250 = r127249 + r127248;
double r127251 = sqrt(r127250);
double r127252 = sqrt(r127249);
double r127253 = r127251 + r127252;
double r127254 = -r127253;
double r127255 = r127248 / r127254;
double r127256 = -r127255;
return r127256;
}




Bits error versus x
Results
| Original | 29.6 |
|---|---|
| Target | 0.2 |
| Herbie | 0.2 |
Initial program 29.6
rmApplied flip--29.4
Simplified0.2
rmApplied add-sqr-sqrt0.2
Applied sqrt-prod0.3
Applied fma-def0.2
rmApplied add-sqr-sqrt0.2
Applied sqrt-prod0.2
Applied sqrt-prod0.3
rmApplied frac-2neg0.3
Simplified0.3
Simplified0.2
Final simplification0.2
herbie shell --seed 2020059 +o rules:numerics
(FPCore (x)
:name "2sqrt (example 3.1)"
:precision binary64
:herbie-target
(/ 1 (+ (sqrt (+ x 1)) (sqrt x)))
(- (sqrt (+ x 1)) (sqrt x)))