\sqrt{x + 1} - \sqrt{x}\frac{1}{\sqrt{x + 1} + \sqrt{x}}double f(double x) {
double r27942498 = x;
double r27942499 = 1.0;
double r27942500 = r27942498 + r27942499;
double r27942501 = sqrt(r27942500);
double r27942502 = sqrt(r27942498);
double r27942503 = r27942501 - r27942502;
return r27942503;
}
double f(double x) {
double r27942504 = 1.0;
double r27942505 = x;
double r27942506 = r27942505 + r27942504;
double r27942507 = sqrt(r27942506);
double r27942508 = sqrt(r27942505);
double r27942509 = r27942507 + r27942508;
double r27942510 = r27942504 / r27942509;
return r27942510;
}




Bits error versus x
Results
| Original | 30.1 |
|---|---|
| Target | 0.2 |
| Herbie | 0.2 |
Initial program 30.1
rmApplied flip--29.8
Simplified0.2
rmApplied *-un-lft-identity0.2
Applied associate-/r*0.2
Simplified0.2
Final simplification0.2
herbie shell --seed 2019174 +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)))