\left(\left(n + 1\right) \cdot \log \left(n + 1\right) - n \cdot \log n\right) - 1
\frac{\frac{1}{2}}{n} - \left(\frac{\frac{1}{6}}{n \cdot n} - \log n\right)double f(double n) {
double r9635977 = n;
double r9635978 = 1.0;
double r9635979 = r9635977 + r9635978;
double r9635980 = log(r9635979);
double r9635981 = r9635979 * r9635980;
double r9635982 = log(r9635977);
double r9635983 = r9635977 * r9635982;
double r9635984 = r9635981 - r9635983;
double r9635985 = r9635984 - r9635978;
return r9635985;
}
double f(double n) {
double r9635986 = 0.5;
double r9635987 = n;
double r9635988 = r9635986 / r9635987;
double r9635989 = 0.16666666666666666;
double r9635990 = r9635987 * r9635987;
double r9635991 = r9635989 / r9635990;
double r9635992 = log(r9635987);
double r9635993 = r9635991 - r9635992;
double r9635994 = r9635988 - r9635993;
return r9635994;
}




Bits error versus n
Results
| Original | 63.0 |
|---|---|
| Target | 0 |
| Herbie | 0 |
Initial program 63.0
Simplified44.2
Taylor expanded around inf 0.0
Simplified0
Final simplification0
herbie shell --seed 2019128 +o rules:numerics
(FPCore (n)
:name "logs (example 3.8)"
: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))