\sqrt{x + 1} - \sqrt{x}\frac{1 + 0}{\mathsf{fma}\left(\sqrt{\sqrt{x + 1}}, \sqrt{\sqrt{x + 1}}, \sqrt{x}\right)}double f(double x) {
double r503623 = x;
double r503624 = 1.0;
double r503625 = r503623 + r503624;
double r503626 = sqrt(r503625);
double r503627 = sqrt(r503623);
double r503628 = r503626 - r503627;
return r503628;
}
double f(double x) {
double r503629 = 1.0;
double r503630 = 0.0;
double r503631 = r503629 + r503630;
double r503632 = x;
double r503633 = r503632 + r503629;
double r503634 = sqrt(r503633);
double r503635 = sqrt(r503634);
double r503636 = sqrt(r503632);
double r503637 = fma(r503635, r503635, r503636);
double r503638 = r503631 / r503637;
return r503638;
}




Bits error versus x
| Original | 29.7 |
|---|---|
| Target | 0.2 |
| Herbie | 0.2 |
Initial program 29.7
rmApplied flip--29.5
Simplified0.2
rmApplied add-sqr-sqrt0.2
Applied sqrt-prod0.3
Applied fma-def0.2
Final simplification0.2
herbie shell --seed 2020033 +o rules:numerics
(FPCore (x)
:name "Main:bigenough3 from C"
:precision binary64
:herbie-target
(/ 1 (+ (sqrt (+ x 1)) (sqrt x)))
(- (sqrt (+ x 1)) (sqrt x)))