在Python中计算e(自然对数的基数)到高精度?

skr*_*oth 13 python math floating-point numpy scipy

是否可以使用Python以高精度(2000+小数位)计算数学常数e的值?

我对与NumPySciPy集成的解决方案特别感兴趣.

Mer*_*moz 21

您可以使用十进制 内置模块设置所需的精度:

from decimal import *
getcontext().prec = 40
Decimal(1).exp()
Run Code Online (Sandbox Code Playgroud)

返回:

Decimal('2.718281828459045235360287471352662497757')
Run Code Online (Sandbox Code Playgroud)

  • +1; 对于任何怀疑这是否适用于任意精度的人,请检查我的答案。 (2认同)

Gar*_*err 8

这也可以通过使用数值评估的同情来完成:

import sympy

print sympy.N(sympy.E, 100)
Run Code Online (Sandbox Code Playgroud)

  • 或者使用原创的http://code.google.com/p/mpmath/.非常好的Python库,用于具有大量功能的任意精度浮点算法,而Frederic的博客很有趣 (4认同)

Nic*_*k T 7

使用一系列总和,您可以计算它:

getcontext().prec = 2000
e = Decimal(0)
i = 0
while True:
    fact = math.factorial(i)
    e += Decimal(1)/fact
    i += 1
    if fact > 10**2000: break
Run Code Online (Sandbox Code Playgroud)

但这并不是必要的,因为Mermoz确实对此表示同意:

>>> e 
Decimal('2.7182818284590452353602874713526624977572470936999595749669676 
277240766303535475945713821785251664274274663919320030599218174135966290 
435729003342952605956307381323286279434907632338298807531952510190115738 
341879307021540891499348841675092447614606680822648001684774118537423454 
424371075390777449920695517027618386062613313845830007520449338265602976 
067371132007093287091274437470472306969772093101416928368190255151086574 
637721112523897844250569536967707854499699679468644549059879316368892300 
987931277361782154249992295763514822082698951936680331825288693984964651 
058209392398294887933203625094431173012381970684161403970198376793206832 
823764648042953118023287825098194558153017567173613320698112509961818815 
930416903515988885193458072738667385894228792284998920868058257492796104 
841984443634632449684875602336248270419786232090021609902353043699418491 
463140934317381436405462531520961836908887070167683964243781405927145635 
490613031072085103837505101157477041718986106873969655212671546889570350 
354021234078498193343210681701210056278802351930332247450158539047304199 
577770935036604169973297250886876966403555707162268447162560798826517871 
341951246652010305921236677194325278675398558944896970964097545918569563 
802363701621120477427228364896134225164450781824423529486363721417402388 
934412479635743702637552944483379980161254922785092577825620926226483262 
779333865664816277251640191059004916449982893150566047258027786318641551 
956532442586982946959308019152987211725563475463964479101459040905862984 
967912874068705048958586717479854667757573205681288459205413340539220001 
137863009455606881667400169842055804033637953764520304024322566135278369 
511778838638744396625322498506549958862342818997077332761717839280349465 
014345588970719425863987727547109629537415211151368350627526023264847287 
039207643100595841166120545297030236472549296669381151373227536450988890 
313602057248176585118063036442812314965507047510254465011727211555194866 
850800368532281831521960037356252794495158284188294787610852639810')
>>> Decimal(1).exp() 
Decimal('2.7182818284590452353602874713526624977572470936999595749669676 
277240766303535475945713821785251664274274663919320030599218174135966290 
435729003342952605956307381323286279434907632338298807531952510190115738 
341879307021540891499348841675092447614606680822648001684774118537423454 
424371075390777449920695517027618386062613313845830007520449338265602976 
067371132007093287091274437470472306969772093101416928368190255151086574 
637721112523897844250569536967707854499699679468644549059879316368892300 
987931277361782154249992295763514822082698951936680331825288693984964651 
058209392398294887933203625094431173012381970684161403970198376793206832 
823764648042953118023287825098194558153017567173613320698112509961818815 
930416903515988885193458072738667385894228792284998920868058257492796104 
841984443634632449684875602336248270419786232090021609902353043699418491 
463140934317381436405462531520961836908887070167683964243781405927145635 
490613031072085103837505101157477041718986106873969655212671546889570350 
354021234078498193343210681701210056278802351930332247450158539047304199 
577770935036604169973297250886876966403555707162268447162560798826517871 
341951246652010305921236677194325278675398558944896970964097545918569563 
802363701621120477427228364896134225164450781824423529486363721417402388 
934412479635743702637552944483379980161254922785092577825620926226483262 
779333865664816277251640191059004916449982893150566047258027786318641551 
956532442586982946959308019152987211725563475463964479101459040905862984 
967912874068705048958586717479854667757573205681288459205413340539220001 
137863009455606881667400169842055804033637953764520304024322566135278369 
511778838638744396625322498506549958862342818997077332761717839280349465 
014345588970719425863987727547109629537415211151368350627526023264847287 
039207643100595841166120545297030236472549296669381151373227536450988890 
313602057248176585118063036442812314965507047510254465011727211555194866 
850800368532281831521960037356252794495158284188294787610852639814') 
Run Code Online (Sandbox Code Playgroud)


dou*_*oug 5

优秀的纯python库Mpmath肯定会有所作为.

该库的唯一重点是多精度浮点运算.

例如,Mpath可以将e评估为任意精度:

In [2]: from mpmath import *
# set the desired precision on the fly
In [3]: mp.dps=20; mp.pretty=True
In [4]: +e
Out[4]: 2.7182818284590452354

# re-set the precision (50 digits)
In [5]: mp.dps=50; mp.pretty=True
In [6]: +e
Out[6]: 2.7182818284590452353602874713526624977572470937
Run Code Online (Sandbox Code Playgroud)

另外,Mpmath也与Matplotlib紧密集成.