- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
旅行商lingo运算
function [ pop ] cross (pop)
[ s, t ] size (pop) ;
data; %取城市位置数据
distma = dists( mm, mm ) ; %生成距离表
pop1 = pop; %保存原群体矩阵
m = zeros(1, 31) ; %初始化交叉后第一个个体
n = zeros ( 1, 31) ; %初始化交叉后第二个个体
for i = 1:2: S %每两行进行交叉操作
x1 = pop ( i , :) ; %取出要交叉的两行进行右交叉
y1 = pop ( i + 1, :) ;
x2 = pop ( i , :) ; %取出要交叉的两行进行左交叉
y2 = pop ( i + 1, :) ;
c1 = round ( rand3 29) ; %随机产生交叉起点
c2 = c1; m (1) = c1 ; n (1) = c2 ; j = 2;
while size ( x1, 2) 2%交叉结束的条件
l = find ( x1 = = c1 ) ; h = find ( x2 = =c2 ) ;
if l = = 32 – j %若为最后一个城市,则右城市为第一个城市
lr = 1;
else
lr = l + 1; %其他情况直接加一
end
if h = = 1 %若为第一个城市,则左城市为最后一个城市
hl = 32 - j ;
else
h1 = h - 1 ;
end
q = find ( y1 = = c1 ) ; z = find ( y2 = = c2 ) ;
if q = = 32 - j %找出第二个父代的右城市
qr = 1;
else
qr = q + 1;
end
if z = = 1 %找出第二个父代的左城市
z1 = 32 - j ;
else
z1 = z - 1 ;
end
if
distma ( c1 + 1, x1 ( lr) + 1 ) distma ( c1 + 1,
y1 ( qr) + 1) % 比较两父代交叉点与右城市的距离,取距离小的城市为子代的下一个点
m ( j) = x1 ( lr) ; c1 = x1 ( lr) ;
else
m ( j) = y1 ( qr) ; c1 = y1 ( qr) ;
m ( j) = y1 ( qr) ; c1 = y1 ( qr) ;
end
x1 (1) = [ ]; %删除父代中已经选中的点
y1 ( q) = [ ];
if
distma ( c2 + 1, x2 ( h l) + 1) distma ( c2 + 1,
y2 ( zl) + 1) %比较两父代交叉点与左城市的距离,取距离小的城市作为第二子代的下一点
n ( j) = x2 ( h l) ; c2 = x2 ( h l) ;
else
n ( j) = y2 ( zl) ; c2 = y2 ( zl) ;
end
x2 ( h) = [ ]; %删除父代中已经选中的点
y2 ( z) = [ ];
j = j + 1;
end
pop1 ( i , : ) = m ; %得到交叉后的群体矩阵
pop1 ( i + 1, : ) = n ;
end
pop1 = qiujuli ( pop1) ; %求出交叉种群中个体的适应值
for i = 1:s %逐行比较,保留适应值较小的个体
if pop1 ( i, t ) pop ( i, t )
pop ( i , : ) = pop1 ( i , : ) ;
end
end
Global optimal solution found.
Objective value: 1777.000
Objective bound: 1777.000
Infeasibilities: 0.000000
Extended solver steps: 273
Total solver iterations: 20191
Variable Value
N 30.00000
您可能关注的文档
最近下载
- 河南省青桐鸣2024-2025学年高二上学期11月期中化学试卷.docx VIP
- 住院费用清单模板.doc VIP
- 大学学术英语视听说教程下册(第2版)Miriam_Espeseth习题答案.pdf
- 浙江省嘉兴八校联盟2024-2025学年高一上学期期中联考物理试卷(含答案).pdf VIP
- 颈动脉灌注机制.pptx VIP
- 浙江省嘉兴八校联盟2024-2025学年高一上学期期中考试 化学试题(含答案).pdf VIP
- Unit 4 Friends Lesson3 课件 人教精通版英语三年级上册.ppt
- 锅炉原理课件:第七章 锅炉设备的通风计算.ppt VIP
- 生涯发展展示-(第一版).pptx VIP
- 《选品与采购》课件——4.电商采购.pptx VIP
原创力文档


文档评论(0)