日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 >

python数值积分_python与计算物理:实现数值积分的Simpson方法

發(fā)布時(shí)間:2023/12/18 38 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python数值积分_python与计算物理:实现数值积分的Simpson方法 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

1.[代碼]python與計(jì)算物理:實(shí)現(xiàn)數(shù)值積分的Simpson方法。

#!/usr/bin/env python

#coding=utf-8

'''

Created on 2012年10月27日

@author: yanghl

simpson 法計(jì)算積分,數(shù)值積分,效果非常理想

'''

from math import *

def func(x):

"""

定義被積分函數(shù)

"""

return x*sin(x)

def Get_N(a,b,width):

# width為步長

N=int((b-a)/width + 1)

if N%2 == 0:

N=N+1

return N

def GenerateData(a,b,n,width):

datas = []

r=a

for i in range(0,n):

datas.append(func(r))

r = r+width

return datas

def simpson_integral(datas,width,n):

sum = datas[0]+datas[n-1]

for i in range(2,n):

if i%2== 0:

sum = sum +4*datas[i-1]

else:

sum = sum +2*datas[i-1]

return sum*width/3.0

if __name__ == "__main__":

a=1.0 #積分上限

b=3.0 #積分下限

width=0.0625 #步長

N=Get_N(a,b,width)

datas = GenerateData(a,b,N,width)

print simpson_integral(datas,width,N)

#調(diào)用scipy.integrate 包進(jìn)行計(jì)算

import scipy.integrate as integrate

print integrate.quad(func, a, b)[0]

總結(jié)

以上是生活随笔為你收集整理的python数值积分_python与计算物理:实现数值积分的Simpson方法的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。