《遗传算法的Matlab实现讲解》由会员分享,可在线阅读,更多相关《遗传算法的Matlab实现讲解(37页珍藏版)》请在人人文库网上搜索。

1、数学建模专题之遗传算法的MATLAB实现,Contents I,Matlab编程实现GA,1,Matlab编程实现GA,例1:计算目标函数值函数,主程序,遗传算法主程序 function My_GA global Cmin; Cmin=-106; popsize=50; %群体大小 Gene=20; chromlength=20; %字符串长度(个体长度) pc=0.8; %交叉概率 pm=0.01; %变异概率 Xmax=10; Xmin=0,Matlab编程实现GA,pop=initpop(popsize,chromlength); %随机产生初始群体 for i=1:Gene %20为迭。

2、代次数 objvalue=calobjvalue(pop,chromlength,Xmax,Xmin); %计算目标函数 fitvalue=calfitvalue(objvalue); %计算群体中每个个体的适应度 newpop=selection(pop,fitvalue); %复制 newpop=crossover(newpop,pc); %交叉 newpop=mutation(newpop,pm); %变异 bestindividual,bestfit=best(pop,fitvalue); %求出群体中适应值最大的个体及其适应值 x(i)=decodechrom(bestindivid。

3、ual,1,chromlength)*10/(2chromlength-1); %最佳个体解码 y(i)=bestfit+Cmin; %最佳个体适应度 y_mean(i)=mean(fitvalue+Cmin); %第i代平均适应度 pop=newpop; end fplot(2*x+10*sin(5*x)+7*cos(4*x),0 10) hold on plot(x,y,r*) hold off,初始化(编码, initpop.m函数的功能是实现群体的初始化,popsize表示群体的大小,chromlength表示染色体的长度(二值数的长度), % 长度大小取决于变量的二进制编码的长度(在。

4、本例中取20位)。 %Name: initpop.m function pop=initpop(popsize,chromlength) pop=round(rand(popsize,chromlength); % rand随机产生每个单元为 0,1 行数为popsize,列数为chromlength的矩阵, % round对矩阵的每个单元进行取整。这样产生的初始种群,Matlab编程实现GA,将二进制数转化为十进制数,将二进制数转化为十进制数 %产生 2n 2(n-1) . 1 的行向量,然后求和,将二进制转化为十进制 function pop2=decodebinary(pop) px,p。

5、y=size(pop); %求pop行和列数 for i=1:py pop1(:,i)=2.(py-i).*pop(:,i); end pop2=sum(pop1,2); %求pop1的每行之和 function pop2=decodechrom(pop,spoint,length) pop1=pop(:,spoint:spoint+length-1); pop2=decodebinary(pop1,Matlab编程实现GA,计算目标函数值,计算目标函数值 % calobjvalue.m函数的功能是实现目标函数的计算,其公式采用本文示例仿真,可根据不同优化问题予以修改。 %遗传算法子程序 %N。

6、ame: calobjvalue.m %实现目标函数的计算 function objvalue=calobjvalue(pop,chromlength,Xmax,Xmin) temp1=decodechrom(pop,1,chromlength); %将pop每行转化成十进制数 x=temp1*(Xmax-Xmin)/(2chromlength-1); %将十进制域 中的数转化为变量域 的数 objvalue=2*x+10*sin(5*x)+7*cos(4*x); %计算目标函数值,Matlab编程实现GA,计算个体的适应值,function fitvalue=calfitvalue(objv。

7、alue) global Cmin; fitvalue=objvalue-Cmin,Matlab编程实现GA,选择复制,function newpop=selection(pop,fitvalue) %程序中采用赌轮盘选择法选择实现 totalfit=sum(fitvalue); %求适应值之和 fitvalue=fitvalue/totalfit; %单个个体被选择的概率 fitvalue=cumsum(fitvalue); %如 fitvalue=1 2 3 4,则 cumsum(fitvalue)=1 3 6 10 px,py=size(pop); ms=sort(rand(px,1);。

8、 %从小到大排列 fitin=1; newin=1; while newin=px %蒙特卡洛方法抽样 if(ms(newin)fitvalue(fitin) newpop(newin,:)=pop(fitin,:); newin=newin+1; else fitin=fitin+1; end end,Matlab编程实现GA,交叉,function newpop=crossover(pop,pc) px,py=size(pop); newpop=ones(size(pop); for i=1:2:px-1 if(randpc) cpoint=round(rand*py); newpop(i。

9、,:)=pop(i,1:cpoint),pop(i+1,cpoint+1:py); newpop(i+1,:)=pop(i+1,1:cpoint),pop(i,cpoint+1:py); else newpop(i,:)=pop(i); newpop(i+1,:)=pop(i+1); end end,Matlab编程实现GA,变异,function newpop=mutation(pop,pm) px,py=size(pop); newpop=ones(size(pop); for i=1:px if(randpm) mpoint=round(rand*py); if mpoint=0 mpo。

10、int=1; end newpop(i,:)=pop(i,:,Matlab编程实现GA,if any(newpop(i,mpoint)=0 newpop(i,mpoint)=1; else newpop(i,mpoint)=0; end else newpop(i,:)=pop(i,:); end end,求出群体中最大的适应值及其个体,function bestindividual, bestfit =best(pop, fitvalue) px,py=size(pop); bestindividual=pop(1,:); bestfit=fitvalue(1); for i=2:px if。

11、 fitvalue(i)bestfit bestindividual=pop(i,:); bestfit=fitvalue(i); end end,Matlab编程实现GA,或 function bestindividual, bestfit= best(pop, fitvalue) bestfit,m_indx=max(fitvalue); bestindividual=pop(m_indx,:,结果见My_GA.m,Matlab编程实现GA,Matlab函数调用实现GA,Matlab的GA函数 x fval = ga(fitnessfun, nvars, , options); fitne。

12、ssfcn Fitness function nvars Number of variables for the problem Aineq Matrix for inequality constraints Bineq Vector for inequality constraints Aeq Matrix for equality constraints Beq Vector for equality constraints LB Lower bound on x UB Upper bound on x nonlcon Nonlinear constraint Function optio。

13、ns Options structure,Matlab函数调用实现GA,Matlab的GA函数 x = ga(fitnessfcn,nvars) x = ga(fitnessfcn,nvars,A,b) x = ga(fitnessfcn,nvars,A,b,Aeq,beq) x = ga(fitnessfcn,nvars,A,b,Aeq,beq,LB,UB) x = ga(fitnessfcn,nvars,A,b,Aeq,beq,LB,UB,nonlcon) x = ga(fitnessfcn,nvars,A,b,Aeq,beq,LB,UB,nonlcon,options) x = ga(p。

14、roblem) x, fval = ga(.) x, fval, exitflag = ga(.,Matlab函数调用实现GA,GA函数调用步骤 第一步:编写适应度函数; 第二步:对GA参数进行设置; options = gaoptimset(参数名, 参数值, , 参数名, 参数值) 例:options = gaoptimset(PopulationSize, 100) 第三步:调用GA函数; x fval = ga(fitnessfun, nvars) x fval exitflag output population scores = ga(fitnessfcn, nvars) x fv。

15、al = ga(fitnessfun, nvars, ,options,specify any linear equality, linear inequality, or nonlinear constraints,Matlab函数调用实现GA,调用GA函数求例1的最大值 (见ga_eg1.m) 第一步:编写适应度函数; function y=fit1(x) y=-(2*x+10*sin(5*x)+7*cos(4*x); 第二步:设置参数 options = gaoptimset(PopulationSize,100,PopulationType,doubleVector,PlotFcns,。

16、gaplotbestf,gaplotbestindiv,gaplotexpectation,gaplotstopping) 第三步:调用GA函数 x fval=ga(fit1,1,0,10,options); 最后还原 y=-1*fit1(x)%最小值还原为最大值 figure; fplot(2*x+10*sin(5*x)+7*cos(4*x),0 10) hold on plot(x,y,*,遗传算法的GA工具箱实现,Matlab的GA工具箱(R2007,Matlab的GA工具箱(R2010b,遗传算法的GA工具箱实现,例二,求下列优化问题,Matlab函数调用实现,调用GA函数求解(见ga。

17、_eg2.m,function ga_eg2 A = 1 1;-1 2; 2 1; b = 2; 2; 3; lb = zeros(2,1); x,fval,exitflag = ga(lincontest6,2,A,b,lb); mesh_lincontest6; hold on; plot3(x(1),x(2),fval,r*); function mesh_lincontest6 m=10;n=1000; x=-n:m:n; y=-n:m:n; z= 0.5*(ones(length(x),1)*x).2 + (ones(length(y),1)*y).2 . -(ones(length。

18、(x),1)*x).*(ones(length(y),1)*y) -2*(ones(. length(x),1)*x) - 6*(ones(length(y),1)*y); mesh(x,y,z,Matlab函数调用实现,调用GA函数求解(见ga_eg2.m,遗传算法的GA工具箱实现,Matlab的GA工具箱(R2010b,练习一,在5=Xi=5,i=1,2区间内,求解 f(x1,x2)=-20*exp(0.2*sqrt(0.5*(x1.2+x2.2)-exp(0.5*(cos(2*pi*x1)+cos(2*pi*x2)+22.71282的最小值。 要求:种群大小20,最大代数100,变异率0。

19、.1,交叉率0.7,Contents II,GA求解多目标优化问题,1,II-1 GA求解多目标优化问题,通常多目标优化,例如非线性整数规划是一个具有指数复杂度的NP问题,如果约束较为复杂,Matlab优化工具箱和一些优化软件比如lingo等,常常无法应用,即使能应用也不能给出一个较为令人满意的解。这时就需要针对问题设计专门的优化算法。 模型的形式和适应度函数定义如下,II-1 GA求解多目标优化问题,源代码见nonlin.m,练习二,利用GA求解以下多目标优化问题,II-2 GA优化BP神经网络,给定一百组数据(X,Y,Z),(X,Y)为两种测量参数(即输入),Z为结果(即输出)。 请利用N。

20、N模拟输入和输出的关系。 测量数据可利用函数关系模拟,II-2 GA优化BP神经网络,源代码见GABPNN.m,II-2 GA优化BP神经网络,GA优化的结果,II-2 GA优化BP神经网络,GA优化的结果,练习三,给定100组数据(X1,X2,X3,X4,Y1,Y2),(X1,X2,X3,X4)为四种测量参数(即输入),(Y1,Y2)为结果(即输出)。 请利用GA优化BPNN模拟输入和输出的关系。 测量数据可利用函数关系模拟,II-3 GA求解TSP问题,求中国31个省会城市的最短路径(GATSP_PPT2.m,II-3 GA求解TSP问题,GA收敛过程(GATSP_PPT2.m,练习四,调节GATSP_PPT2中的参数,使其达到最佳状态,Thank You。

遗传算法 matlab 详解,遗传算法的Matlab实现讲解相关推荐

  1. 【多元域除法】多项式除法电路原理及MATLAB详解

    关注公号[逆向通信猿]更精彩!!! 关于二元域上的两个元素的加法和乘法.多项式除法,在之前的博客 [有限域除法]二元多项式除法电路原理及MATLAB详解 子程序:sub_poly_div.m [有限域 ...

  2. 【多元域乘法】多项式乘法电路原理及MATLAB详解

    关注公号[逆向通信猿]更精彩!!! 关于二元域上的两个元素的乘法.多项式除法,在之前的博客 [有限域除法]二元多项式除法电路原理及MATLAB详解 子程序:sub_poly_div.m [有限域元素加 ...

  3. 程序阅读_全面详解LTE:MATLAB建模仿真与实现_自学笔记(1)调制与编码_程序阅读

    程序阅读_全面详解LTE:MATLAB建模仿真与实现_自学笔记(1)调制与编码_程序阅读 在粗浅地掌握了LTE知识后,从今天开始对<全面详解LTE:MATLAB建模仿真与实现>一书的学习. ...

  4. 启发式算法详解——遗传算法

    启发式算法详解--遗传算法 算法原理 算法详解 算法详解 算法总结 算法原理 遗传算法(Genetic Algorithm)遵循『适者生存』.『优胜劣汰』的原则,是一类借鉴生物界自然选择和自然遗传机制 ...

  5. 天津理工大学《操作系统》实验二,存储器的分配与回收算法实现,代码详解,保姆式注释讲解

    天津理工大学<操作系统>实验二,存储器的分配与回收算法实现,代码详解,保姆式注释讲解 实验内容 1. 本实验是模拟操作系统的主存分配,运用可变分区的存储管理算法设计主存分配和回收程序,并不 ...

  6. 详解遗传算法(含MATLAB代码)

    目录 一.遗传算法概述 二.遗传算法的特点和应用 三.遗传算法的基本流程及实现技术 3.1 遗传算法的基本流程 3.2 遗传算法的实现技术 1.编码 2.适应度函数 3.选择算子 4.交叉算子 5.变 ...

  7. 超级详解遗传算法(GA)学习笔记(1.1) 持续更新

    遗传算法入门第一式---------求解函数极值问题(附完整代码和详解) 声明:大佬请指点,小白同学一起聚聚交流~~~~ 联想到球球大作战!!!!! 以这幅图为例,可以将其看成是一个种群,当中的散点就 ...

  8. 主成分分析,PCA(Principle Component Analysis)详解 ,结合matlab

    https://my.oschina.net/gujianhan/blog/225241 一.简介 PCA(Principal Components Analysis)即主成分分析,是图像处理中经常用 ...

  9. 基于YOLOv5的目标检测系统详解(附MATLAB GUI版代码)

    摘要:本文重点介绍了基于YOLOv5目标检测系统的MATLAB实现,用于智能检测物体种类并记录和保存结果,对各种物体检测结果可视化,提高目标识别的便捷性和准确性.本文详细阐述了目标检测系统的原理,并给 ...

  10. python与matlab哪个更容易学-详解python和matlab的优势与区别

    Python是一种面向对象的解释型计算机程序设计语言.Python是纯粹的自由软件, 源代码和解释器CPython遵循 GPL(GNU General Public License)协议 .Pytho ...

最新文章

  1. Navicat for SQLite 15中文版
  2. 农林行业的系统应用 php专业,农林|类专业
  3. psid mysql_MySQL数据双向同步解决方案(推荐)
  4. mysql delete in死锁_mysql 执行delete引发死锁问题
  5. 网络技巧:想要WiFi信号满格,路由器应该这样放!
  6. java 布局管理器_有时在Java中,一个布局管理器是不够的
  7. fofa自动化爬虫脚本更新+详解
  8. django-中间件0911-2
  9. 编写第一个Linux环境下程序的编译,下载记录
  10. CenterNet+ deepsort实现多目标跟踪
  11. iOS 开发常用链接总结
  12. 2-9 prev + next选择器 “远亲不如近邻” 返回且只返回唯一-个元素。 而通过prev + next选择器就可以查找与“prev”元素紧邻的下一个“next”元素...
  13. Linux/Unix 中 wheel 组的来源
  14. uefi能重置系统吗_无惧UEFI, Win10也能玩转一键自动还原
  15. python概率密度函数参数估计_概率密度估计介绍
  16. 宅家必备 | 笔记本开启WiFi共享
  17. wordpress网站打开速度优化压缩html代码
  18. 使用WHM重新编译Apache+PHP环境
  19. sql server(MSSQLSERVER)服务不能启动 解决办法
  20. eh怎么搜索重口sm_wifi怎么隐藏?

热门文章

  1. iOS-dSYM 文件分析工具
  2. React自定义视频全屏按钮
  3. 我国4G标准拓展国际市场取得重要突破
  4. imx8qm LVDS屏 DS90UB9478调试
  5. Windows10更新工具
  6. 运筹学 $5约束极值
  7. mac的截图命令screencapture
  8. VC编程读取文本数据
  9. java applet图形_java APPlet 绘制图像
  10. [JZOJ3296] 【SDOI2013】刺客信条