2020-09-22

请问这个寻优结果的初始值是2?是怎么设定的呢?

figure(1)
hold on;
lb=1;
ub=2;
ezplot('sin(10*pi*X)/X',[lb,ub]);
xlabel('自变量/X');
ylabel('函数值/Y');

NIND=40;%种群大小
MAXGEN=20;%最大遗传代数
PRECI=20;%个体长度
GGAP=0.95;%代沟
px=0.7;%交叉概率
pm=0.01;%变异概率
trace1=zeros(2,MAXGEN);%寻优结果的初始值
FieldD=[PRECI;lb;ub;1;0;1;1];%区域描述器
Chrom=crtbp(NIND,PRECI)%创建任意离散随机种群
%%优化
gen=0;
X=bs2rv(Chrom,FieldD);
ObjV=sin(10*pi*X)./X;
count=0;

while gen<MAXGEN
    FitnV=ranking(ObjV);
    SelCh=select('sus',Chrom,FitnV,GGAP);%选择
    SelCh=recombin('xovsp',SelCh,px);%重组
    SelCh=mut(SelCh,pm);%变异
    X=bs2rv(SelCh,FieldD);%子代个体的十进制转换
    ObjVSel=sin(10*pi*X)./X;%计算子代的目标函数值
    [Chrom,ObjV]=reins(Chrom,SelCh,1,1,ObjV,ObjVSel);%重插入子代到父代,得到新的种群
    X=bs2rv(Chrom,FieldD);
    gen=gen+1;%代计数器增加
    %获取每代的最优解及其序号,Y为最优解,I为个体的序号
    [Y,I]=min(ObjV)
    trace1(1,gen)=X(I)%记下每代的最优值
    trace1(2,gen)=Y%记下每代的最优值
end

plot(t1,t2,'bo');%画出每代的最优点
grid on;
ObjV
plot(X,ObjV,'b*');%画出最后一代的种群
hold off

figure(2);
plot(1:MAXGEN,trace1(2,:));
grid on
xlabel('遗传代数')
ylabel('解的变化')
title('进化过程')
bestY=trace1(2,end)
bestX=trace1(1,end)
fprintf(['最优解:\nX=',num2str(bestX),'\nY=',num2str(bestY),'\n']);

疑问### 疑问 trace1(1,gen)=X(I)%记下每代的最优值,为什么是2行20列,而不是一行20列呢?奇怪!



评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值