(二)Tiki-taka算法(TTA)求解无人机三维路径规划研究(MATLAB)

2023-12-02 22:15

本文主要是介绍(二)Tiki-taka算法(TTA)求解无人机三维路径规划研究(MATLAB),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、无人机模型简介:

单个无人机三维路径规划问题及其建模_IT猿手的博客-CSDN博客

参考文献:

[1]胡观凯,钟建华,李永正,黎万洪.基于IPSO-GA算法的无人机三维路径规划[J].现代电子技术,2023,46(07):115-120

二、Tiki-taka算法(TTA)简介

极致攻守算法(Tiki-Taka Algorithm,TTA)由Mohd Fadzil Faisae Ab. Rashid于2020年提出,该算法受tiki-taka 足球风格的短传、球员定位和保持控球的特点所启发。其旨在控制控球权并利用其战术优势击败对手,TTA算法新颖高效。单目标应用:Tiki-taka算法(TTA)求解太阳能光伏模型MATLAB_IT猿手的博客-CSDN博客

参考文献:

[1]Ab. Rashid, M.F.F. (2021), "Tiki-taka algorithm: a novel metaheuristic inspired by football playing style", Engineering Computations, Vol. 38 No. 1, pp. 313-343. Tiki-taka algorithm: a novel metaheuristic inspired by football playing style | Emerald Insight

[2]Zamli, Kamal Z , Kader, et al. Selective chaotic maps Tiki-Taka algorithm for the S-box generation and optimization. 

三、TTA求解无人机路径规划

(1)部分代码

close all
clear  
clc
addpath('./Algorithm/')%添加算法路径
warning off;
%% 三维路径规划模型定义
global startPos goalPos N
N=2;%待优化点的个数(可以修改)
startPos = [10, 10, 80]; %起点(可以修改)
goalPos = [80, 90, 150]; %终点(可以修改)
SearchAgents_no=30; % 种群大小(可以修改)
Function_name='F2'; %F1:随机产生地图 F2:导入固定地图
Max_iteration=50; %最大迭代次数(可以修改)
% Load details of the selected benchmark function
[lb,ub,dim,fobj]=Get_Functions_details(Function_name);
[Best_score,Best_pos,curve]=TTA(SearchAgents_no,Max_iteration,lb,ub,dim,fobj);%算法优化求解
AlgorithmName='TTA';%算法名字
figure
semilogy(curve,'Color','g','linewidth',3)
xlabel('迭代次数');
ylabel('飞行路径长度');
legend(AlgorithmName)
display(['算法得到的最优适应度: ', num2str(Best_score)]); 
Position=[Best_pos(1:dim/3); Best_pos(1+dim/3:2*(dim/3)); Best_pos(1+(2*dim/3):end)]'; %优化点的XYZ坐标(每一行是一个点)
plotFigure(Best_pos,AlgorithmName)%画最优路径

(2)部分结果

