1、狼群算法中的狼种类分为以下几种:

头狼、探狼、猛狼。

2、猎物分配规则:论功行赏,先强后弱。

3、狼群算法的主体构成:探狼游走、头狼召唤、猛狼围攻3种智能行为,“胜者为王”的头狼角逐规则和“优胜劣汰”的狼群更新规则。

Step1:在解空间中随机初始化狼群的空间坐标,依据目标函数值的大小角逐出人工头狼。

Step2:探狼开始随机游走搜索猎物,若发现某个位置的目标函数值大于头狼的目标函数值,将更新头狼位置,同时头狼发出召唤行为;若未发现,探狼继续游走直到达到最大游走次数,头狼在原本的位置发出召唤行为。

Step3:听到头狼召唤的猛狼以较大的步长快速向头狼奔袭,若奔袭途中猛狼的目标函数值大于头狼的目标函数值,则将对头狼位置进行更新;否则,猛狼将继续奔袭直到进入围攻范围。

Step4:靠近头狼的猛狼将联合探狼对猎物(把头狼位置视为猎物)进行围捕,围捕过程中若其他人工狼的目标函数值大于头狼的目标函数值,则对头狼位置进行更新,直到捕获猎物。

Step5:淘汰狼群中目标函数值较小的人工狼,并在解空间中随机生成新的人工狼,实现狼群的更新。

Step6:最后判断头狼的目标函数值是否达到精度要求或算法是否达到最大迭代次数。

4、人工狼群算法的若干规则:

(1)头狼产生规则

         初始解空间中,具有最优目标函数值的人工狼即为头狼;在迭代过程中,将每次迭代后最优狼的目标函数值与前一代中头狼的值进行比较,若更优则对头狼位置进行更新,若此时存在多匹的情况,则随机选一匹成为头狼。头狼不执行3种智能行为,直接进入迭代,直到被其他更强的人工狼代替。

(2)游走行为

        除头狼外最佳的S_sum匹人工狼视为探狼,S_sum随机取[n/α+1,n/α]之间的整数,α为探狼比例因子。

        计算探狼【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法的目标函数值【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_02,若【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_02大于头狼的目标函数值【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_04,则更新头狼,【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_04=【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_02,探狼【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法替代头狼发起召唤;若【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_04>【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_02,则探狼向h个方向分别前进一步(游走步长为【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_10),记录没前进一步后的函数数值,那么向第p(p=1,2,...,h)个方向前进后探狼【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法所处的位置为

                                          【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_12                             (1)

此时,探狼所在位置的函数值为【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_13,选择函数值最大且大于当前函数值【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_02的方向前进一步,更新探狼的状态【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_15,重复以上的游走行为直到某匹探狼的函数值【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_02>【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_04或游走次数达到最大游走次数【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_18

        由于每匹探狼的猎物搜寻方式存在差异,因此【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_19的取值不同,实际中可取【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_20之间的随机整数,【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_19越大探狼搜寻得越精细但同时速度也相对较慢。

(3)召唤行为

        头狼召集【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_22匹猛狼向头狼所在位置迅速靠拢,其中【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_23;猛狼以相对较大的奔袭步长【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_24快速逼近头狼所在位置。

 猛狼【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_26次迭代时,所处的位置为

【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_27                       (2)

式中,【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_28为第k代头狼的位置。式(2)由2部分组成,前者为人工狼的当前位置,后者表示人工狼逐渐向头狼位置聚集的趋势。

奔袭途中,若猛狼【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法的函数值【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_30,则【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_31,该猛狼转化为头狼并发起召唤行为;若【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_32,则猛狼【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法继续奔袭直到其与头狼【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_34之间的距离【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_35小于【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_36时转入围攻行为。

设待寻优的变量取值范围为[lb,ub],则判定距离【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_36可由式(3)估计得到

【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_38                                                                 (3)

式中,【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_39为距离判定因子,【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_39增大会加速算法收敛,但【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_39过大会使得人工狼很难进入围攻行为。

(4)围攻行为

经过奔袭的猛狼距离猎物较近,此时猛狼要联合探狼对猎物进行围攻,并捕获。这里将离猎物最近的狼,即头狼的位置视为猎物移动的位置。具体地,对于第k代狼群,设猎物的位置为【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_42,则狼群的围攻行为可用方程(4)表示:

