1. 用1阶至4阶Newton-Cotes公式计算积分

程序:

function I = NewtonCotes(f,a,b,type)

%

syms t;

t=findsym(sym(f));

I=0;

switch type

case 1,

I=((b-a)/2)*(subs(sym(f),t,a)+subs(sym(f),t,b));

case 2,

I=((b-a)/6)*(subs(sym(f),t,a)+4*subs(sym(f),t,(a+b)/2)+...

subs(sym(f),t,b));

case 3,

I=((b-a)/8)*(subs(sym(f),t,a)+3*subs(sym(f),t,(2*a+b)/3)+...

3*subs(sym(f),t,(a+2*b)/3)+subs(sym(f),t,b));

case 4,

I=((b-a)/90)*(7*subs(sym(f),t,a)+...

32*subs(sym(f),t,(3*a+b)/4)+...

12*subs(sym(f),t,(a+b)/2)+...

32*subs(sym(f),t,(a+3*b)/4)+7*subs(sym(f),t,b));

case 5,

I=((b-a)/288)*(19*subs(sym(f),t,a)+...

75*subs(sym(f),t,(4*a+b)/5)+...

50*subs(sym(f),t,(3*a+2*b)/5)+...

50*subs(sym(f),t,(2*a+3*b)/5)+...

75*subs(sym(f),t,(a+4*b)/5)+19*subs(sym(f),t,b));

case 6,

I=((b-a)/840)*(41*subs(sym(f),t,a)+...

216*subs(sym(f),t,(5*a+b)/6)+...

27*subs(sym(f),t,(2*a+b)/3)+...

272*subs(sym(f),t,(a+b)/2)+...

27*subs(sym(f),t,(a+2*b)/3)+...

216*subs(sym(f),t,(a+5*b)/6)+...

41*subs(sym(f),t,b));

case 7,

I=((b-a)/17280)*(751*subs(sym(f),t,a)+...

3577*subs(sym(f),t,(6*a+b)/7)+...

1323*subs(sym(f),t,(5*a+2*b)/7)+...

2989*subs(sym(f),t,(4*a+3*b)/7)+...

2989*subs(sym(f),t,(3*a+4*b)/7)+...

1323*subs(sym(f),t,(2*a+5*b)/7)+...

3577*subs(sym(f),t,(a+6*b)/7)+751*subs(sym(f),t,b));

end

syms x

f=exp(-x).*sin(x);

a=0;b=2*pi;

I = NewtonCotes(f,a,b,1)

N=1:

I =

0

N=2:

I =

0

N=3:

I =

(pi*((3*3^(1/2)*exp(-(2*pi)/3))/2 - (3*3^(1/2)*exp(-(4*pi)/3))/2))/4

N=4:

I =

(pi*(32*exp(-pi/2) - 32*exp(-(3*pi)/2)))/45

2. 已知,因此可以通过数值积分计算的近似值。

(1)分别取和,利用复合梯形公式和复合Simpson公式计算的近似值;

程序:

function Y= CombineTraprl(f,a,b,h)

%用复合梯形公式计算积分

syms t;

t= findsym(sym(f));

n=(b-a)/h;

I1= subs(sym(f),t,a);

l=0;

for k=1:n-1

xk=a+h*k;

l=l+2*subs(sym(f),t,xk);

end

Y=(h/2)*(I1+l+subs(sym(f),t,b));

syms x

f=4/(1+x^2);

a=0;b=1;

y= CombineTraprl(f,a,b,0.1);

vpa(y,6)

h=0.1:

ans =

3.13993

H=0.2:

ans =

1.04498

复合辛普森:

function Y= CombineSimpson(f,a,b,h)

%用复合辛普森公式计算积分

syms t;

t= findsym(sym(f));

n=(b-a)/h;

I1= subs(sym(f),t,a);

l=0;

for k=1:n-1

xk=a+h*k;

l=l+2*subs(sym(f),t,xk);

end

l2=0;

for k=1:n-1

xk2=a+h*(k+1)/2;

l2=l2+4*subs(sym(f),t,xk2);

end