无人机飞行路径坐标:

   1.0000000e+01   1.0000000e+01   8.0000000e+011.0069761e+01   1.1125126e+01   8.0947246e+011.0158293e+01   1.2169888e+01   8.1882689e+011.0265680e+01   1.3137305e+01   8.2806728e+011.0392006e+01   1.4030396e+01   8.3719762e+011.0537355e+01   1.4852178e+01   8.4622189e+011.0701812e+01   1.5605672e+01   8.5514408e+011.0885461e+01   1.6293895e+01   8.6396818e+011.1088385e+01   1.6919866e+01   8.7269818e+011.1310670e+01   1.7486605e+01   8.8133807e+011.1552399e+01   1.7997129e+01   8.8989182e+011.1813656e+01   1.8454458e+01   8.9836344e+011.2094525e+01   1.8861610e+01   9.0675690e+011.2395092e+01   1.9221604e+01   9.1507620e+011.2715439e+01   1.9537458e+01   9.2332531e+011.3055651e+01   1.9812192e+01   9.3150824e+011.3415813e+01   2.0048823e+01   9.3962896e+011.3796008e+01   2.0250372e+01   9.4769146e+011.4196320e+01   2.0419855e+01   9.5569974e+011.4616835e+01   2.0560293e+01   9.6365777e+011.5057635e+01   2.0674704e+01   9.7156955e+011.5518805e+01   2.0766106e+01   9.7943906e+011.6000429e+01   2.0837518e+01   9.8727029e+011.6502592e+01   2.0891959e+01   9.9506723e+011.7025377e+01   2.0932448e+01   1.0028339e+021.7568869e+01   2.0962003e+01   1.0105742e+021.8133152e+01   2.0983643e+01   1.0182922e+021.8718309e+01   2.1000387e+01   1.0259918e+021.9324426e+01   2.1015253e+01   1.0336771e+021.9951587e+01   2.1031261e+01   1.0413520e+022.0599875e+01   2.1051428e+01   1.0490206e+022.1269375e+01   2.1078774e+01   1.0566867e+022.1960170e+01   2.1116317e+01   1.0643544e+022.2672346e+01   2.1167077e+01   1.0720278e+022.3405986e+01   2.1234070e+01   1.0797107e+022.4161174e+01   2.1320318e+01   1.0874071e+022.4937994e+01   2.1428837e+01   1.0951211e+022.5736532e+01   2.1562647e+01   1.1028566e+022.6556870e+01   2.1724767e+01   1.1106176e+022.7399094e+01   2.1918215e+01   1.1184082e+022.8263286e+01   2.2146009e+01   1.1262322e+022.9149532e+01   2.2411170e+01   1.1340938e+023.0057916e+01   2.2716714e+01   1.1419967e+023.0988521e+01   2.3065662e+01   1.1499452e+023.1941432e+01   2.3461032e+01   1.1579431e+023.2916733e+01   2.3905842e+01   1.1659944e+023.3914508e+01   2.4403111e+01   1.1741031e+023.4934842e+01   2.4955857e+01   1.1822733e+023.5977818e+01   2.5567101e+01   1.1905088e+023.7043521e+01   2.6239860e+01   1.1988137e+023.8132035e+01   2.6977152e+01   1.2071920e+023.9243444e+01   2.7781998e+01   1.2156476e+024.0377832e+01   2.8657415e+01   1.2241846e+024.1535284e+01   2.9606421e+01   1.2328069e+024.2715883e+01   3.0632037e+01   1.2415185e+024.3919714e+01   3.1737280e+01   1.2503234e+024.5146860e+01   3.2925169e+01   1.2592256e+024.6397407e+01   3.4198724e+01   1.2682291e+024.7671438e+01   3.5560962e+01   1.2773379e+024.8969037e+01   3.7014902e+01   1.2865559e+025.0290289e+01   3.8563563e+01   1.2958872e+025.1635278e+01   4.0209964e+01   1.3053356e+025.3004087e+01   4.1957123e+01   1.3149053e+025.4396802e+01   4.3808060e+01   1.3246002e+025.5813505e+01   4.5765792e+01   1.3344243e+025.7254282e+01   4.7833339e+01   1.3443816e+025.8719217e+01   5.0013719e+01   1.3544760e+026.0208393e+01   5.2309952e+01   1.3647116e+026.1721896e+01   5.4725054e+01   1.3750924e+026.3259808e+01   5.7262047e+01   1.3856222e+026.4822214e+01   5.9923947e+01   1.3963052e+026.6409199e+01   6.2713774e+01   1.4071453e+026.8020847e+01   6.5634547e+01   1.4181464e+026.9657241e+01   6.8689283e+01   1.4293127e+027.1318466e+01   7.1881003e+01   1.4406480e+027.3004606e+01   7.5212724e+01   1.4521563e+027.4715745e+01   7.8687466e+01   1.4638417e+027.6451968e+01   8.2308247e+01   1.4757081e+027.8213358e+01   8.6078085e+01   1.4877596e+028.0000000e+01   9.0000000e+01   1.5000000e+02

四、完整MATLAB代码

