tsp遗传算法 c语言,遗传算法解决TSP问题

1.遗传算法与生物进化学说

1885年年,达尔文用自然选择来解释物种的起源和生物的进化。

达尔文的自然选择学说包括三个方面:

遗传

变异

生存斗争和适者生存

上世纪20年代,一些学者用统计生物学和种群遗传学重新解释达尔文自然选择理论,形成现代综合进化论。

种群遗传学认为:

在一定地域中一个物种的全体成员构成一个种群;

生物的进化是种群的进化,每一代个体基因型的改变会影响种群基因库的组成,而种群基因库组成的变化就是这一种群的进化。

遗传算法中与生物学相关的概念和术语与优化问题中的描述的关系:

个体:解

种群:解集/解空间

适应度:评价/目标/寻优函数

选择、交叉、变异:产生新解的方法

2.遗传算法的计算机实现

上世纪60年代中期,Holland提出位串编码技术。

这种技术适用于变异和交叉操作,而且强调将交叉作为主要的遗传操作。

Holland将该算法用于自然和人工系统的自适应行为研究中,在1975出版了开创性著作“Adaptation in Natural and Artifical System”。

之后,他将算法应用到优化以及学习中,并将其命名为遗传算法(简称GA)。

遗传算法基本思路:

计算开始时,随机初始化一定数目的个体,并计算每个个体的适应度值,产生第一代(初始种群)。

如果不满足优化准则,开始新一代的计算:

按照适应度值选择个体,产生下一代;

父代按一定概率进行交叉操作,产生子代;

所有的子代按一定概率变异,形成新的一代。

计算新子代的适应度值。

这一过程循环执行,直到满足优化准则为止。

流程图:

b344e96c9770

遗传算法流程图

3.遗传算法解决TSP问题思路

3.1 编码

最常用策略:路径编码

直接采用城市在路径中的位置来构造用于优化的状态。

例:九城市TSP问题,路径:5-4-1-7-9-8-6-2-3

路径编码:(5 4 1 7 9 8 6 2 3)

3.2 交叉

b344e96c9770

交叉操作

3.3 变异

b344e96c9770

多种可行的变异操作

4.遗传算法解决TSP问题编程实现

输入:

10城市坐标为:

(41, 94);(37, 84);(54, 67);(25, 62);(7, 64); (2, 99);(68, 58);(71, 44);(54, 62); (83, 69)

运行结果:

b344e96c9770

算法运行结果

5.遗传算法的特点

GA是一种通用的优化算法,它的优点有:

编码技术和遗传操作比较简单;

优化不受限制性条件的约束;

隐含并行性和全局解空间搜索。

随着计算机技术的发展,GA愈来愈得到人们的重视,并在机器学习、模式识别、图像处理、神经网络、优化控制、组合优化、VLSI设计、遗传学等领域得到了成功应用。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值