\frac{x0}{1 - x1} - x0\frac{\log \left(e^{\frac{\left(\frac{x0}{1 - x1} \cdot \frac{x0}{1 - x1}\right) \cdot x0}{1 - x1} - x0 \cdot \left(x0 \cdot x0\right)}\right)}{\left(x0 \cdot \sqrt[3]{\frac{x0}{1 - x1} \cdot \left(\frac{x0}{1 - x1} \cdot \frac{x0}{1 - x1}\right)} + x0 \cdot x0\right) + \frac{x0}{1 - x1} \cdot \frac{x0}{1 - x1}}double f(double x0, double x1) {
double r2913295 = x0;
double r2913296 = 1.0;
double r2913297 = x1;
double r2913298 = r2913296 - r2913297;
double r2913299 = r2913295 / r2913298;
double r2913300 = r2913299 - r2913295;
return r2913300;
}
double f(double x0, double x1) {
double r2913301 = x0;
double r2913302 = 1.0;
double r2913303 = x1;
double r2913304 = r2913302 - r2913303;
double r2913305 = r2913301 / r2913304;
double r2913306 = r2913305 * r2913305;
double r2913307 = r2913306 * r2913301;
double r2913308 = r2913307 / r2913304;
double r2913309 = r2913301 * r2913301;
double r2913310 = r2913301 * r2913309;
double r2913311 = r2913308 - r2913310;
double r2913312 = exp(r2913311);
double r2913313 = log(r2913312);
double r2913314 = r2913305 * r2913306;
double r2913315 = cbrt(r2913314);
double r2913316 = r2913301 * r2913315;
double r2913317 = r2913316 + r2913309;
double r2913318 = r2913317 + r2913306;
double r2913319 = r2913313 / r2913318;
return r2913319;
}




Bits error versus x0




Bits error versus x1
Results
| Original | 7.9 |
|---|---|
| Target | 0.3 |
| Herbie | 6.0 |
Initial program 7.9
rmApplied flip3--7.7
Simplified7.3
rmApplied associate-*l/6.1
rmApplied add-cbrt-cube6.1
Applied add-cbrt-cube6.1
Applied cbrt-undiv6.1
Simplified6.1
rmApplied add-log-exp6.0
Final simplification6.0
herbie shell --seed 2019156
(FPCore (x0 x1)
:name "(- (/ x0 (- 1 x1)) x0)"
:pre (or (and (== x0 1.855) (== x1 0.000209)) (and (== x0 2.985) (== x1 0.0186)))
:herbie-target
(/ (* x0 x1) (- 1 x1))
(- (/ x0 (- 1 x1)) x0))