Y=(h/6)*(I1+l+l2+subs(sym(f),t,b));

H=0.1:

ans =

3.22605

H=0.2:

ans =

2.93353

(2)把区间[0,1] 等分,利用复合梯形公式和复合Simpson公式计算的近似值,若要求误差不超过,问需要把区间[0,1]划分成多少等份;

function n=trap(f,a,b)

syms t;

t= findsym(sym(f));

I=zeros(1,500);

I(1)=((b-a)/2)*(subs(sym(f),t,a)+subs(sym(f),t,b));

I(2)=((b-a)/4)*(subs(sym(f),t,a)+2*subs(sym(f),t,(b-a)/2)+subs(sym(f),t,b));

k=3;

while((I(k-1)-I(k-2))>1/2*10^(-6))

l=0;

for i=1:k-1

xi=a+(b-a)/k*i;

l=l+2*subs(sym(f),t,xi);

end

I(k)=((b-a)/(2*k))*(subs(sym(f),t,a)+l+subs(sym(f),t,b));

k=k+1;

end

n=k-1;

syms x;

f=4./(1+x.^2);

a=0;b=1;

n=trap(f,a,b)

n =

88

复合辛普森公式:

function n=Simpson(f,a,b)

syms t;

t= findsym(sym(f));

I=zeros(1,500);

I(1)=((b-a)/6)*(subs(sym(f),t,a)+4*subs(sym(f),t,(b-a)/2)+subs(sym(f),t,b));

I(2)=((b-a)/12)*(subs(sym(f),t,a)+4*subs(sym(f),t,(b-a)/4)+4*subs(sym(f),t,3*(b-a)/4)+2*subs(sym(f),t,(b-a)/2)+subs(sym(f),t,b));

k=3;

while((I(k-1)-I(k-2))>1/2*10^(-6))

l=0;

m=4*subs(sum(f),t,(a+((a+b)/(2*k))));

for i=1:k-1

xi=a+(b-a)/k*i;

l=l+2*subs(sym(f),t,xi);

end

for j=1:k-1

xj=a+(b-a)/(k*2)+(b-a)/k*j;

m=m+4*subs(sym(f),t,xj);

end

I(k)=((b-a)/(2*k))*(subs(sym(f),t,a)+l+m+subs(sym(f),t,b));

k=k+1;

end

n=k-1;

n =

5

(3)选择不同的,对两种复合求积公式,试将误差描述为的函数,并比较两种方法的精度。

复合求积公式:

function y=traprls(f,a,b,h)

syms t;

t= findsym(sym(f));

n=(b-a)/h;

l=0;

for k=1:n-1

xk=a+h*k;

l=l+2*subs(sym(f),t,xk);

end

I1=(h/2)*(subs(sym(f),t,a)+l+subs(sym(f),t,b));

h=(b-a)/(n-1);

n=(b-a)/h;

l=0;

for k=1:n-1

xk=a+h*k;

l=l+2*subs(sym(f),t,xk);

end

I2=(h/2)*(subs(sym(f),t,a)+l+subs(sym(f),t,b));

y=I2-I1;

y=abs(y);

y=vpa(y,8);

syms x;

f=4./(1+x.^2);

a=0;b=1;

h=0.01:0.05:0.5;

v=zeros(1,10);

for i=1:10

v(i)=traprls(f,a,b,h(i))

end

v

plot(h,v,‘r-‘)

复合辛普森公式:

function y=Simpsons(f,a,b,h)

syms t;

t= findsym(sym(f));

n=(b-a)/h;

l=0;

m=4*subs(sum(f),t,(a+h/2));

for k=1:n-1

xk=a++h*k;

l=l+2*subs(sym(f),t,xk);

end

for i=1:n-1

xi=a+h/2+h*i;

m=m+4*subs(sym(f),t,xi);

end

I1=(h/6)*(subs(sym(f),t,a)+l+m+subs(sym(f),t,b));

h=(b-a)/(n-1);

n=(b-a)/h;

l=0;

m=4*subs(sum(f),t,(a+h/2));

for k=1:n-1

xk=a++h*k;

