【Matlab】智能优化算法_亨利气体溶解度优化算法HGSO

【Matlab】智能优化算法_亨利气体溶解度优化算法HGSO

  • 1.背景介绍
  • 2.数学模型
    • 2.1 亨利定律
    • 2.2 HGSO
  • 3.文件结构
  • 4.伪代码
  • 5.详细代码及注释
    • 5.1 Create_Groups.m
    • 5.2 Evaluate.m
    • 5.3 fun_checkpoisions.m
    • 5.4 fun_getDefaultOptions.m
    • 5.5 HGSO.m
    • 5.6 main.m
    • 5.7 sumsqu.m
    • 5.8 update_positions.m
    • 5.9 update_variables.m
    • 5.10 worst_agents.m
  • 6.运行结果
  • 7.参考文献

1.背景介绍

以亨利定律的行为为基础,为HGSO提供了启示。亨利定律,由J.W.亨利于1800年首次提出。总的来说,在特定的温度或压力下,能够溶解在特定量的溶剂中的最大溶质量称为溶解度。因此,HGSO的行为受到了亨利定律的启发。根据等式(1)至(5),亨利定律可用于确定低溶解度气体在液体中的溶解度。

此外,温度和压力是影响溶解度的两个因素;在高温下,固体变得更易溶解,而气体则不易溶解。对于压力,气体的溶解度随着压力的增加而增加。我们的研究涉及气体的溶解度,如图1所示。

在这里插入图片描述

2.数学模型

2.1 亨利定律

1803年,威廉·亨利制定了亨利定律,即气体定律。亨利定律规定:在恒定温度下,溶解在给定类型和体积的液体中的给定气体的量与该气体与该液体平衡的分压成正比。因此,亨利定律高度依赖于温度,并表明气体的溶解度(Sg)与气体的分压(Pg)成正比,如以下方程所示:

在这里插入图片描述

其中H是亨利常数,该常数在给定温度下对于给定的气体-溶剂组合是特定的,并且气体的分压由Pg表示。

此外,还必须考虑温度对亨利定律常数的影响。亨利定律常数随系统温度的变化而变化,可以用Van’t Hoff方程描述如下:

在这里插入图片描述

其中∇sol E是溶解焓,R是气体常数,A和B是H的T依赖性的两个参数。因此,方程(1)可以积分如下:

在这里插入图片描述

其中H是参数a和B的函数,其中a和B是H的T依赖性的两个参数。或者,可以在参考温度T=298.15K下基于H创建表达式。

在这里插入图片描述

Van’t Hoff方程是有效的,当∇sol E是一个常数时,因此,方程(4)可以重新表述如下:

在这里插入图片描述

2.2 HGSO

步骤1:初始化过程。气体的数量(种群大小N)和气体的位置基于以下等式初始化:

在这里插入图片描述

其中,种群N中第i个气体的位置由X(i)表示,r是0和1之间的随机数,Xmin、Xmax是问题的边界,t是迭代时间。气体i的数量、类型j的亨利常数值(Hj(t))、簇j中气体i的分压Pi,j和类型j(Ci)的∇solE/R常数值使用以下方程初始化:

在这里插入图片描述

其中,l1、l2和l3分别定义为值等于(5E−02、100和1E−02)的常数。

步骤2:聚类。种群因子被划分为等同于气体类型数量的相等簇。每个星团都有相似的气体,因此具有相同的亨利常数值(Hj)。

步骤3:评估。对每个簇j进行评估,以从其类型中的其他簇中识别出达到最高平衡状态的最佳气体。然后,对气体进行排序,以获得整个群体中的最佳气体。

步骤4:更新亨利系数。亨利系数根据以下方程式进行更新:

在这里插入图片描述

其中,Hj是簇j的亨利系数,T是温度,Tθ是常数,等于298.15,iter是迭代总数。

步骤5:更新溶解度。溶解度根据以下方程式进行更新:

在这里插入图片描述

其中Si,j是气体i在簇j中的溶解度,Pi,j是簇j中气体i的分压,K是常数。

步骤6:更新位置。职位更新如下:

在这里插入图片描述

