\frac{x0}{1 - x1} - x0\frac{\frac{\left(\frac{x0}{1 - x1} \cdot \frac{x0}{1 - x1}\right) \cdot x0}{1 - x1} - x0 \cdot \left(x0 \cdot x0\right)}{\frac{x0}{1 - x1} \cdot \frac{x0}{1 - x1} + \left(\sqrt[3]{\frac{x0}{1 - x1} \cdot \left(\frac{x0}{1 - x1} \cdot \frac{x0}{1 - x1}\right)} \cdot x0 + x0 \cdot x0\right)}double f(double x0, double x1) {
double r8065816 = x0;
double r8065817 = 1.0;
double r8065818 = x1;
double r8065819 = r8065817 - r8065818;
double r8065820 = r8065816 / r8065819;
double r8065821 = r8065820 - r8065816;
return r8065821;
}
double f(double x0, double x1) {
double r8065822 = x0;
double r8065823 = 1.0;
double r8065824 = x1;
double r8065825 = r8065823 - r8065824;
double r8065826 = r8065822 / r8065825;
double r8065827 = r8065826 * r8065826;
double r8065828 = r8065827 * r8065822;
double r8065829 = r8065828 / r8065825;
double r8065830 = r8065822 * r8065822;
double r8065831 = r8065822 * r8065830;
double r8065832 = r8065829 - r8065831;
double r8065833 = r8065826 * r8065827;
double r8065834 = cbrt(r8065833);
double r8065835 = r8065834 * r8065822;
double r8065836 = r8065835 + r8065830;
double r8065837 = r8065827 + r8065836;
double r8065838 = r8065832 / r8065837;
return r8065838;
}




Bits error versus x0




Bits error versus x1
Results
| Original | 7.8 |
|---|---|
| Target | 0.2 |
| Herbie | 6.1 |
Initial program 7.8
rmApplied flip3--7.6
Simplified7.2
rmApplied associate-*r/6.1
rmApplied add-cbrt-cube6.1
Applied add-cbrt-cube6.1
Applied cbrt-undiv6.1
Simplified6.1
Final simplification6.1
herbie shell --seed 2019168
(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.0 x1))
(- (/ x0 (- 1.0 x1)) x0))