Matlab遗传算法工具箱的使用

  遗传算法(Genetic Algorithm,GA)是J.Holland教授1975年在其专著中首次发表,又经Goldberg、DeJong等研究总结形成的一种模拟进化算法,其基于生物进化和物种选择理论模拟自然界基因进化的过程与机理来实现最优值搜索。“适者生存”是遗传算法效仿的基本原理,算法通过模仿基因复制、交换、变异等过程使初始解最终逼近最优解。

1、遗传算法的基本概念

  由于遗传算法的理念主要源于生物进化理论,所以算法中的许多专业概念与生物进化中的概念很相近,以下做简要说明。
  (1)问题的解空间:利用遗传算法时,其最优解和次优解往往存在于同一个集合里,这便是解空间。
  (2)种群与个体:遗传算法的解空间源于提供的多个原始解,他们的集合便形成种群,里面的每条原始解便为单个个体。在进行算法迭代时,种群的个体数不会发生变化,而个体会不断“进化”。
  (3)染色体编码与基因组:在学习和推导过程里,需要将种群中的每个个体编码,以实现后期的个体选择、交叉和变异,编码形成的二进制串或格雷串便为个体的染色体,上面的数字称为个体基因,每一数字段称为基因组。
  (4)适应度函数:适应度函数可以来判断个体与环境(问题)之间的契合性,选取有效适用度函数来判断个体与最优解之间的距离是遗传算法中最为重要的一步。
  (5)选择:从种群选取优秀个体的一个过程,利用适应度函数来完成选择步骤。
  (6)交叉:即模仿生物繁殖过程,使同源染色体互换位置,以形成两个更适应问题的新个体。
  (7)变异:即在进化过程时对染色体上的编码数值采用取反处理以诞生新个体的过程。

2、遗传算法原理

  基本遗传算法以一个种群或其中的个体为单位,使用遗传算子、选择算子、交叉算子和变异算子来完成学习和求解过程。这个过程可以表示为:

  式中,C表示编码方法,E为适应度函数,P是初始种群,M为种群大小,φ是选择算子,τ为交叉算子,Ψ为变异算子,T是运算终止条件。

3、遗传算法程序实现

  同生物自然进化相同,遗传算法将所有数据编码形成染色体,通过迭代不断选择、交叉和变异运算,从而得到问题的最优解。

  (1)初始种群的生成
  遗传算法实现过程中的初始种群诞生有两种形式:一是在对问题的解没有任何先验知识情况下的完全随机产生法;二是在之前经验中选择符合要求的个体组成初始种群,这样可以使初始种群更快达到最优解。
  (2)适应度评估
  适应度评估是通过适应度函数来实现,是个体是否遗传到下一代的依据。它是影响遗传算法性能最关键的因素之一,其需要结合问题本身进行因变量设计,并预先设定好个体适应度到预期因变量的转换规律。
  (3)遗传操作算子
  遗传算法包括选择、交叉、变异三种,其各自模仿生物基因的繁殖、交叉和突变过程,使算法产生较强的检索技能。
  1)选择算子
  选择即从当前群体中选择满足适应度的个体,使其直接或交叉后遗传至下一代种群里。选择完个体后,算法将随机决定该个体与谁进行交配。当其被选中概率较大时,其交配次数就会增加,反之将被舍弃。
  2)交叉算子
  即用两个父代个体产生新个体的过程。通过交叉不仅可以保留优秀基因,还可以产生包含更复杂基因的新个体,从而提高检索能力。因此,交叉算子是遗传算法的核心。
  3)变异算子
  为了避免出现问题的过早收敛,遗传算法利用基因链模仿基因突变现象,使得个体基因编码出现小规模翻转。变异属于局部搜索,其与另外两种算子一同确保了算法的有效性。

4、遗传算法的特点

  遗传算法基于生物进化中“优胜劣汰,适者生存”的相关理论,不同于传统的枚举法、搜索算法等,有着自己独特的特点和优点。
  (1)具有自适应、自组织和智能性
  遗传算法在确定了初始的参数后便可以在进程中对信息进行自行搜索,以适应度值为筛选依据,对适应性更强的个体进行保留与遗传,并利用基因重组和变异操作获得更优后代。遗传算法这种特性可以自身发现环境特征和规律,有着极强的智能性,克服了传统算法中需要人事先主观描述问题特征的不足。
  (2)以编码集为处理对象
  遗传算法是直接针对研究的主体对象进行优化迭代,具有更广泛的应用领域。
  (3)易于并行性
  主要表现在其以种群为单位进行最优解搜寻,可以同时对多个解空间进行搜索和信息交换,这样可以大大加快的优化效率,并大大减少优化费用。
  (4)无规则转换性
  遗传算法是以概率调整的方式来调整算法的搜索的,虽然这种没有绝对转换规则的搜索看起来是盲目的,但概率的指引实际上已经使所发搜索有了明确方向。
  (5)便捷性
  遗传算法的原理、进化和计算流程都很规整明确,在实际应用中有着很强的便捷性。
  遗传算法的以上这些特点不仅可以更容易的获得全局最优解,还更有利于处理大规模的复杂问题。