l=l+2*subs(sym(f),t,xk);

end

for i=1:n-1

xi=a+h/2+h*i;

m=m+4*subs(sym(f),t,xi);

end

I2=(h/6)*(subs(sym(f),t,a)+l+m+subs(sym(f),t,b));

y=abs(I2-I1);

y=vpa(y,10);

通过图像对比可知,复合辛普森公式精度更高。

(4)是否存在某个值,当小于这个值之后,再继续减小,计算结果不再有改进?为什么?

复合求积公式:

syms x;

f=4./(1+x.^2);

a=0;b=1;

h=0.001:0.004:0.2;

v=zeros(1,10);

for i=1:50

v(i)=traprls(f,a,b,h(i));

end

plot(h,v,‘r-‘)

复合辛普森公式:

通过图像可以发现,当h<0.025后,精度不再有显著改变。

3. 分别用三点和五点Gauss-Legendre公式计算积分

程序:

function I = IntGaussLegen(f,a,b,n)

syms t;

t= findsym(sym(f));

ta = (b-a)/2;

tb = (a+b)/2;

switch n

case 0,

I=2*ta*subs(sym(f),t,tb);

case 1,

I=ta*(subs(sym(f),t,ta*0.5773503+tb)+...

subs(sym(f),t,-ta*0.5773503+tb));

case 2,

I=ta*(0.55555556*subs(sym(f),t,ta*0.7745967+tb)+...

0.55555556*subs(sym(f),t,-ta*0.7745967+tb)+...

0.88888889*subs(sym(f),t,tb));

case 3,

I=ta*(0.3478548*subs(sym(f),t,ta*0.8611363+tb)+...

0.3478548*subs(sym(f),t,-ta*0.8611363+tb)+...

0.6521452*subs(sym(f),t,ta*0.3398810+tb) +...

0.6521452*subs(sym(f),t,-ta*0.3398810+tb));

case 4,

I=ta*(0.2369269*subs(sym(f),t,ta*0.9061793+tb)+...

0.2369269*subs(sym(f),t,-ta*0.9061793+tb)+...

0.4786287*subs(sym(f),t,ta*0.5384693+tb) +...

0.4786287*subs(sym(f),t,-ta*0.5384693+tb)+...

0.5688889*subs(sym(f),t,tb));

case 5,

I=ta*(0.1713245*subs(sym(f),t,ta*0.9324695+tb)+...

0.1713245*subs(sym(f),t,-ta*0.9324695+tb)+...

0.3607616*subs(sym(f),t,ta*0.6612094+tb)+...

0.3607616*subs(sym(f),t,-ta*0.6612094+tb)+...

0.4679139*subs(sym(f),t,ta*0.2386292+tb)+...

0.4679139*subs(sym(f),t,-ta*0.2386292+tb));

end

I=simplify(I);

I=vpa(I,6);

三点:

syms x

f=x.*exp(x)./((1+x)^2);

a=0;b=1;

a=IntGaussLegen(f,a,b,2)

a =

0.359187

五点:

a =

0.359141

