Python 實(shí)現(xiàn)定積分與二重定積分的操作
最近項(xiàng)目需要使用程序?qū)崿F(xiàn)數(shù)學(xué)微積分,最初想用java實(shí)現(xiàn),后來發(fā)現(xiàn)可用文檔太少,實(shí)現(xiàn)比較麻煩,后來嘗試使用python實(shí)現(xiàn),代碼量較少,主要有sympy與scipy兩種實(shí)現(xiàn)方式,本文主要記錄scipy的實(shí)現(xiàn)方式。
2.內(nèi)容2.1 所求函數(shù)
# 引入需要的包import scipy.integratefrom numpy import expfrom math import sqrtimport math# 創(chuàng)建表達(dá)式f = lambda x,y : exp(x**2-y**2)# 計(jì)算二重積分:(p:積分值,err:誤差)# 這里注意積分區(qū)間的順序# 第二重積分的區(qū)間參數(shù)要以函數(shù)的形式傳入p,err= scipy.integrate.dblquad(f, 0, 2, lambda g : 0, lambda h : 1)print(p)2.3 注意問題
1. exp盡量使用numpy的exp
2. 注意積分區(qū)間參數(shù)的順序
3. 第二重積分的區(qū)間參數(shù)要以函數(shù)的形式傳入
補(bǔ)充:python實(shí)現(xiàn)求解積分
例子 1:假設(shè)有隨機(jī)變量 x,定義域 X,其概率密度函數(shù)為 p(x),f(x) 為定義在 X 上的函數(shù),目標(biāo)是求函數(shù) f(x) 關(guān)于密度函數(shù) p(x) 的數(shù)學(xué)期望
。
蒙特卡洛法根據(jù)概率分布 p(x) 獨(dú)立地抽樣 n 個(gè)樣本 x1,x2,…..xn,得到近似的 f(x) 期望為:

其實(shí)這個(gè)的理解就是要求一個(gè)擁有概率密度的函數(shù)期望值
期望=積分(每個(gè)點(diǎn)的密度函數(shù)*每個(gè)點(diǎn)的價(jià)值函數(shù))
例子 2:假設(shè)我們想要求解 h(x) 在 X 上的積分:

我們將 h(x) 分解成一個(gè)函數(shù) f(x) 和一個(gè)概率密度函數(shù) p(x) 的乘積,進(jìn)而又將問題轉(zhuǎn)換為求解函數(shù) f(x) 關(guān)于密度函數(shù) p(x) 的數(shù)學(xué)期望
:

這里的Ep(x)是相當(dāng)于把整個(gè)分布當(dāng)時(shí)了概率分布,即總發(fā)生概率為1.
這里,f(x) 表示為
,則有:

更一般的,假設(shè)我們想要求解
,熟悉積分的同學(xué)肯定已經(jīng)知道答案為
,那么如何用采樣的方法來得到這個(gè)值呢?
令
,0<x<10,那么
。
下面是代碼:
’’’import randomnum=1000000sum=0for i in range(0,num): x=random.uniform(0,10) sum+=x*x*10sum/=1000000print(sum)’’’import randomnumSamples=10000samples=[random.uniform(0,10)for _ in range(numSamples)]f_samples=[10*sample**2 for sample in samples]result=1/10000.0*sum(f_samples)print(result)
result=333.10527012455066
random.uniform(x,y)表示在[x,y)之間生成一個(gè) 實(shí)數(shù)
對于復(fù)雜的 h(x),這種方法計(jì)算起來顯然就更加方便了(特別是忘記積分怎么算的同學(xué))。
蒙特卡洛方法其實(shí)就是利用大數(shù)定理通過大量統(tǒng)計(jì)來算出最后的值。
到這里為止,我們簡單的介紹了蒙特卡洛方法,但是依舊沒有提到要怎么利用復(fù)雜的概率密度函數(shù)進(jìn)行采樣。
接下來我們來看一下接受-拒絕法(accept-reject sampling method),它也是蒙特卡洛法中的一種類型適用于不能直接抽樣的情況。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. 使用Python webdriver圖書館搶座自動(dòng)預(yù)約的正確方法2. ASP基礎(chǔ)知識(shí)VBScript基本元素講解3. 在線php代碼縮進(jìn)、代碼美化工具:PHP Formatter4. Linux刪除系統(tǒng)自帶版本Python過程詳解5. Android 簡單的實(shí)現(xiàn)滑塊拼圖驗(yàn)證碼功能6. 淺談?dòng)蓀osition屬性引申的css進(jìn)階討論7. ASP.NET MVC使用jQuery ui的progressbar實(shí)現(xiàn)進(jìn)度條8. PHP如何開啟Opcache功能提升程序處理效率9. Python 合并拼接字符串的方法10. Python3 json模塊之編碼解碼方法講解

網(wǎng)公網(wǎng)安備