这篇关于(二)Tiki-taka算法(TTA)求解无人机三维路径规划研究(MATLAB)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/447030

相关文章

springboot+dubbo实现时间轮算法

《springboot+dubbo实现时间轮算法》时间轮是一种高效利用线程资源进行批量化调度的算法,本文主要介绍了springboot+dubbo实现时间轮算法,文中通过示例代码介绍的非常详细,对大家... 目录前言一、参数说明二、具体实现1、HashedwheelTimer2、createWheel3、n

SpringBoot实现MD5加盐算法的示例代码

《SpringBoot实现MD5加盐算法的示例代码》加盐算法是一种用于增强密码安全性的技术,本文主要介绍了SpringBoot实现MD5加盐算法的示例代码,文中通过示例代码介绍的非常详细,对大家的学习... 目录一、什么是加盐算法二、如何实现加盐算法2.1 加盐算法代码实现2.2 注册页面中进行密码加盐2.

Java时间轮调度算法的代码实现

《Java时间轮调度算法的代码实现》时间轮是一种高效的定时调度算法,主要用于管理延时任务或周期性任务,它通过一个环形数组(时间轮)和指针来实现,将大量定时任务分摊到固定的时间槽中,极大地降低了时间复杂... 目录1、简述2、时间轮的原理3. 时间轮的实现步骤3.1 定义时间槽3.2 定义时间轮3.3 使用时

Linux修改pip和conda缓存路径的几种方法

《Linux修改pip和conda缓存路径的几种方法》在Python生态中,pip和conda是两种常见的软件包管理工具,它们在安装、更新和卸载软件包时都会使用缓存来提高效率,适当地修改它们的缓存路径... 目录一、pip 和 conda 的缓存机制1. pip 的缓存机制默认缓存路径2. conda 的缓

Windows系统下如何查找JDK的安装路径

《Windows系统下如何查找JDK的安装路径》:本文主要介绍Windows系统下如何查找JDK的安装路径,文中介绍了三种方法,分别是通过命令行检查、使用verbose选项查找jre目录、以及查看... 目录一、确认是否安装了JDK二、查找路径三、另外一种方式如果很久之前安装了JDK,或者在别人的电脑上,想

Python中Windows和macOS文件路径格式不一致的解决方法

《Python中Windows和macOS文件路径格式不一致的解决方法》在Python中,Windows和macOS的文件路径字符串格式不一致主要体现在路径分隔符上,这种差异可能导致跨平台代码在处理文... 目录方法 1:使用 os.path 模块方法 2:使用 pathlib 模块(推荐)方法 3:统一使

一文教你解决Python不支持中文路径的问题

《一文教你解决Python不支持中文路径的问题》Python是一种广泛使用的高级编程语言,然而在处理包含中文字符的文件路径时,Python有时会表现出一些不友好的行为,下面小编就来为大家介绍一下具体的... 目录问题背景解决方案1. 设置正确的文件编码2. 使用pathlib模块3. 转换路径为Unicod

如何通过Golang的container/list实现LRU缓存算法

《如何通过Golang的container/list实现LRU缓存算法》文章介绍了Go语言中container/list包实现的双向链表,并探讨了如何使用链表实现LRU缓存,LRU缓存通过维护一个双向... 目录力扣:146. LRU 缓存主要结构 List 和 Element常用方法1. 初始化链表2.

MySQL9.0默认路径安装下重置root密码

《MySQL9.0默认路径安装下重置root密码》本文主要介绍了MySQL9.0默认路径安装下重置root密码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们... 目录问题描述环境描述解决方法正常模式下修改密码报错原因问题描述mysqlChina编程采用默认安装路径,

golang字符串匹配算法解读

《golang字符串匹配算法解读》文章介绍了字符串匹配算法的原理,特别是Knuth-Morris-Pratt(KMP)算法,该算法通过构建模式串的前缀表来减少匹配时的不必要的字符比较,从而提高效率,在... 目录简介KMP实现代码总结简介字符串匹配算法主要用于在一个较长的文本串中查找一个较短的字符串(称为