资源简介
TBM弹道仿真.rar
代码片段和文件信息
%最优制导率仿真初始化参数+10*pi*rand(1)/180 坐标进行了修改
%最优制导律反TBM弹道仿真
clear all;
clear;
global signvc;
g=9.81;
pi=3.14159265;
RHO=1.225;
SONIC=343.13;
dt=0.1;
v0=7*SONIC;
h0=40000; %关机点高度
xt0=652000;
yt0=h0;
h1=80000; %再入段高度
ammax=15*g;
ae=pi/180;
thetat0=135*ae; %初始弹道倾角
vx0=v0*cos(thetat0);
vy0=v0*sin(thetat0);
t=(vy0+sqrt(vy0^2-2*g*(h1-h0)))/g; %再入段时间
xt1=xt0+vx0*t;
yt1=h0+vy0*t-0.5*g*t^2;
vx1=vx0;
vy1=vy0-g*t;
v1=sqrt(vx1^2+vy1^2);
thetat1=atan((v0*sin(thetat0)-g*t)/(v0*cos(thetat0)));%再入角
T=0:dt:t;
x1=xt0+vx0*T;
y1=h0+vy0*T-0.5*g*T.^2;
thetatz=atan((v0*sin(thetat0)-g*T)/(v0*cos(thetat0)));
%figure(1);plot(x1y1)hold on %自由段坐标变化
%figure(2);plot(Tsqrt(vx0.^2+(vy0-g*T).^2))hold on %自由段速度变化
%figure(3);plot(Tthetatz)hold on
R=6371000;
m=100;
CX=5;
d=0.1698;
i=0.5;
ae=pi/180;
thetat=abs(thetat1); %初始弹道倾角
xt=xt1;
yt=h1;
vt=v1; %初速
ptr(:1)=[xt;yt];
vm=2000;%导弹速度
headerror=0*pi/180; %指向角误差
rmx=20000;rmy=0;
pmr(:1)=[rmx;rmy];
vty=-vt*sin(thetat);%目标的速度分量
vtx=-vt*cos(thetat);
rtmx=xt-rmx;%初始弹目相对距离
rtmy=yt-rmy;
rtm=sqrt(rtmx^2+rtmy^2);
sightangle=atan(rtmy/rtmx);%视线角
leadangle=asin(vt*sin(sightangle-thetat)/vm);%指向角
vmy=vm*sin(sightangle-leadangle+headerror);%导弹的速度分量
vmx=vm*cos(sightangle-leadangle+headerror);
vtmx=vtx-vmx;
vtmy=vty-vmy;
%弹目的相对运动速度
vc=-(rtmx*vtmx+rtmy*vtmy)/rtm;
signvc=sign(vc); %vc的符号
time=0;dt=0.1;%时间和时间步长
%pvr(:1)=[time;dtheta];
%file=fopen(‘output.dat‘‘wt‘);%将数据写入文件
%循环
for k=2:4000;
if(rtm<1000)%弹目距离小于100,步长变为0.005
dt=0.001;
end
F=4.75*0.0001*vt^2*CX;
if yt>=9300
H=exp(-0.0001*yt);
end
if yt<9300
H=(1-2.1905*10^(-5*yt))^4.4;
end
XF=i*d^2*1000*H*F./g;
dvt=g*sin(thetat)-XF/m;
dthetat=-g*cos(thetat)/vt+vt*cos(thetat)/(R+yt);
dyt=-vt*sin(thetat);
dxt=R*vt*cos(thetat)/(R+yt);
vt=vt+dt*dvt;
thetat=thetat-dt*dthetat;
yt=yt+dt*dyt;
xt=xt-dt*dxt;
at=dthetat*vt;
ptr(:k)=[xt;yt];
vty=-vt*sin(thetat);%目标的速度分量
vtx=-vt*cos(thetat);
rtmx=xt-rmx;%初始弹目相对距离
rtmy=yt-rmy;
rtm=sqrt(rtmx^2+rtmy^2);
%视线角速率
dsightangle=(rtmx*vtmy-rtmy*vtmx)/(rtm^2);
%dtheta=3*vc*dsightangle/vm;%最优比例导引
dtheta=3*dsightangle;
%k1=1.45;k2=1.5;k3=0.3;k5=3;
%dtheta=k1*vc*dsightangle/(vm*(k2+k3*tgo));
the=thetat+pi; %对thetat进行修正
%dtheta=3*(vc*dsightangle+0.5*g*cos(the))/vm; %目标加速度修正项 %+不如—好!
theta=atan(vmy/vmx);
%导弹加速度
am=vm*dtheta;
%限制机动能力
if(abs(am)>ammax)
am=sign(am)*ammax;
end
%加速度分量
amy=am*cos(sightangle);
amx=-am*sin(sightangle);
amfa=am*cos(sightangle-theta);
time=time+dt;
%导弹速度
vmx=vmx+dt*amx;
vmy=vmy+dt*amy;
vm=sqrt(vmx^2+vmy^2);
%导弹位置
rmx=rmx+dt*vmx;
rmy=rmy+dt*vmy;
rm=sqrt(rmx^2+rmy^2);
pmr(:k)=[rmx;rmy];
pvr(:k)=[time;amfa/g];
%弹目相对位移
rtmx=xt-rmx;
rtmy=yt-rmy;
%
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
文件 4044 2008-11-05 17:27 最优制导律反TBM弹道仿真\zytbm.m
目录 0 2008-11-05 17:27 最优制导律反TBM弹道仿真
----------- --------- ---------- ----- ----
4044 2
相关资源
- DCT.zip
- thy-3f.sch
- 《高级语言程序设计一》实践指导.
- 2012-0158.zip
- 云计算服务安全能力要求-最终版(
- SINS_GPS组合导航系统Kalman滤波仿真研究
- PhotoshopCC2019入门到精通视频教程.txt
- 计算机组网技术入门
- 6.27_0.crx
- 组态王6.55授权.zip
- myMvcApp.rar
- 1.0.4.0.zip
- zw_汇编程序.zip
- zw_VisualAssistX10[1].6.1850注册.zip
- zw_student_manager.zip
- zw_web_login2_20120510.zip
- zw_BFS.zip
- zw_BP.zip
- zw_DAC0832在proteus中的仿真.zip
- zw_20161207121006693.zip
- zw_-PCB布线.zip
- zw_PID程序.zip
- zw_FlappyBird飞翔的小鸟.zip
- zw_KalmanDemoCode.zip
- zw_MD5.zip
- zw_DataSet.zip
- zw_20161011205249419.zip
- zw_hough变化.zip
- zw_ise_vivado_2014_2.zip
- zw_netboard3p.zip
评论
共有 条评论