欢迎来到天天文库
浏览记录
ID:41170827
大小:23.50 KB
页数:3页
时间:2019-08-18
《模拟退火算法求解TSP问题Matlab源码》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库。
1、function[f,T]=TSPSA(d,t0,tf)%TSP问题(货郎担问题,旅行商问题)的模拟退火算法通用malab源程序%f目标最优值,T最优路线,d距离矩阵,t0初始温度,tf结束温度[m,n]=size(d);L=100*n;t=t0;pi0=1:n;min_f=0;fork=1:n-1min_f=min_f+d(pi0(k),pi0(k+1));endmin_f=min_f+d(pi0(n),pi0(1));p_min=pi0;whilet>tffork=1:L;kk=rand;[d_f,pi_1]=exchange_2(pi0,d);r_r=ra
2、nd;ifd_f<0pi0=pi_1;elseifexp(d_f/t)>r_rpi0=pi_1;elsepi0=pi0;endendf_temp=0;fork=1:n-1f_temp=f_temp+d(pi0(k),pi0(k+1));endf_temp=f_temp+d(pi0(n),pi0(1));ifmin_f>f_tempmin_f=f_temp;p_min=pi0;endt=0.87*t;endf=min_f;T=p_min;%aiwa要调用的子程序,用于产生新解function[d_f,pi_r]=exchange_2(pi0,d)[m,n]=siz
3、e(d);clearm;u=rand;u=u*(n-2);u=round(u);ifu<2u=2;endifu>n-2u=n-2;endv=rand;v=v*(n-u+1);v=round(v);ifv<1v=1;endv=u+v;ifv>nv=n;endpi_1(u)=pi0(v);pi_1(v)=pi0(u);ifu>1fork=1:u-1pi_1(k)=pi0(k);endendifv>(u+1)fork=1:v-u-1pi_1(u+k)=pi0(v-k);endendifv4、ifv5、),pi0(k-1));endfork=(u+1):nd_f=d_f-d(pi0(k-1),pi0(k));endendpi_r=pi_1;
4、ifv5、),pi0(k-1));endfork=(u+1):nd_f=d_f-d(pi0(k-1),pi0(k));endendpi_r=pi_1;
5、),pi0(k-1));endfork=(u+1):nd_f=d_f-d(pi0(k-1),pi0(k));endendpi_r=pi_1;
此文档下载收益归作者所有