好文档 - 专业文书写作范文服务资料分享网站

实验五遗传算法求解函数最值问题实验

天下 分享 时间: 加入收藏 我要投稿 点赞

实用标准文档

实验五:遗传算法求解函数最值问题实验

一、 实验目的

使用遗传算法求解函数

二、 实验内容

使用遗传算法进行求解,篇末所附源代码中带有算法的详细注释。算法中涉及不同的参数,参数的取值需要根据实际情况进行设定,下面运行时将给出不同参数的结果对比。

及y

的最大值。

定义整体算法的结束条件为,当种群进化次数达到maxGeneration时停止,此时种群中的最优解即作为算法的最终输出。

设种群规模为N,首先是随机产生N个个体,实验中定义了类型Chromosome表示一个个体,并且在默认构造函数中即进行了随机的操作。

文案大全

实用标准文档

然后程序进行若干次的迭代,在每次迭代过程中,进行选择、交叉及变异三个操作。

1.选择操作

首先计算当前每个个体的适应度函数值,这里的适应度函数即为所要求的优化函数,然后归一化求得每个个体选中的概率,然后用轮盘赌的方法以允许重复的方式选择选择N个个体,即为选择之后的群体。

但实验时发现结果不好,经过仔细研究之后发现,这里在x、y取某些值的时候,目标函数计算出来的适应值可能会出现负值,这时

文案大全

实用标准文档

如果按照把每个个体的适应值除以适应值的总和的进行归一化的话会出现问题,因为个体可能出现负值,总和也可能出现负值,如果归一化的时候除以了一个负值,选择时就会选择一些不良的个体,对实验结果造成影响。对于这个问题,我把适应度函数定为目标函数的函数值加一个正数,保证得到的适应值为正数,然后再进行一般的归一化和选择的操作。实验结果表明,之前的实验结果很不稳定,修正后的结果比较稳定,趋于最大值。

2.交叉操作

首先是根据交叉概率probCross选择要交叉的个体进行交叉。

这里根据交叉参数crossnum进行多点交叉,首先随机生成交叉点位置,允许交叉点重合,两个重合的交叉点效果互相抵消,相当于没有交叉点,然后根据交叉点进行交叉操作,得到新的个体。

文案大全

实用标准文档

3.变异操作

首先是根据变异概率probMutation选择要变异的个体。

变异时先随机生成变异的位置,然后把改位的01值翻转。

经过一定的进化之后得到最终种群,从中选择最优的个体即可得到最终的结果。

文案大全

实用标准文档

4.运行结果

借助matlab软件,我们可以知道该函数在该定义域下的图像为:

以下设置不同的参数值进行对比试验:

表1 不同参数的对比实验

N le文案大全

crossmaxGeneranum tion probCross probMutate 实验一 实验二

实验五遗传算法求解函数最值问题实验

实用标准文档实验五:遗传算法求解函数最值问题实验一、实验目的使用遗传算法求解函数在二、实验内容使用遗传算法进行求解,篇末所附源代码中带有算法的详细注释。算法中涉及不同的参数,参数的取值需要根据实际情况进行设定,下面运行时将给出不同参数的结果对比。
推荐度:
点击下载文档文档为doc格式
5bzxs2elt557eja0pqkz5136q5t3t4006wq
领取福利

微信扫码领取福利

微信扫码分享