|
|
EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
$ D2 O* y0 H! T6 ?2 o! W
合作协同进化(Cooperative Coevolution)是求解大规模优化算法一个有效的方法。将大规模问题分解为一组组较小的子问题。而合作协同进化的关键是分解策略。
0 E( [; Z& w' F/ x# e% c' m
- {. ~ d5 ^1 u% H( @- NNSGA2算法是一种多目标遗传算法。此文章是随机固定分组的合作协同进化利用NSGA2来优化。
9 V/ J4 w# R" G5 T% {7 Z2 u0 N8 M1 r8 v5 @9 E# D
比如有12个决策变量,我们固定随机优化3个决策变量,那么就将决策变量分成了4组。
; n# Q8 L( i; x$ q& h M
: P; _/ K: P% ], ?) YMATLAB主函数代码:8 v0 z* k4 U5 \5 K' X5 T) g2 t
+ F) |0 X5 S2 B5 h6 f
- %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
- clc;
- clear;
- global pop
- pop = 500; %种群数量
- gen = 2; %迭代次数
- global M
- M = 2; %目标数量
- Dim=22; %搜索空间维数(未知数个数)
- sub_dim= 2 ;
- global min_range
- global max_range
- min_range = zeros(1, Dim); %下界
- max_range = ones(1,Dim); %上界
- %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
- divide_datasets();
- global answer
- answer=cell(M,3);
- Dim_index = ones(1,1)*(1:Dim+4);
- %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
- chromosome = initialize_variables(pop, M, Dim, min_range, max_range, Dim_index);
- chromosome = non_domination_sort_mod(chromosome, M, Dim);
- result = 1;
- while gen ~= 0
- subgroup = rnd_divide(Dim, sub_dim);
- for i=1:length(subgroup)
- subgroup{i}(sub_dim+1)=Dim+1;
- subgroup{i}(sub_dim+2)=Dim+2;
- subgroup{i}(sub_dim+3)=Dim+3;
- subgroup{i}(sub_dim+4)=Dim+4;
- [temp_chromosome] = nsga2(chromosome(:,subgroup{i}), sub_dim, subgroup{i});
- chromosome(:,subgroup{i}(1:sub_dim)) = temp_chromosome(:,1:sub_dim);
- end
- chromosome = nsga2(chromosome, Dim, Dim_index);
- chromosome = non_domination_sort_mod(chromosome, M, Dim);
- gen =gen - 1;
- progress = 1-gen/10
- end
- plot(chromosome(:,Dim + 1),chromosome(:,Dim + 2),'*');
- xlabel('f_1'); ylabel('f_2');
- title('Pareto Optimal Front');
8 h4 j+ s/ P0 x) {# J- X
: V& P/ Y+ G7 }, H
- ]% f& H( {: s% d3 Q随机分组代码:& q1 z/ E3 t; B- J5 ]) S: q- w: Q
! a# s# l, E- u5 r2 D4 V: s/ Y- % random grouping
- function group = rnd_divide(dim, subdim)
- dim_rand = randperm(dim);
- group = {};
- for i = 1:subdim:dim
- index = dim_rand(i:i+subdim-1);
- group = {group{1:end} index};
- end
- end
& S: n+ {3 J! ~9 N9 b4 Q+ S5 x
+ q/ e) I" W, `: F( k& `$ W& b; P6 | G O
6 E+ h6 q* k. N8 Q: e* P
3 X5 f) K5 \# X. \, y$ \7 A' I" Y% ^9 ^: \8 }0 N# k
|
|