\sqrt{x + 1} - \sqrt{x}\frac{1 + 0}{\sqrt{x + 1} + \sqrt{x}}double f(double x) {
double r167029 = x;
double r167030 = 1.0;
double r167031 = r167029 + r167030;
double r167032 = sqrt(r167031);
double r167033 = sqrt(r167029);
double r167034 = r167032 - r167033;
return r167034;
}
double f(double x) {
double r167035 = 1.0;
double r167036 = 0.0;
double r167037 = r167035 + r167036;
double r167038 = x;
double r167039 = r167038 + r167035;
double r167040 = sqrt(r167039);
double r167041 = sqrt(r167038);
double r167042 = r167040 + r167041;
double r167043 = r167037 / r167042;
return r167043;
}




Bits error versus x
Results
| Original | 30.1 |
|---|---|
| Target | 0.2 |
| Herbie | 0.2 |
Initial program 30.1
rmApplied flip--29.9
Simplified0.2
Final simplification0.2
herbie shell --seed 2020021 +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)))