其中气体i在簇j中的位置表示为X(i,j),并且r和t分别是随机常数和迭代时间。X(i,best)是簇j中最好的气体i,而Xbest是群中最好的气。此外,γ是团簇i中气体j与其团簇中气体相互作用的能力,α是其他气体对团簇j中气体i的影响,等于1,β是常数。F(i,j)是簇j中气体i的适应度,相反,Fbest是整个系统中最佳气体的适应度。F是改变搜索代理方向并提供分集=±的标志。

X(i,best)和Xbest是负责平衡勘探和开发能力的两个参数。具体而言,X(i,best)是簇j中最好的气体i,而Xbest是群中最好的气。

步骤7:逃离局部最优。此步骤用于脱离局部最优。使用以下等式对最差代理的数量(Nw)进行排序和选择:

在这里插入图片描述

其中N是搜索代理的数量。

步骤8:更新最差代理的位置。

在这里插入图片描述

其中,G(i,j)是气体i在簇j中的位置,r是随机数,Gmin,Gmax是问题的边界。

最后,给出了该算法的伪代码,包括初始种群大小、种群评估和更新参数。

3.文件结构

在这里插入图片描述

Create_Groups.m					% 创建组
Evaluate.m						% 评估位置
fun_checkpoisions.m				% 检查位置
fun_getDefaultOptions.m 		% 获得默认选项
HGSO.m 							% 亨利气体溶解度优化算法
main.m							% 主函数
sumsqu.m 						% 归属权
update_positions.m 				% 更新位置
update_variables.m 				% 更新变量
worst_agents.m 					% 获取最差代理

4.伪代码

在这里插入图片描述

5.详细代码及注释

5.1 Create_Groups.m

function[Group]=Create_Groups(var_n_gases,var_n_types,X)
N=var_n_gases/var_n_types;
i=1;
for j=1:var_n_typesGroup{j}.Position=X(i:i+N,:);i=j*N+1;if i+N>var_n_gasesi= j*N;end
end
end

5.2 Evaluate.m

function [X,best_fit,best_pos] = Evaluate(objfunc,var_n_types,var_n_gases, X,Xnew,init_flag)
if init_flag==1for j=1:var_n_gases/var_n_typesX.fitness(j) = objfunc(X.Position(j,:));endelsefor j=1:var_n_gases/var_n_typestemp_fit = objfunc(Xnew.Position(j,:));if temp_fit<X.fitness(j)X.fitness(j)=temp_fit;X.Position(j,:)= Xnew.Position(j,:);endend
end
[best_fit,index_best]=min(X.fitness(:));
best_pos=X.Position(index_best,:);
end

5.3 fun_checkpoisions.m

function Group=fun_checkpoisions(dim,Group,var_n_gases,var_n_types,var_down,var_up)
Lb=var_down*ones(1,dim);
% Upper bounds
Ub=var_up*ones(1,dim);
for j=1:var_n_typesfor i=1:var_n_gases/var_n_typesisBelow1 = Group{j}.Position(i,:) < Lb;isAboveMax = (Group{j}.Position(i,:) > Ub);if isBelow1 == trueGroup{j}.Position(i,:) =Lb;elseif find(isAboveMax== true)Group{j}.Position(i,:) = Ub;endendend
end

5.4 fun_getDefaultOptions.m

function [var_n_gases,var_n_types,var_niter] = fun_getDefaultOptions()
var_n_gases          = 35;       % The swarm size.
var_n_types         = 5;       % The number of group.
var_niter          = 1000;      % The number of iterations.end

5.5 HGSO.m

