中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MicroPython中怎么計算任意位數圓周率

發布時間:2021-08-05 17:39:21 來源:億速云 閱讀:103 作者:Leah 欄目:互聯網科技

本篇文章為大家展示了MicroPython中怎么計算任意位數圓周率,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

計算任意精度的圓周率是個有趣的主題,得益于python的強大計算能力,我們在MicroPython中也可以輕松的計算pi的數值。

先輸入下面的代碼:

"""
文件:pi.py
說明:用MicroPython計算任意精度圓周率計算
作者:未知
版本:
時間:
修改:邵子揚
      2016.5
      v1.1
http://bbs.micro-python.com/forum.php
"""
import time

def pi(places=10):
  # 3 + 3*(1/24) + 3*(1/24)*(9/80) + 3*(1/24)*(9/80)*(25/168)
  # The numerators 1, 9, 25, ... are given by (2x + 1) ^ 2
  # The denominators 24, 80, 168 are given by (16x^2 -24x + 8)
  extra = 8
  one = 10 ** (places+extra)
  t, c, n, na, d, da = 3*one, 3*one, 1, 0, 0, 24

  while t > 1: 
    n, na, d, da = n+na, na+8, d+da, da+32
    t = t * n // d
    c += t
  return c // (10 ** extra)

def pi_t(n=10):
    t1=time.ticks_us()
    t=pi(n)
    t2=time.ticks_us()
    print('elapsed: ', time.ticks_diff(t1,t2)/1000000, 's')
    return t

def pi2(n=10):
    r=6*(10**n)*1000
    p=0
    k=0
    c=r//2
    d=c//(2*k+1)
    while d>0:
        p=p+d
        k=k+1
        k2=2*k
        c=c*(k2-1)//(4*k2)
        d=c//(k2+1)
    return p//1000

def pi2_t(n=10):
    t1=time.ticks_us()
    t=pi2(n)
    t2=time.ticks_us()
    print('elapsed: ', time.ticks_diff(t1,t2)/1000000, 's')
    return t

我們將它復制到STM32F7DISC中(STM32F7DISC已經下載了MicroPython固件),然后測試一下計算速度。(在其它MicroPython開發板上也可以進行這個測試)

MicroPython v1.8 on 2016-05-15; F7DISC with STM32F746
Type "help()" for more information.
>>> import pi
>>> npi=pi.pi_t(1000)
elapsed:  0.221486 s
>>> npi=pi.pi_t(2000)
elapsed:  0.793141 s
>>> npi=pi.pi_t(5000)
elapsed:  4.981964 s
>>> npi=pi.pi_t(10000)
elapsed:  21.02012 s
>>>

從運行結果可以看出,雖然不是很快,但是考慮到STM32的資源和性能,結果已經出乎預料了,畢竟計算函數還不到10行代碼,沒有做深度優化。最后打印出1000位的圓周率,大家可以和標準結果比較看看。


>>> pi.pi(1000)
31415926535897932384626433832795028841971693993751058209749445923078164062862089986280348253421170679821480865132823066470938446095505822317253594081284811174502841027019385211055596446229489549303819644288109756659334461284756482337867831652712019091456485669234603486104543266482133936072602491412737245870066063155881748815209209628292540917153643678925903600113305305488204665213841469519415116094330572703657595919530921861173819326117931051185480744623799627495673518857527248912279381830119491298336733624406566430860213949463952247371907021798609437027705392171762931767523846748184676694051320005681271452635608277857713427577896091736371787214684409012249534301465495853710507922796892589235420199561121290219608640344181598136297747713099605187072113499999983729780499510597317328160963185950244594553469083026425223082533446850352619311881710100031378387528865875332083814206171776691473035982534904287554687311595628638823537875937519577818577805321712268066130019278766111959092164201989
>>>

上述內容就是MicroPython中怎么計算任意位數圓周率,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

新乐市| 海宁市| 渑池县| 天长市| 梓潼县| 武汉市| 井研县| 威远县| 平舆县| 四子王旗| 任丘市| 江北区| 革吉县| 大悟县| 蒙城县| 布尔津县| 巨野县| 栾城县| 浦县| 辛集市| 临沂市| 奎屯市| 大竹县| 平乡县| 方正县| 建始县| 梧州市| 怀柔区| 怀仁县| 隆林| 凉城县| 建宁县| 郁南县| 山东省| 涡阳县| 全南县| 化德县| 德格县| 桦甸市| 大方县| 青阳县|