亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? pso.m

?? 本人編輯的標(biāo)準(zhǔn)PSO算法
?? M
字號(hào):
%PSO >> function for the PSO ALGORITHM
%
% USAGES:   1.) [fxmin, xmin, Swarm, history] = PSO(psoOptions);
%           2.) [fxmin, xmin, Swarm, history] = PSO;
%           3.) fxmin = PSO(psoOptions);
%           3.) PSO
%           etc.
%
% Arguments     : psoOptions--> A Matlab stucture containing all PSO related options. (see also: get_psoOptions)
% Return Values : [fxmin, xmin, Swarm, history]
%                     |     |       |       |_The history of the algorithm. Depicts how the function value of GBest changes over the run.
%                     |     |       |_The final Swarm. (A matrix containing co-ordinates of all particles)
%                     |     |_The co-ordinates of Best (ever) particle found during the PSO's run.
%                     |__The objective value of Best (^xmin) particle.
%
%  History        :   Author      :   JAG (Jagatpreet Singh)
%                     Created on  :   05022003 (Friday. 2nd May, 2003)
%                     Comments    :   The basic PSO algorithm.
%                     Modified on :   07102003 (Thursday. 10th July, 2003)
%                     Comments    :   It uses psoOptions structure now. More organized.
%
%                     see also: get_psoOptions


% function [fxmin, xmin, Swarm, history, mark_fGBest] = PSO(psoOptions)
%%%%%%%% Globals
global psoFlags;
global psoVars;
global psoSParameters;
global notifications;
%%%%%%% 手動(dòng)改變函數(shù)、參數(shù) %%%%%%%%%
if 1
%     clc;
    clear;
    psoOptions = get_psoOptions;
    psoOptions.Obj.fitnessfunction = 'DeJong';
    psoOptions.Obj.lb = -100;
    psoOptions.Obj.ub = 100;
    psoOptions.SParams.Vmax = 200;    
    psoOptions.Vars.SwarmSize = 50;
    psoOptions.Vars.Dim = 2;
    psoOptions.Vars.Iterations = 1000;
    psoOptions.Flags.Neighbor = 0;
    psoOptions.SParams.w_start = 0.95;
    psoOptions.SParams.w_end = 0.4;
    psoOptions.SParams.w_varyfor = 1;
end
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
GM = 0; % Global minimum (used in the stopping criterion)
ErrGoal = 1e-10; % Desired accuracy

%%%%%%% Initializations
if nargin == 0 % nargin表示輸入?yún)?shù)數(shù)目;
    psoOptions = get_psoOptions;
end

%%%%%%% For Displaying
if psoOptions.Flags.ShowViz
    global vizAxes; %Use the specified axes if using GUI or create a new global if called from command window
    vizAxes = plot(0,0, '.');
    axis([-1000 1000 -1000 1000 -1000 1000]);   %Initially set to a cube of this size
    axis square;
    grid off;
    set(vizAxes,'EraseMode','xor','MarkerSize',15); %Set it to show particles.
    pause(1);
end
%%%%%%%% End Display initialization

%%%%%%%% Initializing variables
success = 0; % Success Flag
iter = 0;   % Iterations' counter
fevals = 0; % Function evaluations' counter,迭代次數(shù)----?????

%%%%%%%% Using params,Determine the value of weight change
%%%%%%%% 速度權(quán)重變化公式 %%%%%%%%
w_start = psoOptions.SParams.w_start;   %Initial inertia weight's value
w_end = psoOptions.SParams.w_end;       %Final inertia weight
w_varyfor = floor( psoOptions.SParams.w_varyfor * psoOptions.Vars.Iterations );
% Weight change step. Defines total number of iterations for which weight is changed.
w_now = w_start;
inertdec = (w_start-w_end)/w_varyfor; %Inertia weight's change per iteration

%%%%%%%% Initialize Swarm and Velocity
SwarmSize = psoOptions.Vars.SwarmSize;
Swarm = rand(SwarmSize, psoOptions.Vars.Dim) * ...
    (psoOptions.Obj.ub-psoOptions.Obj.lb) + psoOptions.Obj.lb;
VStep = rand(SwarmSize, psoOptions.Vars.Dim);

%%%%%%%%% The objective function to optimize
fitness_function = psoOptions.Obj.fitness_function;

%%%%%%%% Find initial function values.
fSwarm = feval(fitness_function, Swarm); %目標(biāo)函數(shù)
fevals = fevals + SwarmSize; %迭代次數(shù)----?????

