网站大量收购独家精品文档,联系QQ:2885784924

实验一基于遗传算法的函数优化.doc

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

人工智能实验报告 实验一 基于遗传算法的函数优化 1、实验目的 掌握Matlab子函数的编写与调用。 理解基本遗传算法的原理,并利用程序实现利用遗传算法优化非线性函数的解。 2、实验内容与实验要求 掌握基本遗传算法方法原理。 掌握matlab子函数的编写方法及调用方法。 根据基本遗传算法方法原理,编写Matlab程序,优化非线性函数的解。 设 f(x) = ,求 max f(x), x( [-2, 2],解的精度保留二位小数。 3、实验要求 自己独立编写Matlab函数。 书写实验报告。 分析实验结果,用图或表描述出迭代次数与适应度函数值的关系曲线。 4、实验设备 计算机 Matlab软件 5、实验结果及分析 (1)编码和产生初始群体 首先需要确定编码的策略,也就是说如何把 [-2, 2] 区间内的数用计算机语言表示出来。采用二进制形式来解决编码问题,即将某个变量值代表的个体表示为一个{0, 1}二进制串。串的长度取决于求解的精度,例如假设求解精度为保留两位小数,由于区间 [-2, 2] 的长度为 4,则必须将该区间分为 400 等分。因为 2840029,所以编码所用的二进制串至少需要9位。 编码:二进制串(b8b7b6…b1b0)与 [-2, 2] 内实数的一一映射: b8b7b6…b1b0 二进制串 a=101000111 其对应的十进制数为: 转化到 [-2, 2] 内的实数为: 产生初始群体: pop1={ 100011110, % a1 001000010, % a2 110000000, % a3 110000101} % a4 转化成 [-2, 2] 之间的十进制数即为: pop1={0.24,-1.48,1.01,1.05} (2)定义适应函数和适应值 由于目标函数 f(x) 在 [-2, 2] 内的值有正有负,所以必须通过建立适应函数与目标函数的映射关系,保证映射后的适应值非负,而且目标函数的优化方向应对应于适应值增大的方向,也为以后计算各个体的入选概率打下基础。 定义适应函数 :为了便于计算,这里的 Fmin 采用了一个特定的输入值,如果取 Fmin=-1,则 f(x)=1 对应的适应值为 g(x)=2。上述随机产生的初始群体,取 Fmin=-1,则它们的目标函数值和适应值分别为: f(pop1)={ -0.02, 4.73, -4.06, -4.30} g(pop1)={ -1.02, 3.73, - 5.06,-5.30} (3)确定选择标准 用适应值比例来作为入选概率。 设给定的规模为400的群体 pop={a1, a2, ..., a400},个体 ai 的适应值为 g(ai),则其入选概率为 ) 上述随机产生的初始群体,它们的入选概率分别为: p(pop1)=g(pop1)/sum(g(pop1)) ={0,1,0,0} (4)产生种群 3 将入选概率大的个体选入种群,淘汰概率小的个体,并用概率最大的个体补入种群,得到与原群体大小同样的种群。 在上述随机产生的初始群体中,淘汰掉 a3,再加入 a2,得到新的种群(选择): newpop1={ 100011110, % a1 001000010, % a2 001000010, % a2 110010101} % a4 交叉: 交叉也就是将一组染色体上对应基因段的交换得到新的染色体,然后得到新的染色体组,组成新的群体。 将前面得到的 newpop1 的四个个体两两配对,重复的不配对,进行交叉(可以在任一位进行交叉): 变异:变异就是通过一个小概率改变染色体位串上的某个基因。 现把 jchpop1 中第 3 个个体中的第 5 位改变,就产生了变异,得到了新的群体 pop2 : pop2={ 001000010, 100011110, 010000101, 101000010} 然后对新的种群重复上述的选择、交叉、变异,直到满足终止条件为止。 (5)实验结果 6、附录(Matlab函数) %遗传算法主函数 %q: 输出最佳个体自变量值 %迭代次数为400 function [q]=GA() global best_in; global g_value; %初始化 initilize(); %初始化最佳个体的适应函数值 for i=1:400 g_value = 0.; end %迭代开始 for k=1:1:100 fitness(); %适应函数操作 calculate();%对出现概率小的个体进行淘汰,并保留最佳个体best_in的信息

文档评论(0)

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

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

1亿VIP精品文档

相关文档