double code(double x) {
return ((double) (((double) (x / x)) - ((double) (((double) (1.0 / x)) * ((double) sqrt(((double) (x * x))))))));
}
double code(double x) {
return ((double) (1.0 - ((double) (1.0 * ((double) (((double) fabs(x)) / x))))));
}




Bits error versus x
Results
| Original | 32.3 |
|---|---|
| Target | 0 |
| Herbie | 0 |
Initial program 32.3
Simplified0
Final simplification0
herbie shell --seed 2020191
(FPCore (x)
:name "sqrt sqr"
:precision binary64
:herbie-target
(if (< x 0.0) 2.0 0.0)
(- (/ x x) (* (/ 1.0 x) (sqrt (* x x)))))