mutation.m
来自「一种基于matlab的遗传规划编码程序 其中包含交叉和变异的代码」· M 代码 · 共 25 行
M
25 行
function tree = mutation(treein,symbols);
tree = treein;
nn = [length(symbols{1}), length(symbols{2})];
% Mutate one node
[n,v] = tree_size(tree);
i = v(floor(rand*(length(v))+1));
if i<(tree.maxsize+1)/2 & rand<0.5,
[tree.nodetyp(i) tree.node(i)] = tree_genrndsymb(abs(rand-0.5),nn);
else
while tree.node(i)==treein.node(i) & tree.nodetyp(i)==treein.nodetyp(i),
[tree.nodetyp(i) tree.node(i)] = tree_genrndsymb(abs(rand-0.5),nn);
end
end
return
%------------------------------------------------------------------
function [nodetyp,node] = tree_genrndsymb(p0,nn)
if rand<p0,
nodetyp = 2;
else
nodetyp = 1;
end
node = floor(nn(nodetyp)*rand)+1;
return
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?