\left(\left(n + 1\right) \cdot \log \left(n + 1\right) - n \cdot \log n\right) - 1
\frac{0.5}{n} - \mathsf{fma}\left(1, -\log n, \frac{0.16666666666666669}{n \cdot n}\right)double f(double n) {
double r73266 = n;
double r73267 = 1.0;
double r73268 = r73266 + r73267;
double r73269 = log(r73268);
double r73270 = r73268 * r73269;
double r73271 = log(r73266);
double r73272 = r73266 * r73271;
double r73273 = r73270 - r73272;
double r73274 = r73273 - r73267;
return r73274;
}
double f(double n) {
double r73275 = 0.5;
double r73276 = n;
double r73277 = r73275 / r73276;
double r73278 = 1.0;
double r73279 = log(r73276);
double r73280 = -r73279;
double r73281 = 0.16666666666666669;
double r73282 = r73276 * r73276;
double r73283 = r73281 / r73282;
double r73284 = fma(r73278, r73280, r73283);
double r73285 = r73277 - r73284;
return r73285;
}




Bits error versus n
| Original | 63.0 |
|---|---|
| Target | 0 |
| Herbie | 0 |
Initial program 63.0
Simplified62.0
Taylor expanded around inf 0.0
Simplified0
Final simplification0
herbie shell --seed 2020043 +o rules:numerics
(FPCore (n)
:name "logs (example 3.8)"
:precision binary64
:pre (> n 6.8e+15)
:herbie-target
(- (log (+ n 1)) (- (/ 1 (* 2 n)) (- (/ 1 (* 3 (* n n))) (/ 4 (pow n 3)))))
(- (- (* (+ n 1) (log (+ n 1))) (* n (log n))) 1))