\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 r70920 = 1.0;
double r70921 = x;
double r70922 = r70920 - r70921;
double r70923 = log(r70922);
double r70924 = r70920 + r70921;
double r70925 = log(r70924);
double r70926 = r70923 / r70925;
return r70926;
}
double f(double x) {
double r70927 = 1.0;
double r70928 = log(r70927);
double r70929 = x;
double r70930 = r70927 * r70929;
double r70931 = 0.5;
double r70932 = 2.0;
double r70933 = pow(r70929, r70932);
double r70934 = pow(r70927, r70932);
double r70935 = r70933 / r70934;
double r70936 = r70931 * r70935;
double r70937 = r70930 + r70936;
double r70938 = r70928 - r70937;
double r70939 = r70930 + r70928;
double r70940 = r70939 - r70936;
double r70941 = r70938 / r70940;
return r70941;
}




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