\frac{x0}{1 - x1} - x0\frac{\frac{\frac{{\left({\left(\frac{x0}{1 - x1} \cdot \left(x0 \cdot \frac{1}{1 - x1}\right)\right)}^{3}\right)}^{3} - {\left({\left(x0 \cdot x0\right)}^{3}\right)}^{3}}{\left({\left(\frac{x0}{1 - x1} \cdot \left(x0 \cdot \frac{1}{1 - x1}\right)\right)}^{6} + {\left(\frac{x0}{1 - x1} \cdot \left(x0 \cdot \frac{1}{1 - x1}\right)\right)}^{3} \cdot {\left(x0 \cdot x0\right)}^{3}\right) + {x0}^{12}}}{\frac{x0}{1 - x1} \cdot \left({\left(\frac{x0}{1 - x1}\right)}^{3} + \frac{{x0}^{3}}{1 - x1}\right) + {x0}^{4}}}{\frac{x0}{1 - x1} + x0}double code(double x0, double x1) {
return ((x0 / (1.0 - x1)) - x0);
}
double code(double x0, double x1) {
return ((((pow(pow(((x0 / (1.0 - x1)) * (x0 * (1.0 / (1.0 - x1)))), 3.0), 3.0) - pow(pow((x0 * x0), 3.0), 3.0)) / ((pow(((x0 / (1.0 - x1)) * (x0 * (1.0 / (1.0 - x1)))), 6.0) + (pow(((x0 / (1.0 - x1)) * (x0 * (1.0 / (1.0 - x1)))), 3.0) * pow((x0 * x0), 3.0))) + pow(x0, 12.0))) / (((x0 / (1.0 - x1)) * (pow((x0 / (1.0 - x1)), 3.0) + (pow(x0, 3.0) / (1.0 - x1)))) + pow(x0, 4.0))) / ((x0 / (1.0 - x1)) + x0));
}




Bits error versus x0




Bits error versus x1
Results
| Original | 8.4 |
|---|---|
| Target | 0.5 |
| Herbie | 5.7 |
Initial program 8.4
rmApplied flip--7.8
rmApplied div-inv6.6
rmApplied flip3--6.0
Simplified6.0
rmApplied flip3--5.6
Simplified5.7
Final simplification5.7
herbie shell --seed 2020102
(FPCore (x0 x1)
:name "(- (/ x0 (- 1 x1)) x0)"
:precision binary64
: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))