人工智能 遗传算法实验报告

人工智能 遗传算法实验报告

ID:26610576

大小:187.55 KB

页数:7页

时间:2018-11-28

人工智能 遗传算法实验报告_第1页
人工智能 遗传算法实验报告_第2页
人工智能 遗传算法实验报告_第3页
人工智能 遗传算法实验报告_第4页
人工智能 遗传算法实验报告_第5页
资源描述:

《人工智能 遗传算法实验报告》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库

1、人工智能实验报告学号:姓名:实验名称:遗传算法实验日期:2016.1.5【实验名称】遗传算法【实验目的】掌握遗传算法的基本原理,熟悉遗传算法的运行机制,学会用遗传算法来求解问题。【实验原理】遗传算法(GeneticAlgorithm)是模拟达尔文生物进化论的自然选择和遗传学机理的生物进化过程的计算模型,是一种通过模拟自然进化过程搜索最优解的方法。遗传算法是从代表问题可能潜在的解集的一个种群开始的,而一个种群则由经过基因编码的一定数目的个体组成。每个个体实际上是染色体带有特征的实体。在一开始需要实现从表现型

2、到基因型的映射即编码工作。由于仿照基因编码的工作很复杂,我们往往进行简化,如二进制编码,初代种群产生之后,按照适者生存和优胜劣汰的原理,逐代演化产生出越来越好的近似解,在每一代,根据问题域中个体的适应度大小选择个体,并借助于自然遗传学的遗传算子进行组合交叉和变异,产生出代表新的解集的种群。这个过程将导致种群像自然进化一样的后生代种群比前代更加适应于环境,末代种群中的最优个体经过解码,可以作为问题近似最优解。遗传算法程度流程图为:【实验内容】题目:已知f(x)=x*sin(x)+1,xÎ[0,2p],求f(

3、x)的最大值和最小值。数据结构:structpoptype{doublegene[length];//染色体doublerealnumber;//对应的实数xdoublefitness;//适应度doublerfitness;//相对适应度doublecfitness;//累计适应度};structpoptypepopulation[popsize+1];//最后一位存放max/minstructpoptypenewpopulation[popsize+1];//染色体编码:,变量长度为2π,取小数点后6

4、位,由于因此,染色体由23位字节的二进制矢量表示,则X与二进制串()2之间的映射如下:;适应度函数:由于要求f(x)的最值,所以适应度函数即可为f(x)。但为了确保在轮赌法选择过中,每个个体都有被选中的可能性,因此需要将所有适应度调整为大于0的值。因此,设计求最大值的适应度函数如下:将最小问题转化为求-f(x)的最大值,同理,设计最小值的适应度函数如下:种群大小:本实验默认为50,再进行种群初始化。实验参数:主要有迭代数,交叉概率,变异概率这三个参数。一般交叉概率在0.6-0.9范

5、围内,变异概率在0.01-0.1范围内。可以通过手动输入进行调试。主要代码如下:voidinitialize()//种群初始化{srand(time(NULL));inti,j;for(i=0;i

6、<23;j++)population[i].realnumber+=population[i].gene[j]*pow(2,j);population[i].realnumber=population[i].realnumber*2*pi/(pow(2,23)-1);}}voidcal_fitness()//计算适应度{inti;for(i=0;i

7、alnumber)+6;}voidselect()//选择操作{intmem,i,j,k;doublesum=0;doublep;for(mem=0;mem

8、m=1;mem

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。