多种群遗传算法的函数寻优算法

2023-10-29 17:20

本文主要是介绍多种群遗传算法的函数寻优算法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

多种群遗传算法的函数寻优算法

  • 多种群遗传算法的介绍
  • 问题与思路
  • 代码
  • 结果显示

多种群遗传算法的介绍

传统的遗传算法是一种借鉴于生物界自然选择和进化机制发展起来的高度并行、随机、自适应的全局优化概率搜索算法。因为优化时不依赖于梯度,具有很强的鲁棒性和全局搜索能力。但是未成熟收敛确实遗传算法中不可忽视的现象,它主要表现为所有个体都区域同一状态而停止进化。

接下来所介绍的多种群遗传算法可以很好地解决这个问题。

多种群遗传算法主要引入了这几个概念。
1.突破SGA仅靠单个种群进行遗传进化的框架,引入多个种群进行全局搜索,不同种群用不同参数,实现不同的搜索目的。2.各种群之间通过移民算子进行联系,实现了多种群协同进化,最优解是多个种群共同进化的结果,3.通过人工算子保留每代中的最优个体,并作为判断收敛的依据。
在这里插入图片描述

问题与思路

在这里插入图片描述
这里是谢尔德工具箱的下载地址,大家可以自行前往gatbx

代码

话不多说,看Matlab代码:

% 多种群遗传算法主函数
clear
clc
nind = 40;
nvar = 1;
preci = 20;
ggap = 0.9;     % 代沟
mp = 10;    % 种群数目
field = [preci;0;1;1;0;1;1];    % 区域描述器
for i = 1:mpchrom{i} = crtbp(nind,nvar*preci);
end
gen = 0;
pc = 0.7 + (0.9-0.7)*rand(mp,1);
pm = 0.001 + (0.05-0.001)*rand(mp,1);
gen0 = 0;
maxgen = 10;
maxy = 0;   % 最优值
% 计算各初始种群的适应度
for i = 1:mpobjv{i} = objf(bs2rv(chrom{i},field));
end
maxobjv = zeros(mp,1);      % 记录精华种群
maxchrom = zeros(mp,preci*nvar);        % 记录精华种群的二进制编码
while gen0 < maxgengen = gen + 1;for i = 1:mp% 各种群的适应度fitnv{i} = ranking(-objv{i});% 选择selch{i} = select('sus',chrom{i},fitnv{i},ggap);% 交叉selch{i} = recombin('xovsp',selch{i},pc(i));% 变异selch{i} = mut(selch{i},pm(i));% 计算子代目标值objvesl = objf(bs2rv(selch{i},field));% 重插入工作[chrom{i},objv{i}] = reins(chrom{i},selch{i},1,1,objv{i},objvesl);end% 移民操作[chrom,objv] = immigrant(chrom,objv);% 人工选择精华种群[maxobjv,maxchrom] = elite(chrom,objv,maxobjv,maxchrom);yy(gen) = max(maxobjv);if yy(gen) > maxymaxy = yy(gen);gen0 = 0;elsegen0 = gen0 + 1;end
end
% 画图
plot(1:gen,yy)
xlabel('进化代数')
ylabel('最优解变化')
title('进化过程')
xlim([1,gen])
% 输出最优解
[y,i] = max(maxobjv);
x = bs2rv(maxchrom(i,:),field);
disp(['最优值为:',num2str(y)])
disp(['对应的自变量取值为:',num2str(x)])function obj = objf(x)
% 目标函数
[row,~] = size(x);
for i = 1:rowobj(i,1) = exp(((x(i,1)-0.1)/0.8)^2)*(sin(5*pi*x(i,1)))^6;
end

这里是谢尔德工具箱的下载地址,大家可以自行前往gatbx

结果显示

在这里插入图片描述
在这里插入图片描述
可以见到,多种群遗传算法对于函数寻优的效果很好,很快就得到收敛找到最优值。相较于传统的遗传算法,一般问题都需要几十代或几百代来说,效果非常好。

这篇关于多种群遗传算法的函数寻优算法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/302153

相关文章

Nginx安全防护的多种方法

《Nginx安全防护的多种方法》在生产环境中,需要隐藏Nginx的版本号,以避免泄漏Nginx的版本,使攻击者不能针对特定版本进行攻击,下面就来介绍一下Nginx安全防护的方法,感兴趣的可以了解一下... 目录核心安全配置1.编译安装 Nginx2.隐藏版本号3.限制危险请求方法4.请求限制(CC攻击防御)

C++中assign函数的使用

《C++中assign函数的使用》在C++标准模板库中,std::list等容器都提供了assign成员函数,它比操作符更灵活,支持多种初始化方式,下面就来介绍一下assign的用法,具有一定的参考价... 目录​1.assign的基本功能​​语法​2. 具体用法示例​​​(1) 填充n个相同值​​(2)

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更

PostgreSQL中rank()窗口函数实用指南与示例

《PostgreSQL中rank()窗口函数实用指南与示例》在数据分析和数据库管理中,经常需要对数据进行排名操作,PostgreSQL提供了强大的窗口函数rank(),可以方便地对结果集中的行进行排名... 目录一、rank()函数简介二、基础示例:部门内员工薪资排名示例数据排名查询三、高级应用示例1. 每

全面掌握 SQL 中的 DATEDIFF函数及用法最佳实践

《全面掌握SQL中的DATEDIFF函数及用法最佳实践》本文解析DATEDIFF在不同数据库中的差异,强调其边界计算原理,探讨应用场景及陷阱,推荐根据需求选择TIMESTAMPDIFF或inte... 目录1. 核心概念:DATEDIFF 究竟在计算什么?2. 主流数据库中的 DATEDIFF 实现2.1

MySQL中的LENGTH()函数用法详解与实例分析

《MySQL中的LENGTH()函数用法详解与实例分析》MySQLLENGTH()函数用于计算字符串的字节长度,区别于CHAR_LENGTH()的字符长度,适用于多字节字符集(如UTF-8)的数据验证... 目录1. LENGTH()函数的基本语法2. LENGTH()函数的返回值2.1 示例1:计算字符串

Python中将嵌套列表扁平化的多种实现方法

《Python中将嵌套列表扁平化的多种实现方法》在Python编程中,我们常常会遇到需要将嵌套列表(即列表中包含列表)转换为一个一维的扁平列表的需求,本文将给大家介绍了多种实现这一目标的方法,需要的朋... 目录python中将嵌套列表扁平化的方法技术背景实现步骤1. 使用嵌套列表推导式2. 使用itert

C#读写文本文件的多种方式详解

《C#读写文本文件的多种方式详解》这篇文章主要为大家详细介绍了C#中各种常用的文件读写方式,包括文本文件,二进制文件、CSV文件、JSON文件等,有需要的小伙伴可以参考一下... 目录一、文本文件读写1. 使用 File 类的静态方法2. 使用 StreamReader 和 StreamWriter二、二进

Python使用pip工具实现包自动更新的多种方法

《Python使用pip工具实现包自动更新的多种方法》本文深入探讨了使用Python的pip工具实现包自动更新的各种方法和技术,我们将从基础概念开始,逐步介绍手动更新方法、自动化脚本编写、结合CI/C... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

MySQL 中的 CAST 函数详解及常见用法

《MySQL中的CAST函数详解及常见用法》CAST函数是MySQL中用于数据类型转换的重要函数,它允许你将一个值从一种数据类型转换为另一种数据类型,本文给大家介绍MySQL中的CAST... 目录mysql 中的 CAST 函数详解一、基本语法二、支持的数据类型三、常见用法示例1. 字符串转数字2. 数字