\sqrt{x + 1} - \sqrt{x}\frac{1}{\sqrt{\sqrt{x + 1}} \cdot \sqrt{\sqrt{x + 1}} + \sqrt{x}}double f(double x) {
double r141384 = x;
double r141385 = 1.0;
double r141386 = r141384 + r141385;
double r141387 = sqrt(r141386);
double r141388 = sqrt(r141384);
double r141389 = r141387 - r141388;
return r141389;
}
double f(double x) {
double r141390 = 1.0;
double r141391 = x;
double r141392 = r141391 + r141390;
double r141393 = sqrt(r141392);
double r141394 = sqrt(r141393);
double r141395 = r141394 * r141394;
double r141396 = sqrt(r141391);
double r141397 = r141395 + r141396;
double r141398 = r141390 / r141397;
return r141398;
}




Bits error versus x
Results
| Original | 29.9 |
|---|---|
| Target | 0.2 |
| Herbie | 0.3 |
Initial program 29.9
rmApplied flip--29.8
Simplified0.2
rmApplied add-sqr-sqrt0.2
Applied sqrt-prod0.3
Final simplification0.3
herbie shell --seed 2020042
(FPCore (x)
:name "2sqrt (example 3.1)"
:precision binary64
:herbie-target
(/ 1 (+ (sqrt (+ x 1)) (sqrt x)))
(- (sqrt (+ x 1)) (sqrt x)))