%%%%%%%%% Initializing the Best positions matrix and
% the corresponding function values
PBest = Swarm; %個(gè)體最優(yōu)位置
fPBest = fSwarm; %個(gè)體最優(yōu)位置的 目標(biāo)函數(shù)最優(yōu)值

% Finding best particle in initial population
[fGBest, g] = min(fSwarm); %全局目標(biāo)函數(shù)最優(yōu)值,全局最優(yōu)位置行數(shù)標(biāo)志g
lastbpf = fGBest; %標(biāo)志:歷史全局目標(biāo)函數(shù)最優(yōu)值
Best = Swarm(g,:); %Used to keep track of the Best particle ever,全局最優(yōu)位置
fBest = fGBest; %標(biāo)志:歷史全局目標(biāo)函數(shù)最優(yōu)值
history = [0, fGBest]; %?????

%%%%%%%%% 定義鄰域拓?fù)浣Y(jié)構(gòu)
if psoOptions.Flags.Neighbor
    % Define social neighborhoods for all the particles
    for i = 1:SwarmSize
        lo = mod(i-psoOptions.SParams.Nhood : i+psoOptions.SParams.Nhood , SwarmSize);
        nhood(i,:) = [lo];
    end
    nhood(find(nhood==0)) = SwarmSize; %Replace zeros with the index of last particle.
end

if psoOptions.Disp.Interval & (rem(iter, psoOptions.Disp.Interval) == 0)
    disp(sprintf('Iterations\t\t\tfGBest\t\t\tfevals'));
end
%%%%%%% 包含高斯分布的分段曲線 %%%%%%%%
w_change = Goss_w(iter,psoOptions.Vars.Iterations);
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%%                  THE  PSO  LOOP                          %%
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
while( (success == 0) & (iter <= psoOptions.Vars.Iterations-1) )
    iter = iter+1; %初值為0,從1開(kāi)始
    % Update the value of the inertia weight w
%     if (iter<=w_varyfor) & (iter > 1)
%         w_now = w_now - inertdec; %Change inertia weight
%     end
%     w_now = Goss_w(iter,psoOptions.Vars.Iterations-1);
    w_now = w_change(iter);
