复化梯形求积分实例——用Python进行数值计算


Posted in Python onNovember 20, 2019

用程序来求积分的方法有很多,这篇文章主要是有关牛顿-科特斯公式。

学过插值算法的同学最容易想到的就是用插值函数代替被积分函数来求积分,但实际上在大部分场景下这是行不通的。

插值函数一般是一个不超过n次的多项式,如果用插值函数来求积分的话,就会引进高次多项式求积分的问题。这样会将原来的求积分问题带到另一个求积分问题:如何求n次多项式的积分,而且当次数变高时,会出现龙悲歌现象,误差反而可能会增大,并且高次的插值求积公式有可能会变得不稳定:详细原因不赘述。

牛顿-科特斯公式解决这一问题的办法是将大的插值区间分为一堆小的插值区间,使得多项式的次数不会太高。然后通过引入参数函数

复化梯形求积分实例——用Python进行数值计算

将带有幂的项的取值范围固定在一个固定范围内,这样一来就将多项式带有幂的部分的求积变为一个固定的常数,只需手工算出来即可。这个常数可以直接带入多项式求积函数。

上式中x的求积分区间为[a, b],h = (b - a)/n, 这样一来积分区间变为[0, n],需要注意的是从这个公式可以看出一个大的区间被分为n个等长的小区间。 这一部分具体请参见任意一本有关数值计算的书!

n是一个事先确定好的值。

又因为一个大的插值区间需要被分为等长的多个小区间,并在这些小区间上分别进行插值和积分,因此此时的牛顿-科特斯公式被称为:复化牛顿-科特斯公式。

并且对于n的不同取值牛顿-科特斯有不同的名称: 当n=1时,叫做复化梯形公式,复化梯形公式也就是将每一个小区间都看为一个梯形(高为h,上底为f(t), 下底为f(t+1))。这与积分的本质:无限分隔 相同。

当n=2时,复化牛顿-科特斯公式被称为复化辛普森公式(非美国法律界著名的那个辛普森)。

我这篇文章实现的是复化梯形公式:

复化梯形求积分实例——用Python进行数值计算

首先写一个函数求节点函数值求和那部分:

"""
@brief: 求和 ∑f(xk) : xk表示等距节点的第k个节点,不包括端点
  xk = a + kh (k = 0, 1, 2, ...)
  积分区间为[a, b]
   
@param: xk  积分区间的等分点x坐标集合(不包括端点)
@param: func 求积函数
@return: 返回值为集合的和
"""
def sum_fun_xk(xk, func):
 return sum([func(each) for each in xk])

然后就可以写整个求积分函数了:

"""
@brief: 求func积分 :
   
@param: a 积分区间左端点
@param: b 积分区间右端点
@param: n 积分分为n等份(复化梯形求积分要求)
@param: func 求积函数
@return: 积分值
""" 
def integral(a, b, n, func):
 h = (b - a)/float(n)
 xk = [a + i*h for i in range(1, n)]
 return h/2 * (func(a) + 2 * sum_fun_xk(xk, func) + func(b))

相当的简单

试验:

当把大区间分为两个小区间时:

复化梯形求积分实例——用Python进行数值计算

分为20个小区间时:

复化梯形求积分实例——用Python进行数值计算

求的积分值就是这些彩色的梯形面积之和。

测试代码:

if __name__ == "__main__":
  
 func = lambda x: x**2
 a, b = 2, 8
 n = 20
 print integral(a, b, n, func)
  
 ''' 画图 '''
 import matplotlib.pyplot as plt
 plt.figure("play")
 ax1 = plt.subplot(111)
 plt.sca(ax1)
  
 tmpx = [2 + float(8-2) /50 * each for each in range(50+1)]
 plt.plot(tmpx, [func(each) for each in tmpx], linestyle = '-', color='black')
  
 for rang in range(n):
  tmpx = [a + float(8-2)/n * rang, a + float(8-2)/n * rang, a + float(8-2)/n * (rang+1), a + float(8-2)/n * (rang+1)]
  tmpy = [0, func(tmpx[1]), func(tmpx[2]), 0]
  c = ['r', 'y', 'b', 'g']
  plt.fill(tmpx, tmpy, color=c[rang%4])
 plt.grid(True)
 plt.show()

