五个城市的TSP问题(MATLAB程序)

五个城市的TSP问题(MATLAB程序)

ID:38597872

大小:39.00 KB

页数:4页

时间:2019-06-15

五个城市的TSP问题(MATLAB程序)_第1页
五个城市的TSP问题(MATLAB程序)_第2页
五个城市的TSP问题(MATLAB程序)_第3页
五个城市的TSP问题(MATLAB程序)_第4页
资源描述:

《五个城市的TSP问题(MATLAB程序)》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库

1、五个城市的TSP问题,距离矩阵为:01015621008139158020156132005291550设初始温度为10,结束温度为0.7,则程序如下:d=[0,10,15,6,2;10,0,8,13,9;15,8,0,20,15;6,13,20,0,5;2,9,15,5,0];t0=10;tf=0.7;[f,T]=trp(d,t0,tf)得结果如下:f=43T=14523MATLAB的程序如下:function[f,T]=trp(d,t0,tf)%f为目标函数最优值,T为最优路线,d为距离矩阵,t0为初始温度,tf为结束温度[m,n]=size(d);L=100*n;t=t0;pi0=1

2、:n;min_f=0;fork=1:(n-1)min_f=min_f+d(pi0(k),pi0(k+1));endmin_f=min_f+d(pi0(n),pi0(1));p_min=pi0;whilet>tffork=1:Lkk=rand;[d_f,pi_1]=exchange_2(pi0,d);r_r=rand;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

3、),pi0(1));ifmin_f>f_tempmin_f=f_temp;p_min=pi0;endt=0.87*t;endf=min_f;T=p_min;%下面的函数产生新解function[d_f,pi_r]=exchange_2(pi0,d)[m,n]=size(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>1fo

4、rk=1:u-1pi_1(k)=pi0(k);endendifv>u+1fork=1:(v-u-1)pi_1(u+k)=pi0(v-k);endendifv

5、sed_f=d(pi0(u-1),pi0(v))+d(pi0(u),pi0(1))-d(pi0(u-1),pi0(u))-d(pi0(v),pi0(1));fork=(u+1):nd_f=d_f+d(pi0(k),pi0(k-1));endfork=(u+1):nd_f=d_f-d(pi0(k-1),pi0(k));endendpi_r=pi_1;

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。