一、神经网络-支持向量机

支持向量机(Support Vector Machine)是Cortes和Vapnik于1995年首先提出的,它在解决小样本、非线性及高维模式识别中表现出许多特有的优势,并能够推广应用到函数拟合等其他机器学习问题中。 1 数学部分 1.1 二维空间 【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_matlab【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_matlab_02【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_matlab_03【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_预测模型_04【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_matlab_05【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_matlab_06【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_预测模型_07【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_matlab_02【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_matlab_09【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_预测模型_04【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_matlab_11【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_预测模型_04【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_matlab_13【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_matlab_02【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_matlab_15【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_matlab_16【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_matlab_17【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_预测模型_04​ 2 算法部分 【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_matlab_19【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_预测模型_20【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_matlab_21【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_matlab_06【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_预测模型_23【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_matlab_16【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_预测模型_25

二、萤火虫算法

算法基本思想描述如下:在群体中,每个萤火虫个体被随机分布在目标函数定义的空间中,初始阶段,所有的萤火虫都具有相同的荧光素值和动态决策半径。其中,每个萤火虫个体根据来自动态决策半径内所有邻居萤火虫信号的强弱来决定其移动的方向。萤火虫的动态决策半径会随着在它范围内萤火虫个体的数目而变化,每个萤火虫的荧光素也会随着决策半径内萤火虫个体的数目而改变。萤火虫群优化算法是无记忆的,无需目标函数的全局信息和梯度信息,具有计算速度快,调节参数少,易于实现等特点。萤火虫进化过程中,每次迭代都由萤火虫的部署(初始化)荧光素更新阶段移动概率计算阶段位置更新阶段邻域范围更新阶段五个部分组成,现分别介绍如下:

1、萤火虫的部署(初始化)

【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_matlab_26
【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_matlab_27
【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_预测模型_28
【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_matlab_292、荧光素更新阶段

【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_预测模型_30
【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_matlab_27
【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_matlab_32
【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_预测模型_333、移动概率计算阶段

【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_matlab_34
【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_预测模型_33
【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_matlab_36
【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_matlab_274、位置更新阶段

【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_预测模型_38
【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_matlab_29
【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_matlab_32
【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_matlab_295、邻域范围更新阶段

【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_预测模型_42

​三、代码

% The Whale Optimization Algorithm
function [Leader_score,Leader_pos,Convergence_curve]=WOA(SearchAgents_no,Max_iter,lb,ub,dim,fobj)

% initialize position vector and score for the leader
Leader_pos=zeros(1,dim);
Leader_score=inf; %change this to -inf for maximization problems


%Initialize the positions of search agents
% Positions=initialization(SearchAgents_no,dim,ub,lb);
Positions=ceil(rand(SearchAgents_no,dim).*(ub-lb)+lb);

Convergence_curve=zeros(1,Max_iter);

t=0;% Loop counter

% Main loop
while t<Max_iter
    for i=1:size(Positions,1)
        
        % Return back the search agents that go beyond the boundaries of the search space
        Flag4ub=Positions(i,:)>ub;
        Flag4lb=Positions(i,:)<lb;
        Positions(i,:)=(Positions(i,:).*(~(Flag4ub+Flag4lb)))+ub.*Flag4ub+lb.*Flag4lb;
        
        % Calculate objective function for each search agent
        fitness=fobj(Positions(i,:));
        
        % Update the leader
        if fitness<Leader_score % Change this to > for maximization problem
            Leader_score=fitness; % Update alpha
            Leader_pos=Positions(i,:);
        end
        
    end
    
    a=2-t*((2)/Max_iter); % a decreases linearly fron 2 to 0 in Eq. (2.3)
    
    % a2 linearly dicreases from -1 to -2 to calculate t in Eq. (3.12)
    a2=-1+t*((-1)/Max_iter);
    
    % Update the Position of search agents 
    for i=1:size(Positions,1)
        r1=rand(); % r1 is a random number in [0,1]
        r2=rand(); % r2 is a random number in [0,1]
        
        A=2*a*r1-a;  % Eq. (2.3) in the paper
        C=2*r2;      % Eq. (2.4) in the paper
        
        
        b=1;               %  parameters in Eq. (2.5)
        l=(a2-1)*rand+1;   %  parameters in Eq. (2.5)
        
        p = rand();        % p in Eq. (2.6)
        
        for j=1:size(Positions,2)
            
            if p<0.5   
                if abs(A)>=1
                    rand_leader_index = floor(SearchAgents_no*rand()+1);
                    X_rand = Positions(rand_leader_index, :);
                    D_X_rand=abs(C*X_rand(j)-Positions(i,j)); % Eq. (2.7)
                    Positions(i,j)=X_rand(j)-A*D_X_rand;      % Eq. (2.8)
                    
                elseif abs(A)<1
                    D_Leader=abs(C*Leader_pos(j)-Positions(i,j)); % Eq. (2.1)
                    Positions(i,j)=Leader_pos(j)-A*D_Leader;      % Eq. (2.2)
                end
                
            elseif p>=0.5
              
                distance2Leader=abs(Leader_pos(j)-Positions(i,j));
                % Eq. (2.5)
                Positions(i,j)=distance2Leader*exp(b.*l).*cos(l.*2*pi)+Leader_pos(j);
                
            end
            
        end
    end
    t=t+1;
    Convergence_curve(t)=Leader_score;
%     [t Leader_score]
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.
  • 74.
  • 75.
  • 76.
  • 77.
  • 78.
  • 79.
  • 80.
  • 81.
  • 82.
  • 83.
  • 84.

【SVM预测】基于萤火虫算法改进SVM算法实现数据分类matlab源码_matlab_43

5.参考文献:

书籍《MATLAB神经网络43个案例分析》