数值积分实验

function [] = Rom(f,a,b,e)

k=0; % 迭代次数

n=1; % 区间划分个数

h=b-a;

T=double(h/2*(f(a)+f(b)));%梯形公式求出T(1,1)

err=b-a;

while err>=e

k=k+1;

h=h/2;

tmp=0;

for i=1:n

tmp=tmp+f(a+(2*i-1)*h);

end

T(k+1,1)=double(T(k)/2+h*tmp);%求出行首元

for j=1:k

T(k+1,j+1)=double(T(k+1,j))+double((T(k+1,j)-T(k,j))/(4^j-1));%迭代算法

end

n=n*2;

err=abs(T(k+1,k+1)-T(k,k));%误差为该次迭代的首元和上一次迭代首元的差

end

disp(T);

实验总结:

在这次实验中,我学会了使用龙贝格积分算法来进行数值积分,并在 MATLAB 中实现了该算法的程序。通过实验,我掌握了龙贝格积分算法的原理和实现步骤,以及如何在 MATLAB 中编写相应的程序。在编写程序的过程中,我训练了 MATLAB 编程的技能,特别是对矩阵运算和循环的应用有了更深的理解和掌握。

通过实验,我发现龙贝格积分算法是一种逐步逼近的方法,它可以在迭代过程中不断提高积分的精度,直到达到预设的精度要求为止。另外,我还发现在编写算法程序时,需要注意数值计算的精度和稳定性,以避免出现误差和计算错误。

今后学习中,我希望进一步加深对数值积分算法的理解,包括其他常用的数值积分方法,以及如何在实际问题中选择合适的积分方法。同时,我也希望提高自己在 MATLAB 编程方面的熟练程度,尤其是在处理数值计算和算法实现方面的能力。

相关推荐
帅帅爱数学22 分钟前
DeepMimic论文详细解析:基于示例引导的深度强化学习实现物理仿真角色技能
算法·强化学习
IT成长日记1 小时前
【LVS入门宝典】LVS调度算法轮询(RR)深度解析:从原理到实战的公平调度之道
算法·lvs·rr·轮询调度算法
NAGNIP1 小时前
一文搞懂量化、剪枝和知识蒸馏都是什么?
算法
点云SLAM2 小时前
GTSAM 中自定义因子(Custom Factor)的详解和实战示例
算法·机器人·slam·后端优化·gtsam·gtsam自定义因子·因子图
萘柰奈2 小时前
LeetCode刷题记录----62.不同路径(Medium)
算法·leetcode·职场和发展
阳光明媚sunny2 小时前
爬楼梯算法java实现
算法·动态规划
贝塔实验室3 小时前
LDPC码的概念
科技·学习·程序人生·算法·学习方法·程序员创富·改行学it
weixin_307779133 小时前
矩形势阱(V(x) = -H for |x|≤L)的束缚态能级求解与宇称分类
算法
MMjeaty3 小时前
数据结构——栈和队列
数据结构·算法
机器学习之心9 小时前
多目标鲸鱼优化算法(NSWOA),含46种测试函数和9个评价指标,MATLAB实现
算法·matlab·多目标鲸鱼优化算法·46种测试函数·9个评价指标