ImageVerifierCode 换一换
格式:DOCX , 页数:20 ,大小:335.37KB ,
资源ID:8853081      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/8853081.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(系统仿真大作业飞机剖析.docx)为本站会员(b****8)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

系统仿真大作业飞机剖析.docx

1、系统仿真大作业飞机剖析作业要求系统仿真作业:观测站(O点)为测得的某航班数据,当飞机到达某位置P时开始对飞机的相关数据进行记录,在位置P处时间t记为0,当飞机到观测站的距离达到最短时飞机所处的位置记为M点,飞机在t时刻所处的位置与观测站O点的连线到直线OM的夹角记为(t)。附表一给出了观测站某次记录数据:A列为记录时间t,其间隔为0.001s;B列为飞机飞行过程中t时刻飞机相对于P点的距离S(t);C列给出了飞机t时刻角度(t)的理论值theta_theory(参考输入),D列给出了观测站实际上观测到的飞机在t时刻时角度(t)的观测值theta_observation;E列给出了当把C列数据t

2、heta_theory作为某标准二阶伺服系统G(s)的输入信号时该标准二阶伺服系统的输出值theta_output。作业要求:(1)将附表一中的数据导入matlab工作空间,使各列数据都能作为变量使用。(2)试根据表格中的数据使用MATLAB完成以下问题1.根据A、B两列数据确定飞机飞行时的理论运行轨迹和飞机的飞行速度;2.根据A、B、C三列数据确定当飞机到达M点时观测站O到M点的距离。(3)设计标准二阶伺服系统G(s),要求:1确定合适的值,其单位阶跃响应的性能指标满足:系统的超调量%介于4.5%8.0%之间2.使用MATLAB仿真确定参数n,使得:当把C列数据theta_theory作为该

3、二阶伺服系统的输入时,系统的输出尽可能的接近E列所给出的theta_output。求出系统传递函数参数。3.将C列theta_theory作为设计好的标准二阶伺服系统的输入信号,计算输出相对于输入的相对误差;作出输出随时间变化的曲线,以及相对误差随时间变化的曲线。(4)在上述设计好的伺服系统中加入合适的干扰信号和适当的非线性环节,使得当把C列数据theta_theory作为输入信号时系统的输出尽可能接近D列数据(t)的观测值theta_observatuon)。试:1.确定干扰信号和非线性环节的相关参数,并画出系统simulink模型。2.画出系统的输出随时间变化的曲线。3.画出输出相对于输入

4、theta_theory的相对误差随时间变化的曲线,以及输出相对于D列数据(t)的观测值theta_observatuon)的相对误差曲线。一、完成内容(1)将附表一中的数据导入matlab工作空间,使各列数据都能作为变量使用。 编写脚本readxlsx.m,读取各列数据的值:%将附表一中的数据导入matlab工作空间,使各列数据都能作为变量使用typ,desc,fmt = xlsfinfo(finaltest.xlsx)%读取表格文件的信息t = xlsread(finaltest.xlsx,1,A2:A143002);%读取excel文件中第一个工作表中A列的全部数据,用数组t()保存数据

5、s = xlsread(finaltest.xlsx,1,B2:B143002);%读取excel文件中第一个工作表中B列的全部数据,用数组s()保存数据theta_theory = xlsread(finaltest.xlsx,1,C2:C143002);%读取excel文件中第一个工作表中C列的全部数据,用数组theta_theory()保存数据theta_observation = xlsread(finaltest.xlsx,1,D2:D143002);%读取excel文件中第一个工作表中D列的全部数据,用数组theta_observation()保存数据theta_output =

