【无人机任务分配】基于合同网协议(CNP算法)实现多无人机具有时间窗口和优先级约束任务分配及跟踪问题附matlab代码

简介: 【无人机任务分配】基于合同网协议(CNP算法)实现多无人机具有时间窗口和优先级约束任务分配及跟踪问题附matlab代码

✅作者简介:热爱科研的Matlab仿真开发者,修心和技术同步精进,matlab项目合作可私信。

🍎个人主页:Matlab科研工作室

🍊个人信条:格物致知。

更多Matlab仿真内容点击👇

智能优化算法       神经网络预测       雷达通信      无线传感器        电力系统

信号处理              图像处理               路径规划       元胞自动机        无人机

⛄ 内容介绍

多无人机(UAV)协同目标分配是多无人机协同控制的重要内容之一.针对多无人机协同侦察问题,以提高作战效能,减少侦察代价和任务完成时间为目的进行目标分配,首先建立了目标分配问题的数学模型,在初始分配的基础上,使用基于合同网的目标分配方法,引入负载系数参数,最后通过迭代执行买卖合同与交换合同实现了任务的合理分配.由仿真结果可知,算法能够给出很好的优化效果的分配方案,并有很好的可扩展性.

⛄ 部分代码

close all

clc

clear


num_of_UAVs = 4; % Num of UAVs


time = 1300;


sample_arena = Arena; % Arena , If you want to change the position of static

% Obstacals, see the Arena.m file


tic


for i = 1:1:num_of_UAVs

   % Initialising the Aircrafts

   UAVs(i) = AirCraft(i);

 

end


sample_mission_planner = mission_planner(UAVs, sample_arena );

% Initialising the mission planner

N = time/sample_arena.dt;

%% Loop run


for i = 1:1:N

   

   for k = 1:1:numel(UAVs)

       

       sample_mission_planner.plan_mission(k);

       % Plan mission i,e get the new command for the k-th UAV

   end

   

   for k = 1:1:numel(UAVs)

       UAVs(k).move(sample_arena);

       % move the K-th UAV

   end

 

end



toc


%% Figure plots

figure (1);

hold on


for l = 1:1:num_of_UAVs

   X = [UAVs(l).vehical_log.x];

   Y = [UAVs(l).vehical_log.y];

   Z = [UAVs(l).vehical_log.h];

   if l == 1

       plot3(X , Y , Z,'y')

   elseif l == 2

       plot3(X , Y , Z , 'g')

          elseif l == 3

       plot3(X , Y , Z , 'k')

       

   end

   

end


buildings = sample_arena.static_object;


plot([buildings(1).x;buildings(2).x;buildings(3).x;buildings(4).x] , [buildings(1).y;buildings(2).y;buildings(3).y;buildings(4).y],'bs')

title('Routes followed by the UAVs','fontsize',7)

xlabel('East(m)')

ylabel('North(m)')

zlabel('Up(m)')


axis equal , grid on , pause(0.01),hold off;



for i = 1:1:num_of_UAVs

   

   speed(:,i) = [UAVs(i).vehical_log.v];

   heading(:,i) = [UAVs(i).vehical_log.psi];

   bank(:,i) = [UAVs(i).vehical_log.phi];

   height(:,i) = [UAVs(i).vehical_log.h];

   

end


figure(3)

subplot(4,1,1)

plot(speed)

xlabel('time (s)','fontsize',7)

ylabel('air spd (m/s)','fontsize',7)


subplot(4,1,2)

plot(heading)

xlabel('time (s)','fontsize',7)

ylabel('hdg (deg)','fontsize',7)



subplot(4,1,3)

plot(bank)

xlabel('time (s); solid - actual; dotted - cmd','fontsize',7)

ylabel('bank (deg)','fontsize',7)

subplot(4,1,4)

plot(height)

xlabel('time (s)','fontsize',7)

ylabel('ht (m)','fontsize',7)

⛄ 运行结果

⛄ 参考文献

[1] 钱艳平, 夏洁, 刘天宇. 基于合同网的无人机协同目标分配方法[C]// CNKI. CNKI, 2011:5.

[2] 常松, 贾子彦. 基于改进合同网算法的多无人机任务分配[J]. 物联网技术, 2020, 10(5):3.

