- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
遗传算法的的MATLAB程序实例
遗传算法的程序实例
如求下列函数的最大值? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?f(x)=10*sin(5x)+7*cos(4x)? ?? ?x∈[0,10] 一、初始化(编码)initpop.m函数的功能是实现群体的初始化,popsize表示群体的大小,chromlength表示染色体的长度(二值数的长度),长度大小取决于变量的二进制编码的长度(在本例中取10位)。代码:
%Name: initpop.m%初始化function pop=initpop(popsize,chromlength)? ???pop=round(rand(popsize,chromlength));? ?? ?? ?% rand随机产生每个单元为 {0,1} 行数为popsize,列数为chromlength的矩阵,% roud对矩阵的每个单元进行圆整。这样产生的初始种群。
二、计算目标函数值1、将二进制数转化为十进制数(1)代码:
%Name: decodebinary.m%产生 [2^n 2^(n-1) ... 1] 的行向量,然后求和,将二进制转化为十进制function pop2=decodebinary(pop)[px,py]=size(pop);? ?? ?? ?? ?? ?? ?? ?%求pop行和例数for i=1:py? ?? ?pop1(:,i)=2.^(py-1).*pop(:,i);? ?? ?py=py-1;endpop2=sum(pop1,2);? ?? ?? ?? ?? ?? ?? ? %求pop1的每行之和
2、将二进制编码转化为十进制数(2)decodechrom.m函数的功能是将染色体(或二进制编码)转换为十进制,参数spoint表示待解码的二进制串的起始位置。(对于多个变量而言,如有两个变量,采用20为表示,每个变量10为,则第一个变量从1开始,另一个变量从11开始。本例为1),参数1ength表示所截取的长度(本例为10)。代码:
%Name: decodechrom.m%将二进制编码转换成十进制function pop2=decodechrom(pop,spoint,length)pop1=pop(:,spoint:spoint+length-1);pop2=decodebinary(pop1);
3、计算目标函数值calobjvalue.m函数的功能是实现目标函数的计算,其公式采用本文示例仿真,可根据不同优化问题予以修改。
代码:
%Name: calobjvalue.m%实现目标函数的计算function [objvalue]=calobjvalue(pop)temp1=decodechrom(pop,1,10);? ? %将pop每行转化成十进制数x=temp1*10/1023;? ?? ?? ?? ?? ? %将二值域 中的数转化为变量域 的数objvalue=10*sin(5*x)+7*cos(4*x);%计算目标函数值
三、计算个体的适应值
代码:%Name:calfitvalue.m%计算个体的适应值function fitvalue=calfitvalue(objvalue)global Cmin;Cmin=0;[px,py]=size(objvalue);for i=1:px? ?? ?if objvalue(i)+Cmin0
? ?? ?? ? temp=Cmin+objvalue(i);? ?? ?else
? ?? ?? ? temp=0.0;? ?? ?end? ?? ?fitvalue(i)=temp;endfitvalue=fitvalue;
四 选择复制选择或复制操作是决定哪些个体可以进入下一代。程序中采用赌轮盘选择法选择,这种方法较易实现。根据方程 pi=fi/∑fi=fi/fsum ,选择步骤:1)在第 t 代,由(1)式计算 fsum 和 pi 2)产生 {0,1} 的随机数 rand( .),求 s=rand( .)*fsum3)求 ∑fi≥s 中最小的 k ,则第 k 个个体被选中4)进行 N 次2)、3)操作,得到 N 个个体,成为第 t=t+1 代种群
代码:
%Name: selection.m%选择复制function [newpop]=selection(pop,fitvalue)totalfit=sum(fitvalue);%求适应值之和fitvalue=fitvalue/totalfit;%单个个体被选择的概率fitvalue=cumsum(fitvalue);
您可能关注的文档
最近下载
- 企业智能工厂建设整体解决方案(56页).pptx VIP
- 冶金机械液压、润滑和气动设备工程安装分项工程质量验收记录文本表.docx VIP
- 2025年舟山市专业技术人员公需课程-全面落实国家数字经济发展战略.doc VIP
- GB 50288-2018 灌溉与排水工程设计标准.docx
- 沪教版高中高一数学上册《函数的基本性质》教案及教学反思.docx VIP
- 2025-2026学年高一地理上学期期中模拟卷(考试版A3)【测试范围:中图中华地图版必修一,第1~2单元】.docx VIP
- 冠状动脉粥样硬化性心脏病人的护理.ppt VIP
- 无人机外卖创业计划书.docx
- 河南2023年初中学业水平考试摸底语文卷(原卷+答案卷).docx VIP
- 原产地证申领员培训课件-常用原产地证书填制介绍(李艳颖)20090331.pptx VIP
文档评论(0)