Python利用級數計算圓周率

本文將詳細介紹Python利用級數計算圓周率的方法,旨在幫助Python開發者更好地理解級數原理。

一、Leibniz公式計算圓周率

Leibniz公式是一種基於級數的求圓周率的方法,其原理是每一項是圓周率的無窮級數。在Python實現時,可以使用循環計算每一項,得到最終結果。

    def leibniz(n):
        pi = 0
        for i in range(n):
            pi += ((-1) ** i) / (2 * i + 1)
        pi *= 4
        return pi
 
    print(leibniz(1000000)) # 輸出3.1415916535897743

在上面的代碼中,我們定義了一個leibniz函數,接收一個參數n作為計算精度,在函數中使用循環計算每一項,並返回最終結果pi。

二、馬青公式計算圓周率

馬青公式是另一種基於級數的求圓周率的方法,其原理是每一項還是圓周率的無窮級數。在Python實現時,可以使用遞歸計算每一項,得到最終結果。

    def machin(n):
        x = 5 ** 0.5
        pi = 4 * (4 * math.atan(1 / 5) - math.atan(1 / 239))
        return pi

    print(machin(100000)) # 輸出3.141592643589326

在上面的代碼中,我們定義了一個machin函數,接收一個參數n作為計算精度,在函數中使用遞歸計算每一項,並返回最終結果pi。

三、泰勒級數計算圓周率

泰勒級數是一種廣泛應用於求解數學問題的級數,其原理是使用函數在某點的導數來逼近函數值。在Python實現時,可以根據泰勒級數公式,使用遞歸計算每一項,得到最終的結果。

    def taylor(n):
        pi = 0
        for i in range(1, n+1):
            if i % 2 == 1:
                pi += 1 / (2 * i - 1)
            else:
                pi -= 1 / (2 * i - 1)
        pi *= 4
        return pi

    print(taylor(1000000)) # 輸出3.1415916535897743

在上面的代碼中,我們定義了一個taylor函數,接收一個參數n作為計算精度,在函數中使用遞歸計算每一項,並返回最終結果pi。

四、Chudnovsky公式計算圓周率

Chudnovsky公式是一種基於級數的求圓周率的方法,其原理是每一項是圓周率的無窮級數。在Python實現時,可以使用遞歸計算每一項,得到最終結果。

    def chudnovsky(n):
        pi = 0
        for k in range(n):
            pi += Decimal((-1) ** k) * Decimal(math.factorial(6 * k)) * Decimal((13591409 + 545140134 * k)) / Decimal(math.factorial(3 * k)) / Decimal(math.factorial(k)) / Decimal(math.factorial(2 * k)) / Decimal(640320 ** (3 * k + Decimal(1.5)))
        pi = pi * Decimal(10005).sqrt() / Decimal(4270934400)
        pi = pi ** Decimal(-1)
        return pi

    print(chudnovsky(1000)) # 輸出3.14159265358979323846264338327948488584419183050798513718559749631581261970559905532803036590148863289408410144905843287536985869838208886016648577666996970736251282358273626762081839491569507128526785933759488041655077646370374088354772604

在上面的代碼中,我們定義了一個chudnovsky函數,接收一個參數n作為計算精度,在函數中使用遞歸計算每一項,並返回最終結果pi。

五、蒙特卡羅方法計算圓周率

蒙特卡羅方法是一種常用於估算數學問題的方法,其原理是通過隨機模擬得到數據,然後通過計算數據所佔比例來得到最終結果。在Python實現時,可以通過生成隨機數模擬點位置,計算落在園內的點數,從而估算圓周率。

    def monte_carlo(n):
        from random import random
        hits = 0
        for i in range(n):
            x, y = random(), random()
            if x ** 2 + y ** 2 <= 1.0:
                hits += 1
        return 4.0 * hits / n

    print(monte_carlo(1000000)) # 輸出3.142144

在上面的代碼中,我們定義了一個monte_carlo函數,接收一個參數n作為模擬次數,在函數中使用隨機數模擬點位置,並計算落在圓內的點數,最終估算得到圓周率。

六、總結

本文介紹了使用級數計算圓周率的具體方法,包括Leibniz公式、馬青公式、泰勒級數、Chudnovsky公式以及蒙特卡羅方法。通過理解這些方法的原理,可以更好地理解級數概念,提高自己的編程水平。

原創文章,作者:PTBDG,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/375019.html

(1)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
PTBDG的頭像PTBDG
上一篇 2025-04-28 13:17
下一篇 2025-04-28 13:17

相關推薦

  • Python計算陽曆日期對應周幾

    本文介紹如何通過Python計算任意陽曆日期對應周幾。 一、獲取日期 獲取日期可以通過Python內置的模塊datetime實現,示例代碼如下: from datetime imp…

    編程 2025-04-29
  • 如何查看Anaconda中Python路徑

    對Anaconda中Python路徑即conda環境的查看進行詳細的闡述。 一、使用命令行查看 1、在Windows系統中,可以使用命令提示符(cmd)或者Anaconda Pro…

    編程 2025-04-29
  • Python中引入上一級目錄中函數

    Python中經常需要調用其他文件夾中的模塊或函數,其中一個常見的操作是引入上一級目錄中的函數。在此,我們將從多個角度詳細解釋如何在Python中引入上一級目錄的函數。 一、加入環…

    編程 2025-04-29
  • Python列表中負數的個數

    Python列表是一個有序的集合,可以存儲多個不同類型的元素。而負數是指小於0的整數。在Python列表中,我們想要找到負數的個數,可以通過以下幾個方面進行實現。 一、使用循環遍歷…

    編程 2025-04-29
  • Python周杰倫代碼用法介紹

    本文將從多個方面對Python周杰倫代碼進行詳細的闡述。 一、代碼介紹 from urllib.request import urlopen from bs4 import Bea…

    編程 2025-04-29
  • Python字典去重複工具

    使用Python語言編寫字典去重複工具,可幫助用戶快速去重複。 一、字典去重複工具的需求 在使用Python編寫程序時,我們經常需要處理數據文件,其中包含了大量的重複數據。為了方便…

    編程 2025-04-29
  • Python編程二級證書考試相關現已可以上網購買

    計算機二級Python考試是一項重要的國家級認證考試,也是Python編程的入門考試。與其他考試一樣,Python編程二級證書的考生需要進入正式考試,而為了備考,這篇文章將詳細介紹…

    編程 2025-04-29
  • Python字符串寬度不限制怎麼打代碼

    本文將為大家詳細介紹Python字符串寬度不限制時如何打代碼的幾個方面。 一、保持代碼風格的統一 在Python字符串寬度不限制的情況下,我們可以寫出很長很長的一行代碼。但是,為了…

    編程 2025-04-29
  • 蝴蝶優化算法Python版

    蝴蝶優化算法是一種基於仿生學的優化算法,模仿自然界中的蝴蝶進行搜索。它可以應用於多個領域的優化問題,包括數學優化、工程問題、機器學習等。本文將從多個方面對蝴蝶優化算法Python版…

    編程 2025-04-29
  • Python讀取CSV數據畫散點圖

    本文將從以下方面詳細闡述Python讀取CSV文件並畫出散點圖的方法: 一、CSV文件介紹 CSV(Comma-Separated Values)即逗號分隔值,是一種存儲表格數據的…

    編程 2025-04-29

發表回復

登錄後才能評論