针对泰勒展开式:ln(1+x)=x-x^2/2+x^3/3-……+(-1)^(k-1)*(x^k)/k(|x|
转换成:ln(1+x)=x(1-x(1/2-x(1/3-x(1/4-x(1/5..........)))))
这样转换并没有提高效率,但可以预算1/2 1/3 1/4 1/5.....针对一万精度,因为经过了开方优化,这里只需要10000\70=133次泰勒级数运算,所以可以预制133个万位长数的表格供调用,
粗略估计可以获得一秒的速度提升。
还可转换成:ln(1+x)=(x(N!-x(N!/2-x(N!/3-x(N!/4-x(N!/5..........))))) )/N! N是你需要运算的泰勒级数
这个转换不仅不能提高效率,在我的程序万位运算中,速度还有所下降。
但它还是有用的:
现在计算十万精度的ln(9),1-100000的倒数绝大多数都是非整数,我的意思就是除不断,为了获得十万精度,这些倒数你需要计算或预制十万位,100000\70=1428,这里需要1428次泰勒级数运算&#