遗传算法求TSP问题
一、实验内容及目的
本实验以遗传算法为研究对象,分析了遗传算法的选择、交叉、变异过程,采用遗传算法设计并实现了商旅问题求解,解决了商旅问题求解最合适的路径,达到用遗传算法迭代求解的目的。选择、交叉、变异各实现了两种,如交叉有顺序交叉和部分交叉。
二、实验环境
Windows10
开发环境Python 3/Flask
三、实验设计与实现

图1软件结构图
图1软件结构图
Flask.py是后端核心代码,里面是遗传算法实现,index.html为首页,即第一次进入网页的页面,进入之后可以进行参数设置,之后点击开始,参数会传到Flask.py中进行解析和算法运行,最终将迭代结果存到result(存储迭代结果图)和result_path(存储最短路径图)在返回给display.html页面显示。

图2系统界面图
图2系统界面图
输入种群规模、迭代次数、变异概率、选择比例、交叉概率并选择变异方法、选择个体方法、交叉方法。点击开始即可运行该系统。
具体算法流程图:

图3核心算法流程图
流程图描述:首先根据参数城市数量和种群规模初始一个城市坐标矩阵的列表并计算城市间的距离存到矩阵,最后生成一个路径矩阵,这样就可以进入下一步计算适应度,每一条路径都有其路径距离值和适应度,接下来一次进行选择,交叉,变异操作,循环往复,直至达到了参数中的迭代次数限制。
选择—轮盘赌:(这里我的算法选出的种群数量不一定就恰好是根据比例算出的数量)

图3核心算法流程图

图4轮盘赌流程图
选择—锦标赛:

图5三元锦标赛流程图
交叉—顺序交叉:
1、 选切点X,Y
2、 交换中间部分
3、 从第二个切点Y后第一个基因起列出原顺序,去掉已有基因
4、 从第二个切点Y后第一个位置起,将获得的无重复顺序填入

图6顺序交叉动态图

图7顺序交叉静态图
交叉—部分交叉:
1、 选切点oop
2、 选取oop到oop+3部分交换(我这里就是三个,你可以做成随机的几个)
3、 判断是否有重复的,若重复则进行映射,保证形成的新一对子代基因无冲突。



图8部分交叉动态图
变异—两点交换
1、 随机选取两点
2、 两点进行交换
变异—相邻交换
1、 随机选取一点
2、 和该点的后面点进行交换
适应度函数:经过测试得A取5,B取0效果好,所以实验中直接取了A=5,B=0运行
借鉴了sigmoid函数的形式,并对数据做了最大最小标准化,A、B是人为给定的常系数mean、max、min是种群所有个体的目标函数值的均值、最大值、最小值图像如下A=5,B=0
适应值较大的更容易进入下一代种群中

图9适应度函数算术表达式
四、实验结果与测试
表1 遗传算法解决TSP问题的测试用例
| 测试内容 | 测试用例 | 预期结果 | 实际结果 |
| 种群规模 | 1.不输入 2.输入除数字其他 3.输入整数数字 4.输入小数或者负数 |
失败 失败 成功 失败 |
与预期相同 |
| 迭代次数 | 5.不输入 6.输入除数字其他 7.输入整数数字 8.输入小数或者负数 |
失败 失败 成功 失败 |
与预期相同 |
| 变异方法 | 9.选择两点交换 10.选择相邻交换 |
成功 成功 |
与预期相同 |
| 选择个体方法 | 11.选择轮盘赌 12.选择锦标赛 |
成功 成功 |
与预期相同 |
| 交叉方法 | 13.选择部分交叉 14.选择顺序交叉 |
成功 成功 |
与预期相同 |
| 变异概率 | 15.不输入 16.输入除数字其他 17.输入小于1的小数 18.输入非小于1的小数或者整数 |
失败 失败 成功 失败 |
与预期相同 |
| 选择比例 | 19.不输入 20.输入除数字其他 21.输入小于1的小数 22.输入非小于1的小数或者整数 |
失败 失败 成功 失败 |
与预期相同 |
| 交叉概率 | 23.不输入 24.输入除数字其他 25.输入小于1的小数 26.输入非小于1的小数或者整数 |
失败 失败 成功 失败 |
与预期相同 |
| 随机产生多少个城市 | 27.不输入 28.输入除数字其他 29.输入整数数字 30. 输入小数或者负数 |
失败 失败 成功 失败 |
与预期相同 |

图10参数设置图
在上述参数设置好之后,即可开始运行系统,最后产生如图11的迭代结果图,最上面是自己的参数设置和最后生成的最小路径min_dist,图示整体为每次迭代的路径距离,可见随着迭代次数增加,路径距离一直减小最后趋于稳定。图12为用python画的路径图,图中横轴纵轴为城市位置的X,Y坐标。

图11 迭代结果图

图12最短路径图
接下来重新选择其他参数来运行一下,看一下有没有区别。

图13参数设置图

图14迭代结果图

