\sqrt{1 + x \cdot x} - \sqrt{1 + x} \cdot x\sqrt{1 + x \cdot x} - \sqrt{1 + x} \cdot xdouble code(double x) {
return ((double) (((double) sqrt(((double) (1.0 + ((double) (x * x)))))) - ((double) (((double) sqrt(((double) (1.0 + x)))) * x))));
}
double code(double x) {
return ((double) (((double) sqrt(((double) (1.0 + ((double) (x * x)))))) - ((double) (((double) sqrt(((double) (1.0 + x)))) * x))));
}



Bits error versus x
Results
Initial program 4.2
Final simplification4.2
herbie shell --seed 2020152
(FPCore (x)
:name "(- (sqrt (+ 1 (* x x))) (* (sqrt (+ 1 x)) x))"
:precision binary64
(- (sqrt (+ 1.0 (* x x))) (* (sqrt (+ 1.0 x)) x)))