第3-1章 续系统数值积分法仿真Matlab编程.ppt

第3-1章 续系统数值积分法仿真Matlab编程.ppt

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

第三章 Matlab编程(数值积分法仿真);function [t,y]=w_DigiInteSimu(tstart,tstop,h,x0,u0,cnty,InteMethod,StateModel,OutputFile, ControlFile) % 函数功能:用数值积分法仿真 % 输入参数:tstart, tstop,h 分别是起始时间、结束时间和仿真步长,是标量 % x0,u0是状态、输入的初值,都是列向量 % cnty是输出变量的个数 % InteMethod时数值积分方法,可以是EUL ,RK2,RK4 % StateModel是状态模型的文件名 % ControlFile是控制作用的文件名 % OutputFile是系统输出的文件名 % 输出参数:t是仿真结果的时间序列 % y是仿真结果系统的输出序列;function [t,y]=w_DigiInteSimu(tstart,tstop,h,x0,u0,cnty,InteMethod,StateModel,OutputFile,ControlFile) t=[tstart:h:tstop];%t数一个行序列 cntt=size(t,2);%返回列数 y=zeros(cnty,cntt);%构造一个空矩阵,用来存储结果 y0=eval([OutputFile,(tstart,x0,u0)]);%计算初始输出 y(:,1)=y0’;%将cury作为输出的第1列 curx=x0; %当前一步的x curu=u0; %当前一步的u cury=y0; %当前一步的y for i=1:1:cntt-1 curu=eval([ControlFile,(t(i),h,curx,curu,cury)]);%计算控制时传递的参数:当前时间,步长,当前状态和输出 curx=w_StepIntegral(t(i),h,curx,curu,InteMethod,StateModel);%单步积分运算 cury=eval([OutputFile,(t(i),curx,curu)]);%计算输出 y(:,i+1)=cury‘;%将输出加入到输出序列里 end;function NewX=w_StepIntegral(curt,h,curx,curu,InteMethod,StateModel) %函数功能:单步积分运算,与模型方程有关 % 输入参数:curt是当前时间,h是数值积分步长 % curx,curu分别是当前的状态和控制向量 % InteMethod是积分算法,字符串类型,可以取EUL,RK2,RK4 % StateModel是状态模型文件名称,字符串类型 % 输出参数:NewX是这一步计算的新的状态向量;function NewX=w_StepIntegral(curt,h,curx,curu,InteMethod,StateModel); if InteMethod == RK4 k1=eval([StateModel,(curt,curx,curu)]); k2=eval([StateModel,(curt+0.5*h,curx+0.5*h*k1,curu)]); k3=eval([StateModel,(curt+0.5*h,curx+0.5*h*k2,curu)]); k4=eval([StateModel,(curt+h,curx+h*k3,curu)]); NewX=curx+h*(k1+2*k2+2*k3+k4)/6; elseif InteMethod == RK2 k1=eval([StateModel,(curt,curx,curu)]); k2=eval([StateModel,(curt+h,curx+h*k1,curu)]); NewX=curx+0.5*h*(k1+k2); else %欧拉法EUL Qk=eval([StateModel,(curt,curx,curu)]);%eval用来执行一个函数,传递函数名和函数的输入参数 NewX=curx+h*Qk; end;函数w_DigiInteSimu和w_StepIntegral构造了一个数值积分法仿真的框架,并不涉及具体的系统。 具体的系统由StateModel,ControlFile,OutputFile参个参数决定,实际上就是三个函数文件名,这三个函数输入输

文档评论(0)

173****7830 + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档