\frac{\log \left(1 - x\right)}{\log \left(1 + x\right)}\frac{\log 1 - \left(1 \cdot x + \frac{1}{2} \cdot \frac{{x}^{2}}{{1}^{2}}\right)}{\left(1 \cdot x + \log 1\right) - \frac{1}{2} \cdot \frac{{x}^{2}}{{1}^{2}}}double f(double x) {
double r67617 = 1.0;
double r67618 = x;
double r67619 = r67617 - r67618;
double r67620 = log(r67619);
double r67621 = r67617 + r67618;
double r67622 = log(r67621);
double r67623 = r67620 / r67622;
return r67623;
}
double f(double x) {
double r67624 = 1.0;
double r67625 = log(r67624);
double r67626 = x;
double r67627 = r67624 * r67626;
double r67628 = 0.5;
double r67629 = 2.0;
double r67630 = pow(r67626, r67629);
double r67631 = pow(r67624, r67629);
double r67632 = r67630 / r67631;
double r67633 = r67628 * r67632;
double r67634 = r67627 + r67633;
double r67635 = r67625 - r67634;
double r67636 = r67627 + r67625;
double r67637 = r67636 - r67633;
double r67638 = r67635 / r67637;
return r67638;
}




Bits error versus x
Results
| Original | 61.5 |
|---|---|
| Target | 0.3 |
| Herbie | 0.4 |
Initial program 61.5
Taylor expanded around 0 60.5
Taylor expanded around 0 0.4
Final simplification0.4
herbie shell --seed 2020046
(FPCore (x)
:name "qlog (example 3.10)"
:precision binary64
:pre (and (< -1 x) (< x 1))
:herbie-target
(- (+ (+ (+ 1 x) (/ (* x x) 2)) (* 0.4166666666666667 (pow x 3))))
(/ (log (- 1 x)) (log (+ 1 x))))