ImageVerifierCode 换一换
格式:DOCX , 页数:9 ,大小:83.89KB ,
资源ID:2914829      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bingdoc.com/d-2914829.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(人工智能遗传算法实验报告.docx)为本站会员(b****1)主动上传,冰点文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰点文库(发送邮件至service@bingdoc.com或直接QQ联系客服),我们立即给予删除!

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

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

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

3、uble realnumber;/对应的实数x double fitness;/适应度 double rfitness;/相对适应度 double cfitness;/累计适应度;struct poptype populationpopsize+1;/最后一位存放max/minstruct poptype newpopulationpopsize+1;/染色体编码:,变量长度为2 ,取小数点后6位,由于因此,染色体由23位字节的二进制矢量表示,那么X与二进制串2之间的映射如下: ; 适应度函数:由于要求f(x)的最值,所以适应度函数即可为f(x)。但为了确保在轮赌法选择过中,每个个体都有被选中

4、的可能性,因此需要将所有适应度调整为大于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+) populationi.genej=rand()%

5、2;void transform()/染色体转化为实数x int i,j; for(i=0;i=popsize+1;i+) populationi.realnumber=0; for(j=0;j23;j+) populationi.realnumber+=populationi.genej*pow(2,j); populationi.realnumber=populationi.realnumber*2*pi/(pow(2,23)-1); void cal_fitness()/计算适应度 int i; for(i=0;ipopsize;i+) populationi.fitness=popul

6、ationi.realnumber*sin(populationi.realnumber)+6;void select()/选择操作 int mem,i,j,k; double sum=0; double p; for (mem=0;mempopsize;mem+) sum+=populationmem.fitness; for (mem=0;mempopsize; mem+) populationmem.rfitness=populationmem.fitness/sum; population0.cfitness=population0.rfitness; for (mem=1;mempo

7、psize;mem+) populationmem.cfitness=populationmem-1.cfitness+populationmem.rfitness; for (i=0;ipopsize;i+) /轮赌法选择机制 p=rand()%1000/1000.0; if (ppopulation0.cfitness) newpopulationi=population0; else for (j=0;j=populationj.cfitness&ppopulationj+1.cfitness) newpopulationi=populationj+1; for (i=0;ipopsiz

8、e;i+)/复制给下一代 populationi=newpopulationi; void cross()/交叉操作 int i, mem, one; int first = 0; double x; for(mem=0;mempopsize;mem+) x = rand()%1000/1000.0; if (xpcross) +first; if (first%2=0) Xover(one,mem);/个体间染色体进行交叉函数 else one=mem; void mutate()/变异操作 int i, j,t; double x; for (i=0;ipopsize;i+) for(j=

9、0;jlength;j+) x=rand()%1000/1000.0; if (xpvariation) if(populationi.genej) populationi.genej=0; else populationi.genej=1; void cal_max()/计算最大值 int i; double max,sum=0; int max_m; max=population0.fitness; for(i=0;ipopulationi+1.fitness) if(populationi.fitness=max) max=populationi.fitness; max_m=i; el

10、se if(populationi+1.fitness=max) max=populationi+1.fitness; max_m=i + 1; if(maxpopulationpopsize.fitness) iteration=0; for (i=0;ilength;i+) populationpopsize.genei=populationmax_m.genei; populationpopsize.fitness=populationmax_m.fitness; for (i=0;ilength;i+) sum=populationpopsize.genei-populationmax_m.genei; if(sum=0) iteration+; transform(); printf(%f,%f,%f,%fn,populationpopsize.fitness,populationpopsize+1.fitness,populationpopsize.realnumber,populationpopsize+1.realnumber);【实验结果】

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2