\frac{x}{x} - \frac{1}{x} \cdot \sqrt{x \cdot x}\sqrt[3]{{\left(\left(-\frac{1}{x}\right) \cdot \left|x\right|\right)}^{3}} + 1double f(double x) {
double r132417 = x;
double r132418 = r132417 / r132417;
double r132419 = 1.0;
double r132420 = r132419 / r132417;
double r132421 = r132417 * r132417;
double r132422 = sqrt(r132421);
double r132423 = r132420 * r132422;
double r132424 = r132418 - r132423;
return r132424;
}
double f(double x) {
double r132425 = 1.0;
double r132426 = x;
double r132427 = r132425 / r132426;
double r132428 = -r132427;
double r132429 = fabs(r132426);
double r132430 = r132428 * r132429;
double r132431 = 3.0;
double r132432 = pow(r132430, r132431);
double r132433 = cbrt(r132432);
double r132434 = 1.0;
double r132435 = r132433 + r132434;
return r132435;
}




Bits error versus x
Results
| Original | 32.4 |
|---|---|
| Target | 0 |
| Herbie | 0.0 |
Initial program 32.4
Simplified30.4
rmApplied fma-udef4.9
rmApplied add-cbrt-cube45.7
Applied add-cbrt-cube49.6
Applied cbrt-unprod44.1
Simplified0.0
Final simplification0.0
herbie shell --seed 2020001 +o rules:numerics
(FPCore (x)
:name "sqrt sqr"
:precision binary64
:herbie-target
(if (< x 0.0) 2 0.0)
(- (/ x x) (* (/ 1 x) (sqrt (* x x)))))