%     w_change(iter) = w_now; %繪圖記錄
    %%%%%%%%%%%%%%%%%% The PLAIN PSO %%%%%%%%%
    % Set GBest
    A = repmat(Swarm(g,:), SwarmSize, 1); %A , repeats the matrix X in m rows by n columns.
    B = A; %B will be nBest (best neighbor) matrix
    % use neighborhood model
    % circular neighborhood is used
    if psoOptions.Flags.Neighbor
        for i = 1:SwarmSize
            [fNBest(i), nb(i)] = min( fSwarm( find(nhood(i)) ) );
            B(i, :) = Swarm(nb(i), :);
        end
    end 
    %%%%%%% 定義粒子群平均適應(yīng)度值 %%%%%%%%%%
    f_avg = sum( fSwarm ) / SwarmSize;
    MarkSwarms = fSwarm < f_avg;
    [m,n] = size( find(MarkSwarms) );
    f_avg2 = sum( fSwarm(find(MarkSwarms)) ) / m;
    Beta(iter) = abs( fGBest-f_avg2 );
    KeepSwarms = fSwarm < f_avg2;
    ChangeSwarms = fSwarm >= f_avg2;

    % Generate Random Numbers
    R1 = rand(SwarmSize, psoOptions.Vars.Dim);
    R2 = rand(SwarmSize, psoOptions.Vars.Dim); 
    % Calculate Velocity
    if ~psoOptions.Flags.Neighbor %Normal
        VStep = w_now*VStep + psoOptions.SParams.c1*R1.*(PBest-Swarm) + psoOptions.SParams.c2*R2.*(A-Swarm);
    else %With neighborhood
        R3 = rand(SwarmSize, psoOptions.Vars.Dim); %random nos for neighborhood
        VStep = w_now*VStep + psoOptions.SParams.c1*R1.*(PBest-Swarm) + psoOptions.SParams.c2*R2.*(A-Swarm) ...
            + psoOptions.SParams.c3*R3.*(B-Swarm);
    end
    %%%%%%%%% 按ChangeSwarms變異PBest或VStep %%%%%%%%%%
    [m,n] = size( find(ChangeSwarms) );
    % VStep(find(ChangeSwarms), :) = VStep(find(ChangeSwarms), :) .* (1+0.5*rand(m, psoOptions.Vars.Dim));
    k = 0.5;
    VStep(find(ChangeSwarms), :) = VStep(find(ChangeSwarms), :) * ( 1 + 1/(1+exp( k*Beta(iter) )) );
    
    % Apply Vmax Operator for v > Vmax
    changeRows = VStep > psoOptions.SParams.Vmax;
    VStep(find(changeRows)) = psoOptions.SParams.Vmax;
    % Apply Vmax Operator for v < -Vmax
    changeRows = VStep < -psoOptions.SParams.Vmax;
    VStep(find(changeRows)) = -psoOptions.SParams.Vmax;   

    % ::UPDATE POSITIONS OF PARTICLES::
    Swarm = Swarm + psoOptions.SParams.Chi * VStep;    % Evaluate new Swarm
    
    % Apply ub Operator for Swarm > ub
    changeRows = Swarm > psoOptions.Obj.ub;
    Swarm(find(changeRows)) = psoOptions.Obj.ub;
    % Apply lb Operator for Swarm < lbp
    changeRows = Swarm < psoOptions.Obj.lb;
    Swarm(find(changeRows)) = psoOptions.Obj.lb;    
    
    fSwarm = feval(fitness_function, Swarm);
    fevals = fevals + SwarmSize;

    % Updating the best position for each particle
    changeRows = fSwarm < fPBest;
    fPBest(find(changeRows)) = fSwarm(find(changeRows));
    PBest(find(changeRows), :) = Swarm(find(changeRows), :);    

    lastbpart = PBest(g, :);
    % Updating index g
    [fGBest, g] = min(fPBest); %標(biāo)志:全局目標(biāo)函數(shù)最優(yōu)值
    mark_fGBest(iter) = min(fPBest); %保存全局最優(yōu)進(jìn)化值;
    
    V_mark(iter,:) = VStep(1,:); %第一粒, 速度變化記錄 ---------------------
    P_mark(iter,:) = Swarm(1,:); %第一粒, 粒子位置變化記錄 ---------------------
    BV_mark(iter) = VStep(g,1); %最優(yōu)粒,第一維 速度變化記錄 ---------------------
    BP_mark(iter) = Swarm(g,1); %最優(yōu)粒,第一維 粒子位置變化記錄 ---------------------

    %Update Best. Only if fitness has improved.
    if fGBest < lastbpf        
        [fBest, b] = min(fPBest); %標(biāo)志:歷史全局目標(biāo)函數(shù)最優(yōu)值
        Best = PBest(b,:);  %全局目標(biāo)函數(shù)最優(yōu)位置
    end
    %%%%%%%%% 按ChangeSwarms變異 PBest或VStep %%%%%%%%%%
%     [m,n] = size( find(ChangeSwarms) );
%     k = 0.5;
%     PBest(find(ChangeSwarms), :) = PBest(find(ChangeSwarms), :) * ( 1 + 1/(1+exp( k*Beta(iter) )) );
%     VStep(find(ChangeSwarms), :) = VStep(find(ChangeSwarms), :) * ( 1 + 1/(1+exp( k*Beta(iter) )) );

    %%OUTPUT%%
    if psoOptions.Save.Interval & (rem(iter, psoOptions.Save.Interval) == 0)
        history( (size(history,1)+1), : ) = [iter, fBest];
    end

    if psoOptions.Disp.Interval & (rem(iter, psoOptions.Disp.Interval) == 0)
        disp(sprintf('%4d\t\t\t%10f\t\t\t%5d', iter, fGBest, fevals));
    end

    if psoOptions.Flags.ShowViz
        [fworst, worst] = max(fGBest);
        DrawSwarm(Swarm, SwarmSize, iter, psoOptions.Vars.Dim, Swarm(g,:), vizAxes);
    end

    %%TERMINATION%%
    if abs(fGBest-psoOptions.Obj.GM) <= psoOptions.Vars.ErrGoal     %GBest
        success = 0;
    elseif abs(fBest-psoOptions.Obj.GM)<=psoOptions.Vars.ErrGoal    %Best
        success = 0;
    else
        lastbpf = fGBest; %To be used to find Best
    end
