\frac{x0}{1 - x1} - x0\frac{\log \left(\sqrt{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) + \log \left(\sqrt{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(\frac{x0}{1 - x1} \cdot x0 + x0 \cdot x0\right) + \frac{x0}{1 - x1} \cdot \frac{x0}{1 - x1}}double f(double x0, double x1) {
double r3222173 = x0;
double r3222174 = 1.0;
double r3222175 = x1;
double r3222176 = r3222174 - r3222175;
double r3222177 = r3222173 / r3222176;
double r3222178 = r3222177 - r3222173;
return r3222178;
}
double f(double x0, double x1) {
double r3222179 = x0;
double r3222180 = 1.0;
double r3222181 = x1;
double r3222182 = r3222180 - r3222181;
double r3222183 = r3222179 / r3222182;
double r3222184 = r3222183 * r3222183;
double r3222185 = r3222184 * r3222179;
double r3222186 = r3222185 / r3222182;
double r3222187 = r3222179 * r3222179;
double r3222188 = r3222179 * r3222187;
double r3222189 = r3222186 - r3222188;
double r3222190 = exp(r3222189);
double r3222191 = sqrt(r3222190);
double r3222192 = log(r3222191);
double r3222193 = r3222192 + r3222192;
double r3222194 = r3222183 * r3222179;
double r3222195 = r3222194 + r3222187;
double r3222196 = r3222195 + r3222184;
double r3222197 = r3222193 / r3222196;
return r3222197;
}




Bits error versus x0




Bits error versus x1
Results
| Original | 7.9 |
|---|---|
| Target | 0.2 |
| Herbie | 5.9 |
Initial program 7.9
rmApplied flip3--7.7
Simplified7.3
rmApplied associate-*l/6.1
rmApplied add-log-exp6.0
rmApplied add-sqr-sqrt6.1
Applied log-prod5.9
Final simplification5.9
herbie shell --seed 2019155
(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))