模拟退火算法社团划分matlab6,完全图哈密尔顿圈的遗传模拟退火算法matlab通用源程序...

完全图哈密尔顿圈的遗传模拟退火算法 matlab 通用源程序 % maxpop 给定群体规模 % pop 群体 % newpop 种群 %t0 初始温度 function [codmin,finmin]=fc0(cc,v0,t0) N=length(cc(1,:)); %定群体规模 if N50 maxpop=2*N-20; end if N0 %用模拟退火产生新的群体 pop=fc1(maxpop,pop,N,cc,v0,t); %转轮赌选择种群 f=zeros(1,maxpop); for i=1:maxpop for j=1:N-1 x=pop(i,j); y=pop(i,j+1); fo1=cc(pop(i,j),pop(i,j+1)); f(i)=f(i)+fo1; end f(i)=f(i)+cc(pop(i,1),pop(i,N)); end fmin=min(f); for i=1:maxpop if fmin==inf end if fmin~=inf|f(i)~=inf dd=fmin-f(i); end ftk(i)=exp(dd/t); end [fin1,cod]=sort(-ftk); fin=abs(fin1); %f(cod(1)) if f(cod(1))=RR); % cod newpop(i,:)=pop(cod(cod2(end)),:); end %单亲繁殖 if N32 jmax=round(N/9); end if NR1 for j=1:2:jmax+2 nn=randperm(N); x=nn(j); y=nn(j+1); if newpop(i,x)==v0|newpop(i,y)==v0 pop(i,:)=newpop(i,:); continue; end box1=newpop(i,x); newpop(i,x)=newpop(i,y); newpop(i,y)=box1; pop(i,:)=newpop(i,:); end end end %温度下降 t=t-0.1; end function pop=fc1(maxpop,pop,N,cc,v0,t) ff(N-1)=0; f=0; pop1=zeros(maxpop,N); for i=1:maxpop for j=1:N-1 x=pop(i,j); y=pop(i,j+1); ff(j)=cc(pop(i,j),pop(i,j+1)); pop1(i,:)=pop(i,:); nn=randperm(N); x=nn(1); y=nn(2); pop1=pop; if pop(i,x)==v0|pop(i,x)==v0 continue box1=pop(i,x); pop1(i,x)=pop1(i,y); pop1(i,y)=box1; end ff1(j)=cc(pop1(i,j),pop1(i,j+1)); end f=sum(ff); f1=sum(ff1); if f==inf end if f~=inf|f1~=inf dd=f-f1; end Aij=min(1,exp(dd/t)); Pacept=rand(1); if AijPacept pop(i,:)=pop1(i,:); end end

展开阅读全文

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值