图15最短路径图
可以从迭代图像看出,参数不同会导致迭代中结果的不同,第一次参数设置的迭代中在前段迭代不稳定,忽上忽下,之后稳定,而第二次参数设置后迭代很快就稳定,没有忽上忽下的现象,所以不同的选择、变异、交叉方法会使迭代结果不同。所以可以根据随机设定让计算机找到最合适的参数设置。
欢迎关注我的知乎平台,我将持续为您解答一系列问题!
遗传算法求TSP问题的更多相关文章
- 基于遗传算法求解TSP问题(Java界面)
近期为做展示,改写了一个遗传算法求TSP的Java界面版,思路代码和 http://blog.csdn.net/wangqiuyun/article/details/12838903 这篇文章思路是一 ...
- 转:遗传算法解决TSP问题
1.编码 这篇文章中遗传算法对TSP问题的解空间编码是十进制编码.如果有十个城市,编码可以如下: 0 1 2 3 4 5 6 7 8 9 这条编码代表着一条路径,先经过0,再经过1,依次下去. 2.选 ...
- 利用遗传算法求解TSP问题
转载地址 https://blog.csdn.net/greedystar/article/details/80343841 目录 一.问题描述 二.算法描述 三.求解说明 四.参考资料 五.源代码 ...
- 遗传算法解决TSP问题实现以及与最小生成树的对比
摘要: 本实验采用遗传算法实现了旅行商问题的模拟求解,并在同等规模问题上用最小生成树算法做了一定的对比工作.遗传算法在计算时间和占用内存上,都远远优于最小生成树算法. 程序采用Microsoft vi ...
- 用遗传算法解决TSP问题
浅谈遗传算法:https://www.cnblogs.com/AKMer/p/9479890.html Description \(小m\)在踏上寻找\(小o\)的路程之后不小心碰到了大魔王\(fat ...
- 遗传算法解决TSP问题
1实验环境 实验环境:CPU i5-2450M@2.50GHz,内存6G,windows7 64位操作系统 实现语言:java (JDK1.8) 实验数据:TSPLIB,TSP采样实例库中的att48 ...
- 遗传算法求解TSP问题
package com.louis.tsp; /** * Project Name:GeneticAlgorithm * File Name:Individual.java * Package Nam ...
- [PHP] 遗传算法求函数最大值一般实现
需求:求解函数 f(x) = x + 10*sin(5*x) + 7*cos(4*x) 在区间[0,9]的最大值. <?php /* 需求:求解函数 f(x) = x + 10*sin(5*x) ...
- 基础遗传算法的TSP问题
一.简介 旅行商问题是一个经典的组合优化问题.一个经典的旅行商问题可以描述为:一个商品推销员要去若干个城市推销商品,该推销员从一个城市出发,需要经过所有城市后,回到出发地.应如何选择行进路线,以使总的 ...
- Python动态展示遗传算法求解TSP旅行商问题(转载)
版权声明:本文为博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明.本文链接:https://blog.csdn.net/jiang425776024/articl ...
随机推荐
- JS 学习笔记 (七) 面向对象编程OOP
1.前言 创建对象有很多种方法,最常见的是字面量创建和new Object()创建.但是在需要创建多个相同结构的对象时,这两种方法就不太方便了. 如:创建多个学生信息的对象 let tom = { n ...
- android 代码分析
1.@Override注解 @Override 注解是用来指定方法重写的,只能修饰方法并且只能用于方法重写,不能修饰其它的元素. 作用是告诉编译器检查这个方法,保证父类要包含一个被该方法重写的方法,否 ...
- easyclick 学习
什么是EC EasyClick 写自动化脚本,使用的编辑器 Idea 运行模式有两种:无障碍模式.代理模式 注释 三种类型: 1./** 对程序作介绍,解释说明用 / 2./* 多行注释 第二行 / ...
- from 表单非空验证以及多表单提交
开发中我们常用到$('#formid').serialize()方法进行表单序列化提交,但也相应催生了表单的非空严重以及多表单提交. form html: <form id="form ...
- STM32标准库中GPIO_ReadInputData与GPIO_ReadInputDataBit的区别
GPIO_ReadInputData读的是GPIOx的整个IDR寄存器的数据,返回一个十六位数,对应IDR寄存器的十六位.反映GPIOx所有端口的电平状态,所以参数只用传入GPIOx. uint16_ ...
- 时间片差分调度法-充分利用MCU的资源
前言 通过该篇学习了嵌入式的任务调度(即时间片论法)后,了解到通过以1ms为调度时间单位轮询判断是否需要执行函数任务,那么下面介绍如何基于时间片论法的任务调度模式充分利用MCU的资源,姑且先称这种方式 ...
- Jmeter 之 jp@gc - Stepping Thread Group
jp@gc - Stepping Thread Group 自定义线程组,根据业务需要进行设计用户增加间隔时间等 1. 下载jmeter-plugins-manager-1.3.jar插件放入lib ...
- 计算存储分离在京东云消息中间件JCQ上的应用
作者:田寄远 JCQ 全名 JD Cloud Message Queue,是京东云自研.具有 CloudNative 特性的分布式消息中间件. JCQ 设计初衷即为适应云特性的消息中间件:具有高可用. ...
- input限制只能输入汉字
<el-form class="det_foot" :model="form" :rules="rules" ref="fo ...
- 甜点cc的2022年回顾总结
每每到年底,总会感概时间飞逝,总会莫名的心慌几天. 高中时代我就明白了一个道理:自己决定做的事,就算结果再烂以后也不要后悔,因为那无异于否定过去的自己.人不能总是否定自己的过去,因为我觉得这样会打击自 ...