\frac{\log \left(1 - x\right)}{\log \left(1 + x\right)}\sqrt[3]{{\left(\frac{1}{\frac{\mathsf{fma}\left(x, 1, \log 1 - \frac{1}{2} \cdot \frac{{x}^{2}}{{1}^{2}}\right)}{\log 1 - \left(1 \cdot x + \frac{1}{2} \cdot \frac{{x}^{2}}{{1}^{2}}\right)}}\right)}^{3}}double f(double x) {
double r82354 = 1.0;
double r82355 = x;
double r82356 = r82354 - r82355;
double r82357 = log(r82356);
double r82358 = r82354 + r82355;
double r82359 = log(r82358);
double r82360 = r82357 / r82359;
return r82360;
}
double f(double x) {
double r82361 = 1.0;
double r82362 = x;
double r82363 = 1.0;
double r82364 = log(r82363);
double r82365 = 0.5;
double r82366 = 2.0;
double r82367 = pow(r82362, r82366);
double r82368 = pow(r82363, r82366);
double r82369 = r82367 / r82368;
double r82370 = r82365 * r82369;
double r82371 = r82364 - r82370;
double r82372 = fma(r82362, r82363, r82371);
double r82373 = r82363 * r82362;
double r82374 = r82373 + r82370;
double r82375 = r82364 - r82374;
double r82376 = r82372 / r82375;
double r82377 = r82361 / r82376;
double r82378 = 3.0;
double r82379 = pow(r82377, r82378);
double r82380 = cbrt(r82379);
return r82380;
}




Bits error versus x
| Original | 61.3 |
|---|---|
| Target | 0.3 |
| Herbie | 0.4 |
Initial program 61.3
Taylor expanded around 0 60.4
Simplified60.4
Taylor expanded around 0 0.4
rmApplied add-cbrt-cube42.3
Applied add-cbrt-cube41.8
Applied cbrt-undiv41.8
Simplified0.4
rmApplied clear-num0.4
Final simplification0.4
herbie shell --seed 2019347 +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))))