Python实现数值积分方式
作者:MachineRandy 时间:2022-01-23 14:00:37
原理:
利用复化梯形公式,复化Simpson公式,计算积分。
步骤:
import math
"""测试函数"""
def f(x,i):
if i == 1:
return (4 - (math.sin(x)) ** 2) ** 0.5
if i == 2:
if x == 0:
return 1
else:
return math.sin(x) / x
if i == 3:
return (math.exp(x)) / (4 + x ** 2)
if i == 4:
return math.log(1+x,math.e) / (1 + x ** 2)
"""打印显示函数"""
def p(i,n):
return "第" + str(i) + "题,n=" + str(n) + "时的积分值为:"
"""复化Simpson函数"""
def Simpson(a, b, n, i):
h = (b - a) / (2 * n)
F0 = f(a,i) + f(b,i)
F1 = 0
F2 = 0
for j in range(1,2 * n):
x = a + (j * h)
if j % 2 == 0:
F2 = F2 + f(x,i)
else:
F1 = F1 + f(x,i)
SN = (h * (F0 + 2 * F2 + 4 * F1)) / 3
print("复化Simpson函数" + p(i,n) + str("%-10.7f"%(SN)))
return SN
def T(a, b, n, i):
h = (b - a) / n
F0 = f(a,i) + f(b,i)
F = 0
for j in range(1,n):
x = a + (j * h)
F = F + f(x,i)
SN = (h * (F0 + 2 * F)) / 2
print("复化梯形函数" + p(i,n) + str("%-10.7f"%(SN)))
return SN
def SimpsonTimes(x):
n = 1
y = Simpson(0, math.pi/4, n, 1)
while(abs(y - 1.5343916) > x):
n = n + 1
y = Simpson(0, math.pi/4, n, 1)
else:
return n
def Times(x):
n = 1
y = T(0, math.pi/4, n, 1)
while(abs(y - 1.5343916) > x):
n = n + 1
y = T(0, math.pi/4, n, 1)
else:
return n
"""
测试部分
"""
Simpson(0, math.pi/4, 10, 1)
Simpson(0, 1, 10, 2)
Simpson(0, 1, 10, 3)
Simpson(0, 1, 10, 4)
Simpson(0, math.pi/4, 20, 1)
Simpson(0, 1, 20, 2)
Simpson(0, 1, 20, 3)
Simpson(0, 1, 20, 4)
T(0, math.pi/4, 10, 1)
T(0, 1, 10, 2)
T(0, 1, 10, 3)
T(0, 1, 10, 4)
T(0, math.pi/4, 20, 1)
T(0, 1, 20, 2)
T(0, 1, 20, 3)
T(0, 1, 20, 4)
print("复化梯形函数求解第一问,精度为0.00001时需要" + str(Times(0.00001)) + "个步数")
print("复化Simpson函数求解第一问,精度为0.00001时需要" + str(SimpsonTimes(0.00001)) + "个步数")
print("复化梯形函数求解第一问,精度为0.000001时需要" + str(Times(0.000001)) + "个步数")
print("复化Simpson函数求解第一问,精度为0.000001时需要" + str(SimpsonTimes(0.000001)) + "个步数")
来源:https://blog.csdn.net/MachineRandy/article/details/82634757
标签:Python,数值,积分
0
投稿
猜你喜欢
比较全面的PHP数组的使用方法小结
2023-11-18 21:30:25
怎么样在网页上读取远程xml的数据
2008-10-10 17:43:00
JS分割字符串并放入数组的函数
2023-08-05 15:31:03
关于element-ui中el-form自定义验证(调用后端接口)
2024-04-27 15:57:00
MySQL字符集查看方法
2010-12-14 15:14:00
python操作redis的方法
2021-03-27 05:14:03
python脚本爬取字体文件的实现方法
2022-09-07 18:20:55
pandas 强制类型转换 df.astype实例
2022-03-27 04:41:56
深入讨论Python函数的参数的默认值所引发的问题的原因
2022-08-03 00:54:31
python动态加载变量示例分享
2022-10-23 18:57:50
ASP,PHP与.NET伪造HTTP-REFERER方法及防止伪造REFERER方法探讨
2024-04-29 13:57:44
Pytest实现setup和teardown的详细使用详解
2023-09-12 02:06:48
python+opencv实现论文插图局部放大并拼接效果
2023-12-07 17:29:12
Python Django教程之实现待办事项应用程序
2022-11-13 09:39:15
MySQL数据库卸载的完整步骤
2024-01-13 13:12:52
sql查询点滴记录
2012-01-05 19:07:49
GoLang并发机制探究goroutine原理详细讲解
2023-08-30 05:41:33
Spring 数据库连接池(JDBC)详解
2024-01-22 19:00:36
python django生成迁移文件的实例
2023-07-01 18:48:31
如何使用Vue3设计实现一个Model组件浅析
2024-04-27 15:57:19