实验三 利用欧拉法、梯形数法和二阶显示Adams法对RLC串联电路的仿真.docx

实验三 利用欧拉法、梯形数法和二阶显示Adams法对RLC串联电路的仿真.docx

  1. 1、本文档共6页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多

实验三 利用欧拉法、梯形数法和二阶显示

Adams法对RLC串联电路的仿真

一、实验目的

熟悉MATLAB的工作环境;

掌握在MATLAB命令窗口调试运行程序;

掌握M文件编写规则及在MATLAB命令窗口运行程序;

掌握利用数值积分法构造离散模型的方法。

二、实验内容

1、连续系统模型微分方程

传递函数

U(s) 1

G(s)? c ?

U(s) LCs2?RCs?1

2、离散系统模型

1、欧拉法

前向欧拉法

后向欧拉法

2、梯形法

3、二阶显示Adams

3、MATLAB程序

function[]=RLC(R,L,C,Us,t,T)

R=10;L=0.01;C=1.0e-6;Us=1;t=0.01;

T=5.0e-5;

NNN=fix(t/T);%计算离散时间序列长度

%解析解

tad=R/(2*L);W=sqrt(1/(L*C)-(R/(2*L))^2);

fork=1:1:NNN

y(k)=Us*(1-exp(-tad*(k-1)*T)*(cos(W*(k-1)*T)

+sin(W*(k-1)*T)*tad/W));

end

%系统状态方程系数矩阵

AA

=

[-R/L-1/L;1/C0];

BB

=

[1/L;0];

CC

=

[01];

Nr

=

2;%状态变量数

%前向欧拉法

fori=1:1:Nr%状态变量初值

xx(1:Nr,1)=0;

end

fork=1:NNN

xx(1:Nr,k+1)= xx(1:Nr,k)+(AA*xx(1:Nr,k)+BB)*T;

% XX0=xx(1:Nr,k);

%xx(1:Nr,k+1)=XX1;

end

%后向欧拉法

fori=1:1:Nr%状态变量初值

xxx(1:Nr,1)=0;

end

EE=[10;01];%单位矩阵AA1=inv(EE-AA*T);

fork=1:NNN

xxx(1:Nr,k+1)=AA1*(xxx(1:Nr,k)+BB*T);

% XX0=xxx(1:Nr,k);

end

%梯形法

fori=1:1:Nr%状态变量初值

xxxx(1:Nr,1)=0;end

EE=[10;01];%单位矩阵

AA1=inv(EE-AA*T/2);

fork=1:NNN

xxxx(1:Nr,k+1) = AA1*( xxxx(1:Nr,k) +AA*xxxx(1:Nr,k)*T/2);

% XX0=xxxx(1:Nr,k);end

%二阶显示Adams法

AA1=(EE-AA*T/2);

fori=1:1:Nr%状态变量初值

xxxxx(1:Nr,1)=0;end

EE=[10;01];%单位矩阵

fork=1:2%梯形法起步计算

xxxxx(1:Nr,k+1) = AA1*(xxxxx(1:Nr,k) +AA*xxxxx(1:Nr,k)*T/2);

% XX0=xxxxx(1:Nr,k);end

fork=3:NNN%二阶显示Adams法计算

Fk

=

23*(AA*xxxxx(1:Nr,k)+BB);

Fk1

=

-16*(AA*xxxxx(1:Nr,k-1)+BB);

Fk2

=

5*(AA*xxxxx(1:Nr,k-2)+BB);

xxxxx(1:Nr,k+1)=xxxxx(1:Nr,k)+(Fk+Fk1+Fk2)*T/12;end

fork=1:1:NNN

y1(k)

=

CC*xx(1:Nr,k);

y2(k)

=

CC*xxx(1:Nr,k);

y3(k)

=

CC*xxxx(1:Nr,k);

y4(k)

=

CC*xxxxx(1:Nr,k);

end

fork=1:1:NNNtt(k)=(k-1)*T;

BB*T +

BB*T +

endsubplot(2,2,1),plot(tt,y,b,tt,y1,r)title(前向欧拉法)subplot(2,2,2),plot(tt,y,b,tt,y2,r)title(后向欧拉法)subplot(2,2,3),plot(tt,y,b,tt,y3,r)title(梯形法)subplot(2,2,4),plot(tt,y,b,tt,y4,r)title(二阶显式前Adams法)

4、MATLAB仿真曲线(T取不同值)

T=1.0e-4

T=1.0e-5

25X101 前向欧拉法 后向欧应法

2

5

。!

| \lll

| II

1_5

1

-5

-10 ,

-10 , 。

。 0_005

文档评论(0)

gujianqitan + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档