end
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%%                  END  OF PSO  LOOP                       %%
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
k = size(mark_fGBest);
semilogy( 1:k(2), mark_fGBest,'r:' );
figure(2);
subplot(4,1,1); semilogy( 1:k(2), mark_fGBest,'r:' ); grid on; title('The First P, 1x1'); %plot( 1:k(2), mark_fGBest,'r:');
subplot(4,1,2); plot( 1:k(2),w_change,'b:'); grid on;
subplot(4,1,3); plot( 1:k(2),V_mark(:,1),'b:'); grid on; ylabel('V');
subplot(4,1,4); plot( 1:k(2),P_mark(:,1),'b:'); grid on; ylabel('P');
figure(3);
subplot(4,1,1); semilogy( 1:k(2), mark_fGBest,'r:' ); grid on; title('The First P, 1x2'); %plot( 1:k(2), mark_fGBest,'r:');
subplot(4,1,2); plot( 1:k(2),w_change,'b:'); grid on;
subplot(4,1,3); plot( 1:k(2),V_mark(:,2),'b:'); grid on; ylabel('V');
subplot(4,1,4); plot( 1:k(2),P_mark(:,2),'b:'); grid on; ylabel('P');
figure(4);
subplot(4,1,1); semilogy( 1:k(2), mark_fGBest,'r:' ); grid on; title('The First Particle 1x3'); %plot( 1:k(2), mark_fGBest,'r:');
subplot(4,1,2); plot( 1:k(2),w_change,'b:'); grid on;
subplot(4,1,3); plot( 1:k(2),V_mark(:,3),'b:'); grid on; ylabel('V');
subplot(4,1,4); plot( 1:k(2),P_mark(:,3),'b:'); grid on; ylabel('P');

figure(5);
subplot(5,1,1); semilogy( 1:k(2), mark_fGBest,'r:' ); grid on; title('The Best particle'); %plot( 1:k(2), mark_fGBest,'r:');
subplot(5,1,2); plot( 1:k(2),w_change,'b:'); grid on;
subplot(5,1,3); plot( 1:k(2),BV_mark,'b:'); grid on; ylabel('BV');
subplot(5,1,4); plot( 1:k(2),BP_mark,'b:'); grid on; ylabel('BP');
subplot(5,1,5); plot( 1:k(2),Beta,'b:'); grid on; ylabel('Beta');
figure(6);
plot(w_change);

