关键词不能为空

当前您在: 主页 > 高中公式大全 >

圆心距离公式复化梯形公式和复化Simpson公式

作者:高考题库网
来源:https://www.bjmy2z.cn/gaokao
2020-10-02 21:49
tags:梯形求高公式

有关月亮的古诗-will的过去式

2020年10月2日发(作者:徐霞客)
数值计算方法上机题目3
一、计算定积分得近似值:

要求:
(1)若用复化梯形公式与复化Simpson公式计算,要求误差限,分
别利用她们得余项估计对每种 算法做出步长得事前估计;
(2)分别利用复化梯形公式与复化Simpson公式计算定积分;
(3)将计算结果与精确解比较,并比较两种算法得计算量.
1、复化梯形公式
程序:
程序1(求f(x)得n阶导数:
syms x
f=x*exp(x) %定义函数f(x)
n=input('输入所求导数阶数:’)
f2=diff(f,x,n) %求f(x)得n阶导数
结果1
输入n=2
f2 =
2*exp(x) + x*exp(x)
程序2:
clc
clear
syms x %定义自变量x
f=inline('x*exp(x)','x’) %定义函数f(x)=x*exp(x),换函数时只需换
该函数表达式即可
f2=inline(’(2*exp(x) + x*exp(x))','x’) %定义f(x)得二阶导数,输
入程序1里求出得f2即可。
f3='-(2*exp(x) + x*exp(x))' %因fminbnd()函数求得就是表达式
得最小值,且要求表达式带引号,故取负号,以便求最大值
e=5*10^(—8) %精度要求值
a=1 %积分下限
b=2 %积分上限
x1=fminbnd(f3,1,2) %求负得二阶导数得最小值点,也就就是求二阶导数得
最大值点对应得x值
for n=2:1000000 %求等分数n
Rn=—(b—a)12*((b-a)n)^2*f2(x1) %计算余项
if abs(Rn) break % 符合要求时结束
end
end
h=(b-a)n %求h
Tn1=0
for k=1:n—1 %求连加与
xk=a+k*h
Tn1=Tn1+f(xk)
end
Tn=h2*((f(a)+2*Tn1+f(b)))
z=exp(2)
R=Tn-z %求已知值与计算值得差
fprintf('用复化梯形算法计算得结果 Tn=')
disp(Tn)
fprintf('等分数 n=’)
disp(n) %输出等分数
fprintf('已知值与计算值得误差 R=')
disp(R)
输出结果显示:
用复化梯形算法计算得结果 Tn= 7、3891
等分数 n=7019
已知值与计算值得误差 R= 2、8300e—008
2、 Simpson公式
程序:
程序1:(求f(x)得n阶导数):
syms x

f=x*exp(x) %定义函数f(x)

n=input('输入所求导数阶数:')

f2=diff(f,x,n) %求f(x)得n阶导数
结果1
输入n=4
f2 =
4*exp(x) + x*exp(x)
程序2:
clc
clear
syms x %定义自变量x
f=inline(’x*exp(x)’,'x’) %定义函数f(x)=x*exp(x),换函数时只需
换该函数表达式即可
f2=inline('(4*exp(x) + x*exp(x))’,’x') %定义f(x)得四阶导数,输
入程序1里求出得f2即可
f3='—(4*exp(x) + x*exp(x))' %因fminbnd()函数求得就是表达式
得最小值,且要求表达式带引号,故取负号,一边求最大值
e=5*10^(-8) %精度要求值
a=1 %积分下限
b=2 %积分上限
x1=fminbnd(f3,1,2) %求负得四阶导数得最小值点,也就就是求
四阶导数得最大值点对应得x值
for n=2:1000000 %求等分数n
Rn=—(b—a)180*((b-a)(2*n))^4*f2(x1) %计算余项
if abs(Rn)〈e %用余项进行判断
break % 符合要求时结束
end
end
h=(b-a)n %求h
Sn1=0
Sn2=0
for k=0:n-1 %求两组连加与
xk=a+k*h
xk1=xk+h2
Sn1=Sn1+f(xk1)
Sn2=Sn2+f(xk)
end
Sn=h6*(f(a)+4*Sn1+2*(Sn2-f(a))+f(b)) %因Sn2多加了k=0时得值,
故减去f(a)
z=exp(2)
R=Sn—z %求已知值与计算值得差
fprintf(’用Simpson公式计算得结果 Sn=')
disp(Sn)
fprintf('等分数 n=’)
disp(n)
fprintf('已知值与计算值得误差 R=’)
disp(R)
输出结果显示:
用Simpson公式计算得结果 Sn= 7、3891
等分数 n=24
已知值与计算值得误差 R= 2、7284e—008
用复化梯形公式计算得 结果为:7、3891,与精确解得误差为:2、83
00e-008。等分数n=7019
用复化Simpson公式计算得结果为:7、3891,与精确解得误差
为:2、7284e-008 .等分数n=24
3、柯斯特公式求积分:
程序代码:
(1)function [y,Ck,Ak]=NewtonCotes(fun,a,b,n)
if nargin==1
[mm,nn]=size(fun);
if mm〉=8
error('为了保证NewtonCotes积分得稳定性,
最多只能有9个等距节点!')
elseif nn~=2
error(’fun构成应为:第一列为x,第二列为y,
并且个数为小于10得等距节点!')
end
xk=fun(1,:);
fk=fun(2,:);
a=min(xk);
b=max(xk);
n=mm-1;
elseif nargin==4
xk=linspace(a,b,n+1);
if isa(fun,’function_handle')
fx=fun(xk);
else
error('fun积分函数得句柄,且必须能够接受矢量输
入!')
end
else
error(’输入参数错误,请参考函数帮助!’)
end
Ck=cotescoeff(n);
Ak=(b-a)*Ck;
y=Ak*fx';
(2)function Ck=cotescoeff(n)
for i=1:n+1
k=i-1;
Ck(i)=(—1)^(n -k)factorial(k)factorial(n—k)n*q
uadl((t)intfun (t,n,k),0,n);
end
(3)function f=intfun(t,n,k)
f=1;
for i=[0:k—1,k+1:n]
f=f、*(t-i);
end
代码解释:
function [y,Ck,Ak]=NewtonCotes(fun,a,b,n)
% y=NewtonCotes(fun,a,b,n)
% 牛顿-科特斯数值积分公式
% 参数说明:
% fun,积分表达式,这里有两种选择
%(1)积分函数 句柄,必须能够接受矢量输入,比如fun=(x)
sin(x)、*cos(x)
% (2)x,y坐标得离散点, 第一列为x, 第二列为y, 必须等距, 且
节点得个数小于9, 比如: fun=[1:8;sin(1:8)]'
% 如果fun得表采用第二种方式,那么只需要输入第一个参数即可,
否则还要输入a,b,n三个参数
% a,积分下限
% b,积分上限
% n,牛顿- 科特斯数公式得阶数,必须满足1〈n〈7,因为n〉
=8时不能保证公式得稳定性
% (1)n=1,即梯形公式
% (2)n=2,即辛普森公式
% (3)n=4,即科特斯公式
% y,数值积分结果
% Ck,科特斯系数
% Ak,求积系数

% Example
% fun1=(x)sin(x);%必须可以接受矢量输入
% fun2=[0:0、1:0、5;sin(0:0、1:0、5)];%最多8个点,
必须等距
% y1=NewtonCotes(fun1,0,0、5,6)
% y2==NewtonCotes(fun2)
if nargin==1
[mm,nn]=size(fun);
if mm〉=8
error('为了保证NewtonCotes积分得稳定性,最
多只能有9个等距节点!')
elseif nn~=2
error(’fun构成应为:第一列为x,第二列为y,并且
个数为小于10得等距节点!')
end
xk=fun(1,:);
fk=fun(2,:);
a=min(xk);
b=max(xk);
n=mm-1;
elseif nargin==4
% 计算积分节点xk与节点函数值fx
xk=linspace(a,b,n+1);
if isa(fun,’function_handle’)
fx=fun(xk);
else
error('fun积分函数得句柄,且必须能够接受矢
量输入!’)
end
else
error('输入参数错误,请参考函数帮助!')
end
% 计算科特斯系数
Ck=cotescoeff(n);
% 计算求积系数
Ak=(b-a)*Ck;
% 求与算积分
y=Ak*fx’;
function Ck=cotescoeff(n)
% 由于科特斯系数最多7阶,为了方便我们可以直接使用,省
得每次都计算
% A1=[1,1]2
% A2=[1,4,1]6
% A3=[1,3,3,1]8
% A4=[7,32,12,32,1]/90
% A5=[19,75,50,50,75,19]288
% A6=[41,216,27,272,27,216,41]840
% A7=[751,357 7,1323,2989,2989,1323,3577,
751]17280
% 当时为了体现公式,我们使用程序计算n阶科特斯系数
for i=1:n+1
k=i-1;
Ck(i)=(-1)^(n-k)/factorial(k)facto ri
al(n—k)n*quadl((t)intfun(t,n,k),0,n);
end
function f=intfun(t,n,k)
% 科特斯系数中得积分表达式
f=1;
for i=[0:k-1,k+1:n]
f=f、*(t—i);
end
输出结果:
fun=(x)exp(x);
a=-1;
b=1;
n=4;
NewtonCotes(fun,a,b,n)
ans =2、3505
二、三点数值微分

细胞不能无限长大的原因-唐诗五言绝句


质因数是什么-不字开头的成语大全


无锡商业职业技术学院怎么样-带燕的诗句


会计可以考哪些证-零基础学出纳


怎样撩妹-表扬女人能干的句子


初三家长寄语鼓励-朱拉隆功


技校一般学费多少钱-pl是什么词性


正能量句子励志短句子-私立口腔医院排名



本文更新与2020-10-02 21:49,由作者提供,不代表本网站立场,转载请注明出处:https://www.bjmy2z.cn/gaokao/409309.html

复化梯形公式和复化Simpson公式的相关文章

  • 余华爱情经典语录,余华爱情句子

    余华的经典语录——余华《第七天》40、我不怕死,一点都不怕,只怕再也不能看见你——余华《第七天》4可是我再也没遇到一个像福贵这样令我难忘的人了,对自己的经历如此清楚,

    语文
  • 心情低落的图片压抑,心情低落的图片发朋友圈

    心情压抑的图片(心太累没人理解的说说带图片)1、有时候很想找个人倾诉一下,却又不知从何说起,最终是什么也不说,只想快点睡过去,告诉自己,明天就好了。有时候,突然会觉得

    语文
  • 经典古训100句图片大全,古训名言警句

    古代经典励志名言100句译:好的药物味苦但对治病有利;忠言劝诫的话听起来不顺耳却对人的行为有利。3良言一句三冬暖,恶语伤人六月寒。喷泉的高度不会超过它的源头;一个人的事

    语文
  • 关于青春奋斗的名人名言鲁迅,关于青年奋斗的名言鲁迅

    鲁迅名言名句大全励志1、世上本没有路,走的人多了自然便成了路。下面是我整理的鲁迅先生的名言名句大全,希望对你有所帮助!当生存时,还是将遭践踏,将遭删刈,直至于死亡而

    语文
  • 三国群英单机版手游礼包码,三国群英手机单机版攻略

    三国群英传7五神兽洞有什么用那是多一个武将技能。青龙飞升召唤出东方的守护兽,神兽之一的青龙。玄武怒流召唤出北方的守护兽,神兽之一的玄武。白虎傲啸召唤出西方的守护兽,

    语文
  • 不收费的情感挽回专家电话,情感挽回免费咨询

    免费的情感挽回机构(揭秘情感挽回机构骗局)1、牛牛(化名)向上海市公安局金山分局报案,称自己为了挽回与女友的感情,被一家名为“实花教育咨询”的情感咨询机构诈骗4万余元。

    语文