📄 naadapt.m
字号:
function [q,srm,err]=naadapt(fname,a,b,e)
%用途:自适应Simpson法求函数的积分
%格式:[q,srm,err]=naadapt(fname,a,b,e) fname是被积函数,a,b,分别为下上限,e为精度。
% srm返回计算过程,其第一列为小区间左端点,第二列为小区间右端点,第三列为小区间积分值,第为二分小区间积分值
% 第五列为小区间积分值误差估计,第六列为小区间积分值控制精度。q为srm第四列的和,返回积分值,err为误差估计。
srm=zeros(30,6);
it=0;done=1;m=1;
sr=simpson(fname,a,b,e);
srm(1,1:6)=sr;
state=it;
while(state==it)
n=m;
for j=n:-1:1
p=j;
sr0=srm(p,:);
err=sr0(5);e=sr0(6);
if e<=err
state=done;
a=sr0(1);b=sr0(2);err=sr0(5);e=sr0(6);
c=0.5*(a+b);e2=0.5*e;
sr1=simpson(fname,a,c,e2);
sr2=simpson(fname,c,b,e2);
err=abs(sr0(3)-sr1(3)-sr2(3))/10;
if err<e
srm(p,:)=sr0;
srm(p,4)=sr1(3)+sr2(3);
srm(p,5)=err;
else
srm(p+1:m+1,:)=srm(p:m,:);
m=m+1;
srm(p,:)=sr1;
srm(p+1,:)=sr2;
state=it;
end
end
end
end
q=sum(srm(:,4));
err=sum(abs(srm(:,5)));
srm=srm(1:m,:);
function z=simpson(fname,a,b,e)
h=b-a;c=0.5*(a+b);
f=feval(fname,[a c b]);
s=h*(f(1)+4*f(2)+f(3))/6;
s2=s;
err=e;
z=[a b s s2 err e];
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -