TSP禁忌搜索程序

上传人:ba****u6 文档编号:184020582 上传时间:2023-02-01 格式:DOCX 页数:4 大小:8.99KB
返回 下载 相关 举报
TSP禁忌搜索程序_第1页
第1页 / 共4页
TSP禁忌搜索程序_第2页
第2页 / 共4页
TSP禁忌搜索程序_第3页
第3页 / 共4页
点击查看更多>>
资源描述
function TspTSclear;city31=1304 2312;3639 1315;4177 2244;3712 1399;3488 1535;3326 1556;3238 1229;4196 1004;4312 790;4386 570;3007 1970;2562 1756;2788 1491;2381 1676;1332 695;3715 1678;3918 2179;4061 2370;3780 2212;3676 2578;4029 2838;4263 2931;3429 1908;3507 2367;3394 2643;3439 3201;2935 3240;3140 3550;2545 2357;2778 2826;2370 2975;for i=1:31for j=1:31DL31(i,j)=(city31(i,1)-city31(j,1)A2+(city31(i,2)-city31(j,2)A2)A0.5;endenddislist=DL31;Clist=city31;CityNum=size(dislist,2);Tlist=zeros(CityNum);% 禁忌表(tabu list)cl=80;%保留前cl个最好候选解bsf=Inf;tl=ceil(CityNumA0.5);%禁忌长度(tabu length)l1=160;%候选解(candidate),不大于n*(n-1)/2(全部领域解个数)S0=randperm(CityNum);S=S0;BSF=S0;Si=zeros(l1,CityNum);StopL=80*CityNum;p=1;clf;figure(1);stop = uicontrol(style,toggle,string,stop, background,white);tic;while (pCityNum*(CityNum)/2disp(候选解个数,不大于n*(n-1)/2(全部领域解个数)!系统自动退出!);l1=(CityNum*(CityNum)/2)A.5;break;endArrS(p)=F(dislist,S);i=1;A=zeros(l1,2);while i=l1M=CityNum*rand(1,2);M=ceil(M);if M(1)=M(2)m1=max(M(1),M(2);m2=min(M(1),M(2);A(i,1)=m1;A(i,2)=m2;if i=1isdel=0;elsefor j=1:i-1if A(i,1)=A(j,1)&A(i,2)=A(j,2) isdel=1;break;elseisdel=0;endendendif isdeli=i+1;else i=i;endelse i=i;endendCL=Inf*ones(cl,4);for i=1:l1Si(i,:)=S;Si(i,A(i,1),A(i,2)=S(A(i,2),A(i,1);F(i)=F(dislist,Si(i,:);if i=clCL(i,2)=F(i);CL(i,1)=i;CL(i,3)=S(A(i,1);CL(i,4)=S(A(i,2);elsefor j=1:clif F(i)CL(j,2)CL(j,2)=F(i);CL(j,1)=i;CL(j,3)=S(A(i,1);CL(j,4)=S(A(i,2);break;endendendendif CL(1,2)bsf%藐视准则(aspiration criterion)bsf=CL(1,2);S=Si(CL(1,1),:);BSF=S;for m=1:CityNumfor n=1:CityNumif Tlist(m,n)=0Tlist(m,n)=Tlist(m,n)-1;endendendTlist(CL(1,3),CL(1,4)=tl;elsefor i=1:clif Tlist(CL(i,3),CL(i,4)=0S=Si(CL(i,1),:);for m=1:CityNumfor n=1:CityNumif Tlist(m,n)=0Tlist(m,n)=Tlist(m,n)-1;endendendTlist(CL(i,3),CL(i,4)=tl;break;endendendp=p+1;Arrbsf(p)=bsf;for i=1:CityNum-1plot(Clist(BSF(i),1),Clist(BSF(i+1),1),Clist(BSF(i),2),Clist(BSF(i+1),2),bo-); hold on;endplot(Clist(BSF(CityNum),1),Clist(BSF(1),1),Clist(BSF(CityNum),2),Clist(BSF(1),2),bo-);title(Counter : ,int2str(p*l1), The Min Distance: ,num2str(bsf);hold off;pause(0.005);if get(stop,value)=1break;endendtoc;BestShortcut=BSFtheMinDistance=bsfset(stop,style,pushbutton,string,close, callback,close(gcf);figure(2);plot(Arrbsf,r); hold on;plot(ArrS,b);grid;title (搜索过程);legend(Best So Far,当 前解);endfunction F=F(dislist,s)DistanV=0;n=size(s,2);for i=1:(n-1)DistanV=DistanV+dislist(s(i),s(i+1);endDistanV=DistanV+dislist(s(n),s(1);F=DistanV;end
展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 图纸设计 > 毕设全套


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!