\sqrt{x + 1} - \sqrt{x}\frac{1}{\sqrt{x + 1} + \sqrt{x}}double f(double x) {
double r25365250 = x;
double r25365251 = 1.0;
double r25365252 = r25365250 + r25365251;
double r25365253 = sqrt(r25365252);
double r25365254 = sqrt(r25365250);
double r25365255 = r25365253 - r25365254;
return r25365255;
}
double f(double x) {
double r25365256 = 1.0;
double r25365257 = x;
double r25365258 = r25365257 + r25365256;
double r25365259 = sqrt(r25365258);
double r25365260 = sqrt(r25365257);
double r25365261 = r25365259 + r25365260;
double r25365262 = r25365256 / r25365261;
return r25365262;
}




Bits error versus x
Results
| Original | 30.3 |
|---|---|
| Target | 0.2 |
| Herbie | 0.2 |
Initial program 30.3
rmApplied flip--30.0
Simplified29.6
Simplified29.6
Taylor expanded around 0 0.2
Final simplification0.2
herbie shell --seed 2019170 +o rules:numerics
(FPCore (x)
:name "Main:bigenough3 from C"
:herbie-target
(/ 1.0 (+ (sqrt (+ x 1.0)) (sqrt x)))
(- (sqrt (+ x 1.0)) (sqrt x)))