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

  1. 1、本文档共7页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
人工智能遗传算法实验报告.doc

人工智能实验报告 学 号: 姓 名: 实验名称: 遗传算法 实验日期: 2016.1.5 【实验名称】 遗传算法 【实验目的】 掌握遗传算法的基本原理,熟悉遗传算法的运行机制,学会用遗传算法来求解问题。 【实验原理】 遗传算法(Genetic Algorithm)是模拟达尔文生物进化论的自然选择和遗传学机理的生物进化过程的计算模型,是一种通过模拟自然进化过程搜索最优解的方法。 遗传算法是从代表问题可能潜在的解集的一个种群开始的,而一个种群则由经过基因编码的一定数目的个体组成。每个个体实际上是染色体带有特征的实体。在一开始需要实现从表现型到基因型的映射即编码工作。由于仿照基因编码的工作很复杂,我们往往进行简化,如二进制编码,初代种群产生之后,按照适者生存和优胜劣汰的原理,逐代演化产生出越来越好的近似解,在每一代,根据问题域中个体的适应度大小选择个体,并借助于自然遗传学的遗传算子进行组合交叉和变异,产生出代表新的解集的种群。这个过程将导致种群像自然进化一样的后生代种群比前代更加适应于环境,末代种群中的最优个体经过解码,可以作为问题近似最优解。 f(x)=x*sin(x)+1,x([0,2(],求f(x)的最大值和最小值。 数据结构: struct poptype { double gene[length];//染色体 double realnumber;//对应的实数x double fitness;//适应度 double rfitness;//相对适应度 double cfitness;//累计适应度 }; struct poptype population[popsize+1];//最后一位存放max/min struct poptype newpopulation[popsize+1];// 染色体编码: ,变量长度为2 π,取小数点后6位,由于 因此,染色体由23位字节的二进制矢量表示,则X与二进制串(b22 b21…… b0)2之间的映射如下: ; 适应度函数: 由于要求f(x)的最值,所以适应度函数即可为f(x)。但为了确保在轮赌法选择过中,每个个体都有被选中的可能性,因此需要将所有适应度调整为大于0的值。因此,设计求最大值的适应度函数如下: 将最小问题转化为求-f(x)的最大值,同理,设计最小值的适应度函数如下: 种群大小: 本实验默认为50,再进行种群初始化。 实验参数: 主要有迭代数,交叉概率,变异概率这三个参数。一般交叉概率在0.6-0.9范围内,变异概率在0.01-0.1范围内。可以通过手动输入进行调试。 主要代码如下: void initialize()//种群初始化 { srand(time(NULL)); int i,j; for(i=0;ipopsize;i++) for(j=0;j23;j++) population[i].gene[j]=rand()%2; void transform()//染色体转化为实数x { int i,j; for(i=0;i=popsize+1;i++) { population[i].realnumber=0; for(j=0;j23;j++) population[i].realnumber+=population[i].gene[j]*pow(2,j); population[i].realnumber=population[i].realnumber*2*pi/(pow(2,23)-1); } } void cal_fitness()//计算适应度 { int i; for(i=0;ipopsize;i++) population[i].fitness=population[i].realnumber*sin(population[i].realnumber)+6; } void select()//选择操作 { int mem,i,j,k; double sum=0; double p; for (mem=0;mempopsize;mem++) sum+=population[mem].fitness; for (mem=0;mempopsize; mem++) population[mem].rfitness=population[mem].fitness/sum; population[0].

文档评论(0)

dmz158 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档