[fxmin, b] = min(fPBest)
xmin = PBest(b, :)
history = history(:,1);
%Comment below line to Return Swarm. Uncomment to return previous best positions.
% Swarm = PBest; %Return PBest

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一区在线视频| 婷婷中文字幕一区三区| 亚洲免费观看高清完整版在线观看| 亚洲美女免费视频| 视频精品一区二区| 国产 欧美在线| 欧美色网一区二区| 精品国产亚洲在线| 自拍偷拍国产精品| 蜜臀av性久久久久蜜臀aⅴ| 国产成人在线视频网址| 日本电影欧美片| 777午夜精品免费视频| 国产欧美日韩一区二区三区在线观看| 欧美高清在线视频| 无码av免费一区二区三区试看| 欧美成人video| 国产精品不卡在线观看| 五月婷婷激情综合网| 国产大陆亚洲精品国产| 欧美色涩在线第一页| 久久亚区不卡日本| 夜夜嗨av一区二区三区四季av| 久久91精品国产91久久小草| 91欧美激情一区二区三区成人| 日韩欧美三级在线| 亚洲免费观看在线视频| 国产精品羞羞答答xxdd| 欧美色爱综合网| 国产欧美日韩另类一区| 日韩专区欧美专区| 色婷婷综合久久久中文字幕| 久久先锋资源网| 亚洲成va人在线观看| 风间由美一区二区av101| 欧美精品777| 又紧又大又爽精品一区二区| 国产精品一线二线三线| 在线播放一区二区三区| 亚洲少妇30p| 国产高清精品网站| 日韩三级视频中文字幕| 亚洲天天做日日做天天谢日日欢| 韩国精品久久久| 91精品国产美女浴室洗澡无遮挡| 亚洲激情成人在线| 高清不卡在线观看| 精品国产乱码91久久久久久网站| 亚洲18影院在线观看| 一本色道久久综合亚洲91| 久久精品欧美日韩| 久久精品国产精品青草| 欧美片网站yy| 亚洲影院理伦片| av在线综合网| 国产精品麻豆欧美日韩ww| 黄色日韩网站视频| 日韩欧美久久久| 日本va欧美va欧美va精品| 精品婷婷伊人一区三区三| 亚洲女同ⅹxx女同tv| 岛国精品在线播放| 国产三级三级三级精品8ⅰ区| 极品少妇一区二区三区精品视频 | 中文字幕在线一区二区三区| 久久av中文字幕片| 欧美一区二区视频在线观看2020 | 中文字幕一区二区三区不卡在线| 国产91精品一区二区麻豆网站 | 国产精品自在欧美一区| 欧美大片在线观看一区二区| 久久99精品网久久| 精品久久久久久久久久久久久久久久久| 日韩高清欧美激情| 日韩免费观看高清完整版| 日韩激情视频网站| 欧美不卡视频一区| 国产精品主播直播| 国产蜜臀97一区二区三区| 国产风韵犹存在线视精品| 久久精品欧美日韩精品| 大桥未久av一区二区三区中文| 国产欧美日韩激情| 99久久精品99国产精品| 中文字幕一区二区三区不卡在线| 91理论电影在线观看| 亚洲精品国产精华液| 欧美亚洲愉拍一区二区| 婷婷开心激情综合| 日韩精品一区二| 国产精品一二三区在线| 国产91色综合久久免费分享| 国产精品久久久久久久久图文区| av中文字幕不卡| 亚洲国产成人高清精品| 91精品国产91久久综合桃花| 久久精品噜噜噜成人88aⅴ| wwww国产精品欧美| www.一区二区| 亚洲国产成人精品视频| 91精品国产麻豆国产自产在线| 国产一区二区在线观看免费| 国产精品丝袜91| 欧美性做爰猛烈叫床潮| 奇米影视一区二区三区小说| 亚洲精品一区二区三区精华液| 国产99久久久国产精品潘金 | 欧美性猛片xxxx免费看久爱| 日韩国产欧美在线视频| 久久精品视频在线免费观看| 91在线播放网址| 日韩精品福利网| 久久精品夜夜夜夜久久| 在线中文字幕一区二区| 蜜臀久久久99精品久久久久久| 国产欧美视频在线观看| 欧美在线色视频| 国产一级精品在线| 亚洲精品国产无套在线观| 日韩视频在线一区二区| 播五月开心婷婷综合| 日韩精品一卡二卡三卡四卡无卡| 国产日本欧美一区二区| 欧美色视频一区| 国产91丝袜在线播放0| 视频一区国产视频| 国产精品久久久爽爽爽麻豆色哟哟| 欧美日韩中文字幕一区| 懂色av一区二区三区免费看| 午夜精品福利一区二区三区av| 欧美激情在线免费观看| 欧美一区二区人人喊爽| 99久久精品国产网站| 国内成+人亚洲+欧美+综合在线 | 日本电影亚洲天堂一区| 激情六月婷婷久久| 亚洲综合一区在线| 久久久久久久网| 91精品国产免费久久综合| 91香蕉视频污| 国产精品系列在线观看| 亚洲va欧美va天堂v国产综合| 中文av一区二区| 日韩一级片网站| 色哟哟国产精品免费观看| 国产精品一线二线三线| 免费精品视频在线| 亚洲精品水蜜桃| 国产精品毛片久久久久久久| 精品日韩一区二区三区 | 天天综合网 天天综合色| 国产精品激情偷乱一区二区∴| 日韩免费看网站| 欧美日韩午夜影院| 色综合天天综合色综合av | 国产精品无码永久免费888| 91精品国产综合久久久久久| 91福利精品视频| 成人av小说网| 成人小视频免费在线观看| 久久99精品国产麻豆不卡| 日本欧美一区二区三区| 亚洲国产成人av| 一区二区三区在线免费播放| 中文字幕高清不卡| 国产午夜精品久久久久久久 | 国产激情视频一区二区在线观看| 日韩av中文在线观看| 亚洲国产精品一区二区久久恐怖片| 国产精品久久影院| 欧美国产精品久久| 欧美精彩视频一区二区三区| 精品成人免费观看| 精品黑人一区二区三区久久 | 蜜桃在线一区二区三区| 日韩精品电影在线观看| 视频一区欧美精品| 日韩av不卡一区二区| 午夜国产不卡在线观看视频| 亚洲一区二区五区| 亚洲一区二区视频在线观看| 亚洲综合男人的天堂| 一区二区三区四区不卡在线| 亚洲精品福利视频网站| 亚洲柠檬福利资源导航| 亚洲激情图片一区| 亚洲国产精品精华液网站| 视频一区在线视频| 美女视频黄 久久| 麻豆国产欧美日韩综合精品二区| 日本不卡中文字幕| 美国十次综合导航| 国模无码大尺度一区二区三区| 紧缚奴在线一区二区三区| 国产美女在线观看一区| 丰满白嫩尤物一区二区| 91在线观看地址| 欧美日韩小视频| 日韩精品一区二区三区三区免费 | 国产精品一区二区黑丝|