5、遗传算法工具箱的安装

  遗传算法工具箱是利用MATLAB矩阵函数构建的一套通用工具,用于实现多种遗传算法方法。遗传算法工具箱(Genetic Algorithm Toolbox)是一组例程,主要用m文件编写,实现了遗传算法中最重要的功能。遗传算法工具箱的安装说明可以在MATLAB安装说明中找到。建议将此工具箱的文件存储在Matlab/toolbox主目录下名为genetic的目录中。
  该工具箱中还有部分实例,例如:sga.m中实现了求解数值优化问题的单种群二进制编码遗传算法。mpga.m中实现了多目标遗传算法的求解动态控制的问题。

6、算法实例

  选取测试函数为:

  其中n表示问题的维数。对于这个例子,我们选择n=20。

function ObjVal = objfun1(Phen)
ObjVal = sum((Phen .* Phen)')';
NIND = 40;           % 种群数
MAXGEN = 300;        % 最大迭代次数
GGAP = .9;           % 新个体
NVAR = 20;           % 变量数
PRECI = 20;          % 二进制精度
% 生成字段描述符
FieldD = [rep([PRECI],[1, NVAR]); rep([-512;512],[1, NVAR]);...rep([1; 0; 1 ;1], [1, NVAR])];
% 种群初始化
Chrom = crtbp(NIND, NVAR*PRECI);
% 重置
Best = NaN*ones(MAXGEN,1); % 最优种群
gen = 0;                   % 代数
% 评价初始种群
ObjV = objfun1(bs2rv(Chrom,FieldD));
% 跟踪最佳个体并显示收敛
Best(gen+1) = min(ObjV);
plot(log10(Best),'ro');xlabel('generation'); ylabel('log10(f(x))');
text(0.5,0.95,['Best = ', num2str(Best(gen+1))],'Units','normalized');
drawnow;
% 代数循环while gen < MAXGEN,% 为整个群体分配适应值FitnV = ranking(ObjV);% 选择个体进行繁殖SelCh = select('sus', Chrom, FitnV, GGAP);% 重组选定个体(交叉)SelCh = recombin('xovsp',SelCh,0.7);% 对后代进行突变SelCh = mut(SelCh);% 评价后代,调用目标函数ObjVSel = objfun1(bs2rv(SelCh,FieldD));% 将后代重新插入当前种群[Chrom ObjV]=reins(Chrom,SelCh,1,1,ObjV,ObjVSel);% 代数+1gen = gen+1;% 更新Best(gen+1) = min(ObjV);plot(log10(Best),'ro'); xlabel('generation'); ylabel('log10(f(x))');text(0.5,0.95,['Best = ', num2str(Best(gen+1))],'Units','normalized');drawnow;
end
% GA结束


  上述遗传算法的百度云链接为:链接:https://pan.baidu.com/s/1q-xR58bQ6IMOy4l3kKkAjw ,提取码:da3j。若在编程方面遇到其他问题,也可以私信我。

Matlab遗传算法工具箱的使用相关推荐

  1. matlab bs2rv.m,matlab遗传算法工具箱中的例子不能用?

    matlab遗传算法工具箱中的例子不能用,我也发现了,求助 figure(1); fplot('variable.*sin(10*pi*variable)+2.0',[-1,2]);   %画出函数曲 ...

  2. 基于Matlab遗传算法工具箱解决物流中心选址

    目录 1.问题 2.建模 3.Matlab编程.求解 1.问题 物流配送中6个客户的位置坐标和配数数量如表1所示,如何设置物流配数中心使得配送量最小. 2.建模 3.Matlab编程.求解 编写目标函 ...

  3. matlab bs2rv.m,matlab遗传算法工具箱gatbx(直接可用版)

    [实例简介] 这是最好用的matlab遗传算法工具箱:gatbx,工具箱可直接使用.安装说明及使用简介可见<matlab遗传算法gatbx工具箱介绍及安装说明>一文. [实例截图] [核心 ...

  4. matlab 工具箱 GATBX 的安装,安装Sheffield Matlab遗传算法工具箱的建议

    在通常的遗传算法学习中,可以直接对目标函数进行编写,但是当我们需要使用simulink进行仿真优化需要用到遗传算法时,我这里有两种建议:①在模型中添加sfunction然后使用自己喜欢的语言进行编写: ...

  5. matlab 遗传算法工具箱(GATBX)

    matlab 遗传算法工具箱(GATBX) 遇到的问题: 找不到 'bs2rv.m' 的完全匹配项(区分大小写) 最接近的匹配项为 D:\soft\Matlab2021a\toolbox\gatbx\ ...

  6. MATLAB遗传算法工具箱安装出现问题总结

    MATLAB遗传算法工具箱安装出现问题总结 参考博文 链接: link. 问题描述: 按照该博文操作后,仍出现一些问题: 输入>> [Chrom,N,Base] = crtbp(5,10) ...

  7. 《MATLAB智能算法30个案例》:第1章 谢菲尔德大学的MATLAB遗传算法工具箱

    <MATLAB智能算法30个案例>:第1章 谢菲尔德大学的MATLAB遗传算法工具箱 1. 前言 2. MATLAB 仿真示例一 3. MATLAB 仿真示例二 4. 小结 1. 前言 & ...

  8. 2021-05-11 Matlab遗传算法工具箱的使用及实例(非线性规划)

    Matlab遗传算法工具箱的使用及实例(非线性规划) 本文将介绍MATLAB遗传算法工具箱求解非线性规划问题.在阅读本文之前,建议读者阅读上一期"MATLAB遗传算法工具箱求解线性规划问题& ...

  9. MATLAB遗传算法工具箱的使用及实例(线性规划)

    一.引言 在使用遗传算法(Genetic Algorithm,GA)之前,你得了解遗传算法是干什么的.遗传算法一般用于求解优化问题.遗传算法最早是由美国的 John holland于20世纪70年代提 ...

  10. MATLAB 遗传算法工具箱与应用

    MATLAB 遗传算法工具箱是一个用于设计和实现遗传算法的工具箱,它提供了一系列函数和工具,可以帮助用户快速开发和测试遗传算法.下面是 MATLAB 遗传算法工具箱的一些基本概念和应用: 1. 遗传算 ...

最新文章

  1. SBB:长期施肥影响土壤固氮菌的群落装配过程
  2. 数据结构:希尔排序(shell sort)
  3. vue2+node+mysql demo总结
  4. 你所能用到的数据结构之番外篇---逆袭的面向对象(一)
  5. 操作系统——相关面试考点
  6. time.h中定义的函数
  7. linux文件名变量,文件名通配符、变量以及管道知识点的总结
  8. WCF学习 (三)深入认识WCF契约
  9. 为什么游戏盒子源码那么重要?(不搞清楚游戏盒子源码,游戏代理很难顺利)(远离那些免费游戏盒子源码,会变得不幸)
  10. FA:萤火虫算法的改进及Python实现
  11. 需求分析报告或需求调研报告和需求规格说明书有什么区别?
  12. 电脑pdf截长图滚动截图保存图片
  13. OMRON欧姆龙驱动器维修R88D-KT06F-Z过压故障处理
  14. MMKV_浅析 - MMKV 1.1.1
  15. Photoshop压缩png图片
  16. 通过UDR扩展GBase8s查询行为的工程实践
  17. 吹气球 Burst Balloons
  18. C#往图片上面添加文字
  19. Eclipse设置各类型文件默认打开方式
  20. 从零学前端第十七讲:小程序开发

热门文章

  1. 基于Java实现的班级信息管理系统
  2. 零基础使用 MATLAB 求解偏微分方程(建议收藏)
  3. oracle mysql认证考试流程_oraclemysql认证考试流程
  4. 产品需求文档(PRD)模板下载(附完整案例)
  5. python3.7中文手册chm_python3.7 官方中文手册文档全套
  6. MD5算法实验报告(XDU物联网安全)
  7. acer软件保护卡怎么解除_Acer软件保护卡下载
  8. 害!!安装电脑系统 分区就那么点事
  9. 前端实现成绩管理系统
  10. java 动态执行代码_java中动态执行一段代码