复合梯形公式C语言程序,复合梯形公式、复合辛普森公式 matlab(示例代码)相关推荐

  1. harris角点检测c语言程序,Harris角点检测学习(示例代码)

    1.角点的定义与性质 角点是一种局部特征,具有旋转不变性和不随光照条件变化而变化的特点,一般将图像中曲率足够高或者曲率变化明显的点作为角点.检测得到的角点特征通常用于图像匹配.目标跟踪.运动估计等方面 ...

  2. Laravel 微信小程序后端实现用户登录的示例代码

    Laravel 微信小程序后端实现用户登录的示例代码 这篇文章主要介绍了Laravel 微信小程序后端实现用户登录的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值 ...

  3. C语言电池电压检测程序,电池温度检测原理和示例代码

    一.原理 其实电池内部有个热敏电阻, 与外部分压电阻构成一个简单的分压电路,  根据ADC采样得到的电压j计算热敏阻值再反推此时的温度, 首先我们要先了解热敏电阻阻值和温度一个公式: /*NTC热敏电 ...

  4. C语言循环选择还有,C语言第五讲,语句 顺序循环选择.(示例代码)

    C语言第五讲,语句 顺序循环选择. 一丶语句的简明了解 我们知道,在编写C语言程序的时候,代码是顺序执行的. 从上往下执行. 但是我们可以控制流程的. 在控制之前,我们要先熟悉什么是语句. 相比大家学 ...

  5. 易语言html规则分析,易语言算法原理浅析【一】(示例代码)

    注: 如果你看完了下面的文章.就来试试这个KeyGenMe吧,相信你能有所收获. 一.文章开头首先我们要贴上一段易语言代码,并且编译这段代码,从汇编角度分析易语言程序编译后,易语言算法在汇编中的实现过 ...

  6. 谁的饭量大 c语言编程,c语言第一章第一节 认识变量(示例代码)

    声明:本人大一新生,闲着无聊..写写c语言教程..菜鸟一枚..大神勿喷!!! 接下来我们都用dev来进行编译..vc++太古老了,没提示功能,不好上手,并且老是出毛病..vs太大了,编个c不至于,运行 ...

  7. matlab 复合辛普森公式,matlab中如何用复合辛普森公式求二重积分?

    function q=DblSimpson(f,a,A,b,B,m,n) if(m==1 && n==1)           %辛普森公式 q=((B-b)*(A-a)/9)*(su ...

  8. 复化梯形公式的c语言程序,复化梯形公式的原与实现毕业论文.doc

    复化梯形公式的原与实现毕业论文 目录 摘要-----------------------------4 1前言 ----------------------------5 2 复化梯形公式的提出背景- ...

  9. c语言程序如何首行缩进,什么叫代码缩进

    框住N行代码 按TAB键 这样代码有层次感 if (n>0) { //缩进写代码 xxxxxx } 什么是代码的缩进格式?是关于C语言.就是源程序的书写格式,看上去可以更清楚.比如 if(a&g ...

最新文章

  1. max_semi_space_size 设置值与实际值不一致的原因分析
  2. python代码示例下载-43个Python代码打包下载
  3. codeforces 935E Fafa and Ancient Mathematics 语法树、动态规划
  4. micropython flask_在Python的Flask框架中实现单元测试的教程
  5. 聚合丁苯橡胶(SSBR)行业调研报告 - 市场现状分析与发展前景预测
  6. 谈朋友圈——周围的朋友们
  7. 数模学习——灰色系统理论
  8. 唯众高职人工智能技术应用专业解决方案
  9. 3D建模软件有哪些?
  10. css中怎么设置字体加粗,css怎么把字体加粗加大
  11. 计算机网络八大性能指标
  12. Proof of Stake-股权证明 系列3
  13. 我叫mt4服务器注册 满了,我叫MT4注册上限怎么办 人数上限解决办法
  14. 零件加工 贪心 题解
  15. 百度api使用:文字识别(OCR)、长图文字识别、姓名识别
  16. 尽量把OAuth2.0的原理讲透透的
  17. 【软件部署】Linux系统yum方式安装Jenkins
  18. MWC 2017小结:各家新机缺乏创新,5G落地尚需时日
  19. 人生最曼妙的风景,竟是内心的淡定与从容——杨绛
  20. YTU 2438: 三人三鬼

热门文章

  1. 最新的爱心代码已就绪 发射成功 速来领取啦
  2. 递归获取翻页数据(TAPD接口实战)
  3. 定义一个存储过程,以员工工号为参数,修改该员工的工资,若该员工属于10部门,则工资增加150 若属于20号部门,工资加200,若属于30部门,工资加250 若其它部门,则加300
  4. 根据ip地址获取相关区域信息
  5. 跨域问题-Refused to display in a frame because it set ‘X-Frame-Options‘ to ‘SAMEORIGIN‘
  6. 20210519: 人脸识别-人脸口罩数据
  7. PDMan 拥有版本控制的版本
  8. C盘用户文件夹里找不到AppData?
  9. python pycurl_简单谈谈Python的pycurl模块
  10. java 打印对象所有属性_输出打印某个对象所有属性及属性值