function [vec_Xbest, var_Gbest,vec_Gbest_iter] = HGSO(objfunc, dim,var_down,var_up,var_niter,var_n_gases,var_n_types)
if nargin<5[var_n_gases,var_n_types,var_niter]=fun_getDefaultOptions();
end
%constants in eq (7)
l1=5E-03;
l2=100;
l3=1E-02;
%constants in eq (10)
alpha=1;
beta=1;
%constant in eq (11)
M1=0.1;
M2=0.2;
%paramters setting in eq. (7)
K=l1*rand(var_n_types,1);
P=l2*rand(var_n_gases,1);
C=l3*rand(var_n_types,1);
%randomly initializes the position of agents in the search space
X=var_down+rand(var_n_gases,dim)*(var_up-var_down);
%The population agents are divided into equal clusters with the same Henry痴 constant value
Group=Create_Groups(var_n_gases,var_n_types,X);
% Compute cost of each agent
for i = 1:var_n_types[Group{i},best_fit(i),  best_pos{i}] = Evaluate(objfunc,var_n_types,var_n_gases, Group{i},0,1);
end
[var_Gbest, var_gbest] = min(best_fit);
vec_Xbest = best_pos{var_gbest};
for var_iter = 1:var_niter[S]=update_variables(var_iter,var_niter,K,P,C,var_n_types,var_n_gases);Groupnew=update_positions(Group,best_pos,vec_Xbest,S,var_n_gases,var_n_types,var_Gbest,alpha,beta,dim);Groupnew=fun_checkpoisions(dim,Groupnew,var_n_gases,var_n_types,var_down,var_up);for i = 1:var_n_types[Group{i},best_fit(i),  best_pos{i}] = Evaluate(objfunc,var_n_types,var_n_gases, Group{i},Groupnew{i},0);Group{i}=worst_agents(Group{i},M1,M2,dim,var_up,var_down,var_n_gases,var_n_types);end[var_Ybest, var_index] = min(best_fit);vec_Gbest_iter(var_iter)=var_Ybest;if var_Ybest<var_Gbestvar_Gbest=var_Ybest;vec_Xbest = best_pos{var_index};endend
end

5.6 main.m

clc;clear all;
close all;
fitfun = @sumsqu;
dim=30;
var_niter=1000;
Lb=-10;
Ub=10;
% var_n_gases=35;
% var_n_types=5;
[xf,fval,vec_Gbest_iter]=HGSO(fitfun,dim,Lb,Ub);
figure,
semilogy(vec_Gbest_iter,'r')
xlim([0 var_niter]);

5.7 sumsqu.m

function [y] = sumsqu(xx)d = length(xx);
sum = 0;
for ii = 1:dxi = xx(ii);sum = sum + ii*xi^2;
endy = sum;end

5.8 update_positions.m

function [Group]=update_positions(Group,best_pos,vec_Xbest,S,var_n_gases,var_n_types,var_Gbest,alpha,beta,var_nvars)
vec_flag=[1,-1];
for i=1:var_n_types    for j=1:var_n_gases/var_n_types;gama=beta*exp(-(var_Gbest+.05)/(Group{i}.fitness(j)+.05));flag_index = floor(2*rand()+1);var_flag=vec_flag(flag_index);for k=1:var_nvarsGroup{i}.Position(j,k)=  Group{i}.Position(j,k)+var_flag*rand*gama*(best_pos{i}(k)-Group{i}.Position(j,k))+rand*alpha*var_flag*(S(i)*vec_Xbest(k)-Group{i}.Position(j,k));endend
end
end

5.9 update_variables.m

function [S]=update_variables(var_iter,var_niter,K,P,C,var_n_types,var_n_gases)
T=exp(-var_iter/var_niter);
T0= 298.15;
i=1;
N=var_n_gases/var_n_types;
for j=1:var_n_typesK(j)=K(j)*exp(-C(j)*(1/T-1/T0));S(i:i+N,:)=P(i:i+N,:)*K(j);i=j*N+1;if i+N>var_n_gasesi= j*N;end
end
end

5.10 worst_agents.m

function [X]=worst_agents(X,M1,M2,dim,G_max,G_min,var_n_gases,var_n_types)
%Rank and select number of worst agents eq.(11)[X_sort,X_index]=sort(X.fitness(:),'descend');M1N =M1*var_n_gases/var_n_types;M2N = M2*var_n_gases/var_n_types;Nw = round((M2N-M1N).*rand(1,1) + M1N);for k=1:NwX.Position(X_index(k),:)=G_min+rand(1,dim)*(G_max-G_min);endend

6.运行结果

在这里插入图片描述

7.参考文献

[1]Hashim A F,Houssein H E,Mabrouk S M, et al. Henry gas solubility optimization: A novel physics-based algorithm[J]. Future Generation Computer Systems,2019,101©.

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/18397.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

微信小程序input的placeholder脱离文档流

