\left(\left(n + 1\right) \cdot \log \left(n + 1\right) - n \cdot \log n\right) - 1
\left(1 \cdot \log n + \left(\left(1 + \frac{0.5}{n}\right) - \frac{0.1666666666666666851703837437526090070605}{n \cdot n}\right)\right) - 1double f(double n) {
double r2281719 = n;
double r2281720 = 1.0;
double r2281721 = r2281719 + r2281720;
double r2281722 = log(r2281721);
double r2281723 = r2281721 * r2281722;
double r2281724 = log(r2281719);
double r2281725 = r2281719 * r2281724;
double r2281726 = r2281723 - r2281725;
double r2281727 = r2281726 - r2281720;
return r2281727;
}
double f(double n) {
double r2281728 = 1.0;
double r2281729 = n;
double r2281730 = log(r2281729);
double r2281731 = r2281728 * r2281730;
double r2281732 = 0.5;
double r2281733 = r2281732 / r2281729;
double r2281734 = r2281728 + r2281733;
double r2281735 = 0.16666666666666669;
double r2281736 = r2281729 * r2281729;
double r2281737 = r2281735 / r2281736;
double r2281738 = r2281734 - r2281737;
double r2281739 = r2281731 + r2281738;
double r2281740 = r2281739 - r2281728;
return r2281740;
}




Bits error versus n
Results
| Original | 63.0 |
|---|---|
| Target | 0 |
| Herbie | 0.0 |
Initial program 63.0
Taylor expanded around inf 0.0
Simplified0.0
Final simplification0.0
herbie shell --seed 2019174
(FPCore (n)
:name "logs (example 3.8)"
:pre (> n 6.8e+15)
:herbie-target
(- (log (+ n 1.0)) (- (/ 1.0 (* 2.0 n)) (- (/ 1.0 (* 3.0 (* n n))) (/ 4.0 (pow n 3.0)))))
(- (- (* (+ n 1.0) (log (+ n 1.0))) (* n (log n))) 1.0))