⛳️ 代码获取关注我

❤️部分理论引用网络文献,若有侵权联系博主删除
❤️ 关注我领取海量matlab电子书和数学建模资料


相关文章
|
7天前
|
缓存 算法 物联网
基于AODV和leach协议的自组网络平台matlab仿真,对比吞吐量,负荷,丢包率,剩余节点个数,节点消耗能量
本系统基于MATLAB 2017b,对AODV与LEACH自组网进行了升级仿真,新增运动节点路由测试,修正丢包率统计。AODV是一种按需路由协议,结合DSDV和DSR,支持动态路由。程序包含参数设置、消息收发等功能模块,通过GUI界面配置节点数量、仿真时间和路由协议等参数,并计算网络性能指标。 该代码实现了节点能量管理、簇头选举、路由发现等功能,并统计了网络性能指标。
131 73
|
2月前
|
算法
基于COPE协议的网络RLNCBR算法matlab性能仿真
摘要: 本研究聚焦于COPE协议与RLNCBR算法(MATLAB仿真),整合随机线性网络编码与背压路由,优化网络编码技术以增强吞吐量与鲁棒性。实验在MATLAB2022a下执行,展示了平均传输次数随接收节点数(N:2-10)变化趋势(P1=...=Pn=0.08,重传间隔100Δt)。COPE协议利用编码机会提高效率,而RLNCBR算法动态调整路径,减少拥塞,提升成功率。数学模型与仿真实验证实算法有效提升网络性能,降低时延与丢包率。[总计239字符]
|
1月前
|
机器人
MATLAB - 使用 TOPP-RA 求解器生成带约束条件的时间最优轨迹
MATLAB - 使用 TOPP-RA 求解器生成带约束条件的时间最优轨迹
40 0
|
2月前
|
前端开发 API Swift
什么是MATLAB许可证协议书
React Native和Swift在多个方面存在显著的区别,这些区别主要体现在它们的技术基础、应用场景、性能特点、开发效率以及社区支持等方面。
25 2
|
2月前
|
算法 物联网
机会路由MORE协议的matlab性能仿真
摘要: 本研究关注无线Mesh网络中的机会路由与网络编码融合技术,特别是MORE协议。机会路由利用无线特性提高网络效率,而网络编码提升网络吞吐量。在分析这两项技术的基础上,提出改进MORE的方案,优化节点选择和路径测量,以增强网络性能。使用MATLAB2022a进行仿真验证。尽管MORE独立于MAC层并应用线性网络编码,但其ETX测量可能存在不准确问题,该问题成为改进的重点。
|
2月前
|
传感器 算法
基于LEACH路由协议的网络性能matlab仿真,包括数据量,能耗,存活节点
- **LEACH协议**在WSN中通过分簇减少能耗,普通节点向最近簇头发送数据,簇头融合后发送给基站。本项目研究LEACH在不同初始能量、数据包及控制包长度条件下的网络性能,如剩余节点、能量、接收数据量和累计接收量。
|
3月前
|
传感器 存储 算法
无线传感网路由VBF协议和DBR协议的MATLAB性能仿真
**摘要** 本文档介绍了在MATLAB2022a中对无线传感器网络的VBF和DBR路由协议的性能仿真,关注能量消耗和节点存活。VBF协议依赖于节点的地理位置,采用源路由,通过矢量和管道路由选择转发节点。DBR协议则运用贪婪算法,基于节点深度决定转发,以接近水面为目标。两协议均考虑能量效率,但可能导致不必要的数据传输和重复分组,需优化策略以适应密集网络和避免冲突。
|
传感器 机器学习/深度学习 算法
用于异构无线传感器网络的多聚合器多链路由协议(Matlab代码实现)
用于异构无线传感器网络的多聚合器多链路由协议(Matlab代码实现)
|
11月前
|
传感器 算法
基于LEACH路由协议的网络性能matlab仿真,包括数据量,能耗,存活节点
基于LEACH路由协议的网络性能matlab仿真,包括数据量,能耗,存活节点
|
机器学习/深度学习 传感器 安全
单播和多播的反应路由协议需求距离向量(AODV)matlab实现
单播和多播的反应路由协议需求距离向量(AODV)matlab实现

热门文章

最新文章