\sqrt{x + 1} - \sqrt{x}\frac{1}{\sqrt{x + 1} + \sqrt{x}}double f(double x) {
double r6040491 = x;
double r6040492 = 1.0;
double r6040493 = r6040491 + r6040492;
double r6040494 = sqrt(r6040493);
double r6040495 = sqrt(r6040491);
double r6040496 = r6040494 - r6040495;
return r6040496;
}
double f(double x) {
double r6040497 = 1.0;
double r6040498 = x;
double r6040499 = r6040498 + r6040497;
double r6040500 = sqrt(r6040499);
double r6040501 = sqrt(r6040498);
double r6040502 = r6040500 + r6040501;
double r6040503 = r6040497 / r6040502;
return r6040503;
}




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 "2sqrt (example 3.1)"
:herbie-target
(/ 1.0 (+ (sqrt (+ x 1.0)) (sqrt x)))
(- (sqrt (+ x 1.0)) (sqrt x)))