Python实现数值积分方式

作者:MachineRandy 时间:2022-01-23 14:00:37 

原理:

利用复化梯形公式,复化Simpson公式,计算积分。

步骤:

Python实现数值积分方式


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
  • asp之家 网络编程 m.aspxhome.com