📄 select.m
字号:
% 函数 - 轮盘赌选择要交叉的个体
function Num = select(sumfitness,oldpop,gen,maxgen)
popsize = length(oldpop);
Psum = 0;
if(sumfitness ~= 0)
for i = 1:popsize
P(i) = oldpop(i).fitness/sumfitness; % 计算个体适应度值对应的选择概率
end
pick = rand(1,1)*sum(P); % 随机选取一点,落入位置即为选中个体
for i=1:popsize
if(Psum < pick)
Psum = Psum + P(i);
else
break
end
end
else
i = ceil(rand(1,1)*(popsize-1)) + 1;
end
Num = i;
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -