(一)项目实践-利用Appdesigner制作目标跟踪仿真软件

前言

        本博客有一个专栏用来介绍有关MATLAB中的Appdesigner的操作以及使用,本文是为了深化读者对于基础知识运用而写作的。博主结合雷达目标kalman滤波跟踪过程,将参数交互、仿真结果展示等知识点结合软件制作过程进行了讲解和分析,设计了一个目标跟踪仿真软件。目的是便于读者理解,同时读者可以根据上传的源代码资源进行拓展开发,对应程序可在资源界面下载。


一、软件页面设计

        软件界面由三大部分组成,第一部分是参数输入部分,第二部分是仿真按钮,第三部分是图形展示部分,具体的软件界面设计如图所示。

        参数输入部分的主要作用是实现数据的交互,获取软件界面输入的参数信息,主要分为仿真参数、目标参数雷达参数三个部分,如图所示。

        仿真按钮部分是程序触发部分,包含了目标跟踪的程序主体。通过点击仿真按钮,程序开始运行,仿真结束之后将仿真结果输出到图形展示框。

        图形展示部分是最终的结果展示部分,主要包括目标及雷达位置示意图和跟踪误差示意图。通过函数将图形绘制到软件界面,实现结果的传递。具体的细节可以参照另外一篇文章:

(五)Appdesigner-参数输入及绘图操作icon-default.png?t=N7T8https://blog.csdn.net/h320130/article/details/139999767?spm=1001.2014.3001.5502

二、仿真部分

(一)参数输入

   仿真代码如下:

%参数设定

nf = app.target5.Value;%噪声强度
N_sim = app.sim.Value;
Ts = app.sim1.Value;
N_step = N_sim/Ts; %仿真时长

radar_location=[app.rad1.Value app.rad2.Value];

H = [1 0 0 0
    0 0 1 0];

ini_state(:,1) = [app.target1.Value, app.target2.Value, app.target3.Value, app.target4.Value]';

R_base = [app.rad3.Value 0;
                0  app.rad4.Value]; 

P_0 = 4500*eye(4);

(二)绘图部分

  仿真代码如下:

%%
cla(app.UIAxes);
cla(app.UIAxes_2);
%绘图部分           
plot(app.UIAxes,X_real{1}(1,:),X_real{1}(3,:),"LineWidth",1.2);
app.UIAxes.NextPlot = 'add';
scatter(app.UIAxes,radar_location(1,1),radar_location(1,2),80,'v','filled');
legend(app.UIAxes,'\fontname{宋体}目标','\fontname{宋体}雷达');
xlabel(app.UIAxes,'x(m)','FontSize',14,'Fontname', 'Times New Roman'),ylabel(app.UIAxes,'y(m)','FontSize',14,'Fontname', 'Times New Roman')
set(app.UIAxes,'FontSize',14,'Fontname', 'Times New Roman');
ymax = max([X_real{1}(3,:),radar_location(2)])+3000;
ymin = min([X_real{1}(3,:),radar_location(2)])-3000;
xmax = max([X_real{1}(1,:),radar_location(1)])+3000;
xmin = min([X_real{1}(1,:),radar_location(1)])-3000;
xlim(app.UIAxes,[xmin, xmax]);
ylim(app.UIAxes,[ymin, ymax]);

plot(app.UIAxes_2,RMSE_each_node_sum',"LineWidth",1);
xlabel(app.UIAxes_2,'Frame','FontSize',14,'Fontname', 'Times New Roman'),ylabel(app.UIAxes_2,'RMSE(m)','FontSize',14,'Fontname', 'Times New Roman')
set(app.UIAxes_2,'FontSize',14,'Fontname', 'Times New Roman');

(三)目标追踪程序

  仿真代码如下:

for k = 1:N_step
                % 目标运动设定
                X_real= cell(N_R,1);
                X_real(:) = {zeros(nx,N_step+1)};
                for i = 1:N_Q
                    X_real{i} = track(app,ini_state(:,i),nx,N_step,F,Q);
                end
                % 目标的估计值为一个确定的数,真实值满足其均值的高斯分布
                %%
                %量测信息更新
                Z_real = cell(N_R,N_Q);
                for i = 1:N_R
                    for j = 1:N_Q
                        Z_real{i,j}= H*X_real{j};%其中h为量测更新函数,为N_R*N_Q的元组
                    end
                end
                z_real_every = cell(N_R,N_step);
                z_real_every(:) = {zeros(nz,1)};

                R = cell(N_R,N_step);
                R(:) = {zeros(nz,nz)};

                %% 最优滤波过程(有反馈)
                X_each_node = cell(N_R,N_step);
                X_each_node(:) = {zeros(nx,1)};

                P_each_node = cell(N_R,N_step);
                P_each_node(:) = {zeros(nx,nx)};

                for i1 = 1:N_R
                    X_each_node{i1,N_initial} = ini_state(:,1) + sqrt(P_0)*randn(nx,1);
                    P_each_node{i1,N_initial} = P_0; 
                    RMSE_each_node(i1,N_initial) = (X_each_node{i1,N_initial}(1,1)-X_real{1}(1,N_initial))^2 + (X_each_node{i1,N_initial}(3,1)-X_real{1}(3,N_initial))^2;
                end

                for i = N_initial+1: N_step
                    for i1 = 1:N_R

                        R_mid = R_cal(app,R_base,X_real{1}(:,i),radar_location(i1,:)');


                        R{i1,i} = R_mid;

                        z_real_every{i1,i} = Z_real{i1,1}(:,i) + R_mid*randn(nz,1);


                        [X_each_node{i1,i},P_each_node{i1,i}] = KF(app,X_each_node{i1,i-1},z_real_every{i1,i},P_each_node{i1,i-1},R_mid,F,Q,H);

                        RMSE_each_node(i1,i) = (X_each_node{i1,i}(1,1)-X_real{1}(1,i))^2 + (X_each_node{i1,i}(3,1)-X_real{1}(3,i))^2;

                    end
                end
                RMSE_each_node_sum = RMSE_each_node + RMSE_each_node_sum;
end

            RMSE_each_node_sum = sqrt(RMSE_each_node_sum/N_step);

 


总结

        以上就是今天要讲的内容,本文简单介绍了一种目标追踪仿真软件的设计方法,涉及软件界面设计、图形展示、参数输入等知识,读者可以在博主设计的软件基础上进行修改,实现自己所需的功能。

  • 29
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值