【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_43                                     (4)

式中,为[]间均匀分布的随机数;为人工狼执行围攻行为时的攻击步长。若实施围攻行为后人工狼感知到的猎物气味儿浓度大于其原位置状态所感知的猎物气味浓度,若不然,人工狼位置不变。

5、人工狼群算法的具体步骤:

step1 数值初始化;

step2 选取头狼以及S_num匹人工狼为探狼并执行游走行为,直到某只探狼【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法侦察到底额猎物气味浓度大于头狼所感知的猎物气味浓度【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_02或达到最大游走次数,结转step3;

step3 人工猛狼根据式(2)向猎物奔袭,若途中猛狼感知的猎物气味浓度【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_30,则【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_31,替代头狼发起召唤行为;若【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_32,则人工猛狼继续奔袭直至【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_49,结转step4;

step4 按式(4)对参与围攻行为的人工狼的位置进行更新,执行围攻行为;

step5 按“胜者为王”的头狼产生规则对头狼位置进行更新;再按照“强者生存”的狼群更新机制进行群体更新;

step6 判断是否达到优化精度要求或最大迭代次数,否则,结转到step2。

 
 
%% 清空环境
clc
clear all
close all
%% 数据初始化
 
%下载数据
load  HeightData
% HeightData=HeightData';
%网格划分
LevelGrid=10;
PortGrid=21;
 
%起点终点网格点
starty=6;starth=1;
endy=8;endh=21;
m=1;
%算法参数
PopNumber=10;         %种群个数
BestFitness=[];    %最佳个体
iter=100;
%初始信息素
pheromone=ones(21,21,21);
dim=PortGrid*2;
Max_iter=100;
ub=PortGrid;
lb=1;
% initialize alpha, beta, and delta_pos
Alpha_pos=zeros(1,dim);
Alpha_score=inf; %change this to -inf for maximization problems
Beta_pos=zeros(1,dim);
Beta_score=inf; %change this to -inf for maximization problems
Delta_pos=zeros(1,dim);
Delta_score=inf; %change this to -inf for maximization problems
%Initialize the path of search agents
Convergence_curve=zeros(1,Max_iter);
l=0;% Loop counter
%% 初始搜索路径
[path,pheromone]=searchpath(PopNumber,LevelGrid,PortGrid,pheromone, ...
    HeightData,starty,starth,endy,endh);
fitness=CacuFit(path);                          %适应度计算
[bestfitness,bestindex]=min(fitness);           %最佳适应度
bestpath=path(bestindex,:);                     %最佳路径
BestFitness=[BestFitness;bestfitness];          %适应度值记录
 
l=0;% Loop counter
 
% Main loop
while l<Max_iter
    for i=1:size(path,1)
        
        % Return back the search agents that go beyond the boundaries of the search space
        Flag4ub=path(i,:)>ub;
        Flag4lb=path(i,:)<lb;
        path(i,:)=round((path(i,:).*(~(Flag4ub+Flag4lb)))+ub.*Flag4ub+lb.*Flag4lb);
        
        % Calculate objective function for each search agent
        fitness=CacuFit(path(i,:));
        
        % Update Alpha, Beta, and Delta
        if fitness<Alpha_score
            Alpha_score=fitness; % Update alpha
            Alpha_pos=path(i,:);
        end
        
        if fitness>Alpha_score && fitness<Beta_score
            Beta_score=fitness; % Update beta
            Beta_pos=path(i,:);
        end
        
end
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.
  • 26.
  • 27.
  • 28.
  • 29.
  • 30.
  • 31.
  • 32.
  • 33.
  • 34.
  • 35.
  • 36.
  • 37.
  • 38.
  • 39.
  • 40.
  • 41.
  • 42.
  • 43.
  • 44.
  • 45.
  • 46.
  • 47.
  • 48.
  • 49.
  • 50.
  • 51.
  • 52.
  • 53.
  • 54.
  • 55.
  • 56.
  • 57.
  • 58.
  • 59.
  • 60.
  • 61.
  • 62.
  • 63.
  • 64.
  • 65.
  • 66.
  • 67.
  • 68.
  • 69.
  • 70.
  • 71.
  • 72.
  • 73.

【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_50

【无人机路径规划】基于狼群算法求解无人机三维路径规划matlab源码_狼群算法_51