\frac{\log \left(1 - x\right)}{\log \left(1 + x\right)}\log \left(e^{\frac{\log 1 - \mathsf{fma}\left(1, x, \frac{1}{2} \cdot \frac{{x}^{2}}{{1}^{2}}\right)}{\mathsf{fma}\left(\frac{-1}{2}, \frac{{x}^{2}}{{1}^{2}}, \mathsf{fma}\left(1, x, \log 1\right)\right)}}\right)double f(double x) {
double r56635 = 1.0;
double r56636 = x;
double r56637 = r56635 - r56636;
double r56638 = log(r56637);
double r56639 = r56635 + r56636;
double r56640 = log(r56639);
double r56641 = r56638 / r56640;
return r56641;
}
double f(double x) {
double r56642 = 1.0;
double r56643 = log(r56642);
double r56644 = x;
double r56645 = 0.5;
double r56646 = 2.0;
double r56647 = pow(r56644, r56646);
double r56648 = pow(r56642, r56646);
double r56649 = r56647 / r56648;
double r56650 = r56645 * r56649;
double r56651 = fma(r56642, r56644, r56650);
double r56652 = r56643 - r56651;
double r56653 = -0.5;
double r56654 = fma(r56642, r56644, r56643);
double r56655 = fma(r56653, r56649, r56654);
double r56656 = r56652 / r56655;
double r56657 = exp(r56656);
double r56658 = log(r56657);
return r56658;
}




Bits error versus x
| Original | 61.3 |
|---|---|
| Target | 0.4 |
| Herbie | 0.5 |
Initial program 61.3
Taylor expanded around 0 60.4
Simplified60.4
Taylor expanded around 0 0.5
Simplified0.5
rmApplied add-log-exp0.5
Final simplification0.5
herbie shell --seed 2019326 +o rules:numerics
(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))))