今天进行真机调试时input的提示词 placeholder脱离了文档流&#xff0c;但是奇怪的是input框没有脱离文档流 如下图所示&#xff1a; 微信开发工具正常&#xff1a; 真机&#xff1a;不正常 脱离文档流 解决方法&#xff1a; <view clas…

【NeRF】相机的内外参是什么?单目相机是如何成像的?

文章目录 【NeRF】相机的内外参是什么&#xff1f;单目相机是如何成像的&#xff1f;1.相机外参2.相机内参 【NeRF】相机的内外参是什么&#xff1f;单目相机是如何成像的&#xff1f; 在做Nerf时对其中的一些原理感到困惑&#xff0c;因而把这些基础理论知识总结下来&#xff…

【工业机器人】用于轨迹规划和执行器分析的机械手和移动机器人模型(MatlabSimulink)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

1、vscode+cmake c++环境配置

文章目录 1、安装2、开发环境 关于vscode c环境的配置&#xff0c;应该有两种一种是vscodec/c插件&#xff0c;另一种是vscodecmake插件&#xff0c;第一种没太多用过&#xff0c;感觉就像python那样&#xff0c;要写相关配置文件&#xff0c;有自己的一套规则&#xff1b;另一…

【数据结构导论】第 6 章:查找

目录 一、基本概念 二、静态查找表 &#xff08;1&#xff09;顺序表上的查找 —— 顺序查找 ① 过程 ② 算法 ③ 算法分析 &#xff08;2&#xff09;有序表上的查找 —— 二分查找 ① 二分查找思想 ② 二分查找过程 ③ 二分查找算法 ④ 示例 ⑤ 算法分析 &#…

选读SQL经典实例笔记05_日期运算(下)

1. 两个日期之间相差的月份和年份 1.1. DB2 1.2. MySQL 1.3. sql select mnth, mnth/12from ( select (year(max_hd) - year(min_hd))*12 (month(max_hd) - month(min_hd)) as mnthfrom (select min(hiredate) as min_hd, max(hiredate) as max_hdfrom emp) x) y 1.4. Or…

ModaHub魔搭社区:向量数据库Zilliz Cloud的AUTOINDEX教程

目录 创建索引和向量搜索 总结 为满足用户不同需求,Zilliz Cloud 提供 3 种类型的集群 CU——性能型、容量型和经济型。但是,为不同类型 CU 集群中的 Collection 创建索引时,通常需要根据所选择的 CU 类型调整索引参数。为了方便您创建索引,免去调节参数的麻烦,Zilliz C…

stm32 使用CubeIDE 移植RTX5

STM32 使用st的官方开发环境 cubeide &#xff08;eclipse gcc&#xff09;移植 cmsis rtos2 RTX5 实时操作系统 这套环境的主要优势是免费。cubeide免费使用。RTX5 免商业版税&#xff08;已从原keil中剥离出来&#xff0c;现在完全开源免费&#xff09;。 一&#xff0c;环…

偏振光的斯托克斯矢量表示法

《光纤偏振模色散原理 测量与自适应补充技术》张晓光 第二章

深入理解Linux网络——内核是如何发送网络包的

文章目录 一、相关实际问题二、网络包发送过程总览三、网卡启动准备四、数据从用户进程到网卡的详细过程1&#xff09;系统调用实现2&#xff09;传输层处理1. 传输层拷贝2. 传输层发送 3&#xff09;网络层发送处理4&#xff09;邻居子系统5&#xff09;网络设备子系统6&#…

智能机器人嵌入ChatGPT会给社会带来哪些进步

智能机器人技术在当今世界中扮演着越来越重要的角色&#xff0c;而其中一个令人印象深刻的例子就是ChatGPT。ChatGPT是一种基于人工智能的对话系统&#xff0c;它利用强大的自然语言处理和生成模型&#xff0c;可以与人类进行自然而流畅的对话。ChatGPT内置了智能机器人技术&am…

92.qt qml-日期/日期时间/时间选择器(日历选择器)

截图如下所示: 效果图如下所示: 1.前言 QML日历组件我们之前移植过: 67.qt quick-qml自定义日历组件(支持竖屏和横屏)_qml日历_诺谦的博客-CSDN博客 但是该组件内部代码比较坑的就是全部使用自定义对象,导致性能不行,动画卡顿,并且不好加时间选择,所以本章我们重新学…