6、xlsread(finaltest.xlsx,1,E2:E143002);%读取excel文件中第一个工作表中E列的全部数据,用数组theta_output()保存数据format long;%设定显示格式为long,因为表格中数据有9位有效值运行结果:依次可取得各数据的值 t(2)ans = 1.000000000000000e-03 s(2)ans = 0.140000000000000 theta_theory(2)ans = -1.520837232808838theta_observation(2)ans = -7.075789556117257e-05 theta_output(2

7、)ans =-7.573799703386787e-05(2) 试根据表格中的数据使用MATLAB完成以下问题根据A、B两列数据确定飞机飞行时的理论运行轨迹和飞机的飞行速度;根据A、B、C三列数据确定当飞机到达M点时观测站O到M点的距离。编写脚本文件plane_rate.mplot(t,s);grid on;%作飞机位移关于时间t的图象,可看出飞机是匀速运动i=2:143001;rate(i)=s(i)./t(i);%求运行轨迹中各点的速率,可看出运动速率恒为140m/si=1:143001;abs_theta_theory(i) = abs(theta_theory(i);%取观察站测得角度

8、的绝对值min_theta_theory k = min(abs_theta_theory);%当飞机到达M点时,观察站测得角度应为最小角,故求得此最小角度时%对应的时间t(k)distance_OM = s(k)*cot(abs_theta_theory(1)%当时间为t(k)时,对应的位移为s(k),tan(theta)=PM/OM%其中PM=s(k),theta=theta_theory的最初的值,由此可求得OM的距离运行结果: planeratedistance_OM = 5.000030000000002e+02故飞机飞行速率为140m/s,OM间距离为500m。(3)设计标准二阶伺

9、服系统G(s) 解:1确定合适的值,其单位阶跃响应的性能指标满足:系统的超调量%介于4.5%8.0%之间因为%=,使%介于4.5%8.0%之间则可取=0.68,此时%= %5.4280251339488,满足要求。 2.使用MATLAB仿真确定参数n,使得:当把C列数据theta_theory作为该二阶伺服系统的输入时,系统的输出尽可能的接近E列所给出的theta_output。求出系统传递函数参数。用simulink设计标准二阶伺服系统,其中w的值待定设计的框图如下:再编写脚本文件,如下:for n=1:20;%取不同的w值时,求输出的theta_output sim(erjiesifuxi

10、tong);%运行simulink中的框图文件, %获得输出的的p_theta_output值,为一个长度为143001的列向量 for j=1:143001; d_value(j)=abs(p_theta_output(j)-theta_output(j); %求每组输出的p_theta_output与理论值的差 end abs_dif(n)=sum(d_value);%取误差和,存到向量ads_dif中,再依次比较向量中 %的值,当取最小值时说明p_theta_output与理论值最接近,此时 %的w值即为标准w值end 当w取120时,得到的abs_dif各值为: abs_difabs_

11、dif = 1.0e+03 * Columns 1 through 4 6.019400510911621 2.739540882427722 1.644088863073810 1.100263457041429 Columns 5 through 8 0.773241725337181 0.549005514111091 0.384051198965172 0.256977609508468 Columns 9 through 12.0791* Columns 13 through 16 0.109981064663135 0.149590657196720 0.183*7703 0.21

12、3275684364825 Columns 17 through 20 0.238998060855472 0.261540130309759 0.281422897899948 0.299065677805618由数据可看出,当w=11时,取得最小的差值,再取w=1012之间的数,求得其中最小差值。得到的simulink框图为:3.将C列theta_theory作为设计好的标准二阶伺服系统的输入信号,计算输出相对于输入的相对误差;作出输出随时间变化的曲线,以及相对误差随时间变化的曲线。作输出变化曲线和相对误差曲线求相对误差的脚本文件为:sim(erjiesifuxitong);%运行二阶伺服

13、系统for i=1:143001;abs_dif(i)=abs(p_theta_output(i)-theta_theory(i);%求输出p_theta_output的绝对误差relative_error(i)=abs_dif(i)/abs(theta_theory(i);%求输出的相对误差End作输出变化曲线为:当作相对误差曲线时,发现为如下图所示:接近于冲激函数。因为时间轴选用的过宽,无法看出细节,故用axis(0,2,0,2)指令截取相应的曲线,就能看清楚了:a)时间轴为02时plot(t,relative_error);axis(0,2,0,1)b)时间轴为270时,图形几乎无变化,

14、即相对误差近似为0.c)时间轴为7073时,plot(t,relative_error);axis(70,73,0,40)由图可看出相对误差变化图在7073之间有一个猛增的过程d)时间轴为73143时,plot(t,relative_error);axis(73,143,0,1)分析图可看出,在70s73s之间,相对误差有一个显著的冲激式上升过程,分析原因:相对误差的求取公式为而theta_theory的值在70s73s时近似取到了零,而theta_theory在分母上,故此时相对误差值会变得极大。当theta_theory取值远离零值时,由于绝对误差接近于0,故相对误差也接近于0。而在0s2

15、S区间可看到一个明显的振荡过程,分析原因:因为系统为二阶系统,输入的起始阶段响应会有超调量,但当经过一段时间系统稳定后,就不会再发生振荡。4.在上述设计好的伺服系统中加入合适的干扰信号和适当的非线性环节,使得当把C列数据theta_theory作为输入信号时系统的输出尽可能接近D列数据(t)的观测值theta_observation)。试:1)确定干扰信号和非线性环节的相关参数,并画出系统simulink模型。作出theta_theory的时间曲线和theta_observation的时间曲线如图,蓝色为theta_theory的时间曲线,红色为theta_observation的时间曲线。编