注意上面代码中的n并不是上文开篇提到的公式中的n,开篇提到的n是指将每一个具体的插值区间(也就是小区间)等距插n个节点,复化梯形公式的n是固定的为1.

而代码中的n指将大区间分为n个小区间。

以上这篇复化梯形求积分实例——用Python进行数值计算就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python快速从注释生成文档的方法
Dec 26 Python
Python编程实现输入某年某月某日计算出这一天是该年第几天的方法
Apr 18 Python
python3实现全角和半角字符转换的方法示例
Sep 21 Python
Python实现读取json文件到excel表
Nov 18 Python
使用Python制作微信跳一跳辅助
Jan 31 Python
python 用lambda函数替换for循环的方法
Jun 09 Python
Python中__slots__属性介绍与基本使用方法
Sep 05 Python
python实现汽车管理系统
Nov 30 Python
python 遍历pd.Series的index和value
Nov 26 Python
Python使用文件操作实现一个XX信息管理系统的示例
Jul 02 Python
Python 随机按键模拟2小时
Dec 30 Python
解决pycharm不能自动保存在远程linux中的问题
Feb 06 Python
Python实现数值积分方式
Nov 20 #Python
基于Python批量生成指定尺寸缩略图代码实例
Nov 20 #Python
python用quad、dblquad实现一维二维积分的实例详解
Nov 20 #Python
利用python实现AR教程
Nov 20 #Python
使用python实现画AR模型时序图
Nov 20 #Python
Python笔记之工厂模式
Nov 20 #Python
Python常用模块logging——日志输出功能(示例代码)
Nov 20 #Python
You might like
dede3.1分页文字采集过滤规则详说(图文教程)续四
2007/04/03 PHP
php 伪造本地文件包含漏洞的代码
2011/11/03 PHP
分享一个PHP数据流应用的简单例子
2012/06/01 PHP
php设置允许大文件上传示例代码
2014/03/10 PHP
Smarty中的注释和截断功能介绍
2015/04/09 PHP
wap浏览自动跳转到wap页面的js代码
2014/05/17 Javascript
为什么JS中eval处理JSON数据要加括号
2015/04/13 Javascript
NodeJs读取JSON文件格式化时的注意事项
2016/09/25 NodeJs
hovertree插件实现二级树形菜单(简单实用)
2016/12/28 Javascript
JS表单传值和URL编码转换
2018/03/03 Javascript
RequireJS用法简单示例
2018/08/20 Javascript
vue项目中实现的微信分享功能示例
2019/01/21 Javascript
vue2.0基于vue-cli+element-ui制作树形treeTable
2019/04/30 Javascript
微信公众号平台接口开发 获取access_token过程解析
2019/08/14 Javascript
微信小程序本地存储实现每日签到、连续签到功能
2019/10/09 Javascript
JavaScript中常用的3种弹出提示框(alert、confirm、prompt)
2020/11/10 Javascript
[03:40]DOTA2抗疫特别篇《英雄年代》
2020/02/28 DOTA
对于Python的框架中一些会话程序的管理
2015/04/20 Python
python中的全局变量用法分析
2015/06/09 Python
使用python检测主机存活端口及检查存活主机
2015/10/12 Python
Python寻找两个有序数组的中位数实例详解
2018/12/05 Python
python实现三维拟合的方法
2018/12/29 Python
TENSORFLOW变量作用域(VARIABLE SCOPE)
2020/01/10 Python
python GUI库图形界面开发之PyQt5滚动条控件QScrollBar详细使用方法与实例
2020/03/06 Python
Python PIL库图片灰化处理
2020/04/07 Python
使用 css3 transform 属性来变换背景图的方法
2019/05/07 HTML / CSS
html5画布旋转效果示例
2014/01/27 HTML / CSS
详解Canvas 跨域脱坑实践
2018/11/07 HTML / CSS
html5拖拽应用记录及注意点
2020/05/27 HTML / CSS
澳大利亚100%丝绸多彩度假装商店:TheSwankStore
2019/09/04 全球购物
财务会计专业推荐信
2013/11/30 职场文书
新学期小学班主任工作计划
2019/06/21 职场文书
教师学期述职自我鉴定
2019/08/16 职场文书
红灯733-1型14管5波段半导体收音机
2021/04/22 无线电
Python 文本滚动播放器的实现代码
2021/04/25 Python
总结Python常用的魔法方法
2021/05/25 Python