16、写M文件,使每选定一种非线性环节或添加一种干扰都能得到对应的曲线,再将对应曲线与给定的观察曲线作比较,即能找到对应的参数。Thetaobservation.m%plot(t,theta_theory);hold on;%作理论曲线plot(t,theta_observation,r);hold on;%作观察所得曲线sim(erjiesifuxitong);%运行仿真框图plot(t,p_theta_output);%作仿真结果曲线hold on;首先在前向通道中加一个死区非线性环节,得到如下图所示波形:此时输出曲线与观察曲线相差较大,故不正确。再将死区非线性放到回路外:得到曲线:输出曲线在中

17、间停滞区与观察曲线近似,经过多次尝试,发现将死区的起始与截止参数改为如下所示:此时能得到与观察曲线非线性弯曲部分重合的曲线:此即找到非线性环节。为找到干扰环节,我作出了极大的努力。首先将观察曲线与输出曲线作对比,如下图:为求出合适的干扰信号使蓝色曲线接近红色曲线,先将两曲线作差(i=1:143001;diff(i)=p_theta_output(i)-theta_observation(i);plot(t,diff);)得到如下曲线:由图可看出,差值diff的时间曲线近似为一个正弦波形,故应输入一个正弦形状的干扰信号。为求出干扰信号的具体差值,我再对diff进行一次线性拟合,编写函数文件如下:

18、function fun_sin = xianxingnihe(x,t)for i=1:143001 fun_sin(i)=x(1)+x(2)*sin(4.5*pi/143*t(i)+x(3)*pi);end再输入指令行x,resnorm=lsqcurvefit(xianxingnihe,x0,t,diff),即对diff曲线进行输入为时间t的线性拟合,拟合结果如下:x = 0.000135938260289 -0.049733591012013.020*resnorm = 2.238947129380221再作出拟合所得曲线与真实的diff曲线作比较:plot(t,diff);hold on

19、;plot(t,xianxingnihe(x,t),r);得到图为:由图可知,拟合结果近似接近于原曲线,因为原曲线幅值较小,故将此拟合结果作为干扰信号输入。输入系统框图如图:其中正弦波参数参照拟合曲线采用,如下输出此框图的结果为:由图可看出,两条曲线近似重合,故此系统即为标准的输入系统。2)画出系统的输出随时间变化的曲线。sim(erjiesifuxitong);%运行仿真框图plot(t,p_theta_output);%作仿真结果曲线3)画出输出相对于输入theta_theory的相对误差随时间变化的曲线,以及输出相对于D列数据(t)的观测值theta_observatuon)的相对误差曲

20、线。输出相对于输入theta_theory的相对误差随时间变化的曲线:i=1:143001;diff_a(i)=abs(p_theta_output(i)-theta_theory(i)./abs(theta_theory(i);plot(t,diff_a);hold on;axis(0 143 0 1);输出相对于D列数据(t)的观测值theta_observatuon)的相对误差曲线i=1:143001;diff_a(i)=abs(p_theta_output(i)-theta_observation(i)./abs(theta_observation(i);plot(t,diff_a);hold on;axis(0 143 0 0.1);图形分析:i.在曲线的起始阶段相对误差有极大的震荡过程,因为在此阶段系统还没有稳定,系统输出值具有较大变动。ii.在曲线的70s80s范围内有一个相对误差猛增的过程,分析原因应为此阶段theta_observation的值无限接近于0,故相除得到误差无限大。iii.在曲线其他阶段,相对误差保持在0.01以下,故认为设计的系统满足题设要求。

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1