基于遗传优化模糊控制器的水箱水位控制系统simulink建模与仿真

目录

1.课题概述

2.系统仿真结果

3.核心程序与模型

4.系统原理简介

4.1 模糊控制器原理

4.2 遗传算法原理

4.3 遗传优化模糊控制器的工作流程

5.完整工程文件


1.课题概述

       基于遗传优化模糊控制器的水箱水位控制系统simulink建模与仿真。对比模糊控制器和基于遗传优化的模糊控制器。

2.系统仿真结果

遗传算法迭代过程:

遗传优化模糊控制和模糊控制的控制器输出对比:

3.核心程序与模型

版本:MATLAB2022a

matlab部分:

..................................................................
Areas = [];
% FIS = addvar(FIS,'input','Cost',[0.5 1.5]);
Areas = [Areas,[0.4;0.6]];
Areas = [Areas,[1.2;1.8]];


%FIS = addmf(FIS,'input',1,'Cheap','trimf', [0 0.5 0.75]);
Areas = [Areas,[0.4;0.6]];
Areas = [Areas,[0.6;0.9]];

%FIS = addmf(FIS,'input',1,'Expensive','trimf',[1.25 1.5 2]);
Areas = [Areas,[1.2;1.3]];
Areas = [Areas,[1.4;1.6]];
Areas = [Areas,[1.8;2.2]];

%FIS = addmf(FIS,'input',1,'Medium','trapmf',[0.5 0.75 1.25 1.5]);
Areas = [Areas,[0.4;0.6]];
Areas = [Areas,[0.6;0.9]];
Areas = [Areas,[1.2;1.3]];
Areas = [Areas,[1.4;1.6]];

%FIS = addvar(FIS,'input','Water level prev',[5 20]);
Areas = [Areas,[4;6]];
Areas = [Areas,[15;25]];
....................................................................


 
FieldD = [rep([10],[1,Nums]);Areas;rep([0;0;0;0],[1,Nums])];

gen   = 0;
Js    = 0.5*rand(NIND,1);
Objv  = (Js+eps);
gen   = 0; 



while gen < MAXGEN
      
      Pe0 = 0.99;
      pe1 = 0.01; 

      FitnV=ranking(Objv);    
      Selch=select('sus',Chrom,FitnV);    
      Selch=recombin('xovsp', Selch,Pe0);   
      Selch=mut( Selch,pe1);   
      phen1=bs2rv(Selch,FieldD);   
 
      for jj=1:1:NIND  
          [gen,jj]
          X           = phen1(jj,:);
          %计算对应的目标值
          [FIS2]      = func_obj(X);
          sim("GA_opt")% Simulink模型"tops"。
          load y2.mat
          dat = ans.Data;
          len = length(dat);
          E           = std(dat(len/2:len,2));
          JJ(jj,1)     = E;
      end 
      
      Objvsel=(JJ);    
      [Chrom,Objv]=reins(Chrom,Selch,1,1,Objv,Objvsel);   
      gen=gen+1; 


      Error2(gen) = mean(JJ);
end 
Error2=smooth(Error2,4);
figure
plot(Error2,'linewidth',2);
grid on
xlabel('迭代次数');
ylabel('遗传算法优化过程');
legend('Average fitness');



[V,I] = min(JJ);
X     = phen1(I,:);


.............................................................................
% 将规则列表添加到FIS中。
FIS2 = addrule(FIS, ruleList);


sim("GA_opt2")

save y3GA.mat Error2 X
54

simulink部分:

4.系统原理简介

       基于遗传优化模糊控制器的水箱水位控制系统是一种将模糊控制与遗传算法相结合的智能控制策略,旨在实现水箱水位的精确控制。模糊控制利用模糊逻辑处理不精确或不确定的信息,而遗传算法则作为一种全局优化技术,用于自动调整模糊控制器的参数,提高控制性能。

4.1 模糊控制器原理

      模糊控制基于模糊集合理论,用于处理具有语言描述而非精确数值的控制问题。对于水箱水位控制系统,模糊控制器的主要组成部分包括:

  • 输入变量:水箱当前水位(Error, e)和水位变化率(Change of Error, ce)。
  • 输出变量:阀门开度控制信号(Control, u)。

4.2 遗传算法原理

       遗传算法(Genetic Algorithm, GA)是一种模拟自然选择和遗传机制的优化算法,用于搜索模糊控制器的最优参数集,如模糊规则的隶属度函数参数、权重因子等。

编码

首先,将模糊控制器的参数编码成染色体,例如使用二进制编码或实数编码。

选择(Selection)

基于适应度函数选择个体进行繁殖,适应度函数衡量个体(即一组参数)控制性能的好坏。

交叉(Crossover)

随机选取两个父代染色体,按一定概率交换部分基因片段,生成子代。

变异(Mutation)

以小概率改变染色体上的某些基因值,增加种群多样性。

重复

经过选择、交叉、变异等操作,生成新一代种群,直到满足停止条件(如最大迭代次数或达到预定的适应度阈值)。

4.3 遗传优化模糊控制器的工作流程

  1. 初始化:随机生成初始模糊控制器参数集,用于优化模糊控制器的隶属函数的参数,构成初始种群。
  2. 评估:应用这些参数至模糊控制器模型,通过仿真评估其控制水箱水位的效果,计算适应度值。
  3. 遗传操作:基于适应度值,进行选择、交叉、变异操作,生成新一代种群。
  4. 优化迭代:重复步骤2和3,直至达到预设的迭代次数或满足收敛条件。
  5. 结果应用:选择适应度最高的个体对应的参数,作为最终的模糊控制器参数设置,实现水箱水位的优化控制。

5.完整工程文件

v

V

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Python基础详解一

一&#xff0c;print打印 print("hello word") print(hello word) 双引号和单引号都可以 二&#xff0c;数据类型 Python中常用的有6种值的类型 输出类型信息 print(type(11)) print(type("22")) print(type(22.2)) <class int> <class str&…

飞书API(7):MySQL 入库通用版本

一、引入 在上一篇介绍了如何使用 pandas 处理飞书接口返回的数据&#xff0c;并将处理好的数据入库。最终的代码拓展性太差&#xff0c;本篇来探讨下如何使得上一篇的最终代码拓展性更好&#xff01;为什么上一篇的代码拓展性太差呢&#xff1f;我总结了几点&#xff1a; 列…

深入理解 Java 并发:AbstractQueuedSynchronizer 源码分析

序言 在多线程编程中&#xff0c;同步机制是保障线程安全和协调线程之间操作顺序的重要手段。AQS 作为 Java 中同步机制的基础框架&#xff0c;为开发者提供了一个灵活且高效的同步工具。本文将通过对 AQS 源码的分析&#xff0c;解读 AQS 的核心实现原理&#xff0c;并深入探…

wireshark的安装使用及相关UDP、TCP、 ARP

初步了解&#xff1a; 进入wireshark后如图&#xff1a; 从图中可以看到很多网络连接在操作的时候我们需要监测哪些 我们可以直接在本地的运行框中输入ipconfig来查看 如图&#xff1a; 从以上图片中我们可以清楚地看到哪些网络连接已经连接的我们只需要按需监测他们即可 但…

【LinuxC语言】信号集与sigprocmask

文章目录 前言一、信号集1.1 操作信号集相关的函数1.2 信号屏蔽字1.3 sigprocmask1.4 示例代码 总结 前言 在Linux C编程中&#xff0c;信号是一种重要的进程间通信机制&#xff0c;用于通知进程发生了特定的事件。然而&#xff0c;程序在执行过程中可能会收到各种各样的信号&…

银河麒麟桌面版开机后网络无法自动链接 麒麟系统开机没有连接ens33

1.每次虚拟机开机启动麒麟操作系统&#xff0c;都要输入账号&#xff0c;密码。 进入点击这个ens33 内网才连接 2. 如何开机就脸上呢&#xff1f; 2.1. 进入 cd /etc/sysconfig/network-scripts 2.2 修改参数 onbootyes 改为yes 2.3 重启即可 a. 直接重启机器查看是否正常&…

软件工程习题答案2024最新版

习题一答案 一、选择题 软件的主要特性是(A B C)。 A) **无形 **B) 高成本 C) **包括程序和文档 ** D) 可独立构成计算机系统 软件工程三要素是(B)。 A) 技术、方法和工具 B) 方法、工具和过程 C) 方法、对象和类 D) 过程、模型、方法 包含风险分析的软件工程模型是(A)…

Reactor模型详解

目录 1.概述 2.Single Reactor 3.muduo库的Multiple Reactors模型如下 1.概述 维基百科对Reactor模型的解释 The reactor design pattern is an event handling pattern for handling service requests delivered concurrently to a service handler by one or more inputs.…

【Java基础】三大特性——封装

封装 只对外提供有用的属性和行为 方法的封装 外界不会用到的方法 class MyMath {//private私有 封装函数&#xff1a;只对外提供有用的属性和行为private void toAny(int num,int base,int offSet){……}public void toHex( int num){toAny( num,15,4);}…… } class Demo…

GNU Radio创建FFT、IFFT C++ OOT块

文章目录 前言一、GNU Radio官方FFT弊端二、创建自定义的 C OOT 块1、创建 OOT 模块2、创建 OOT 块3、修改 C 和 CMAKE 文件4、编译及安装 OOT 块 三、测试1、grc 图2、运行结果①、时域波形对比②、频谱图对比 四、资源自取 前言 GNU Radio 自带的 FFT 模块使用起来不是很方便…

新型直膨式光伏光热热泵/动力热管复合循环系统

太阳能光伏光热热泵&#xff08;即PVT热泵&#xff09;技术是建筑领域内实现碳中和的有效技术手段&#xff0c;该技术具有优越的热电冷联产能力。然而&#xff0c;现有的PVT热泵在良好的室外工况下能耗较高。为了解决这一问题&#xff0c;本文提出了一种新型的DX-PVT热泵/动力热…

书接上文,助力智能化诊断高质提效,基于轻量级CNN模型MobileNet开发构建人体手骨X光骨骼骨龄分析识别系统

骨龄是骨骼年龄的简称&#xff0c;需要借助于骨骼在X光摄像中的特定图像来确定。通常要拍摄左手手腕部位的X光片&#xff0c;医生通过X光片观察来确定骨龄。这在临床上是一件非常消耗精力和时间的一项放射临床工作。写一个骨龄可能要10多分钟去完成。如果一天要写几十个骨龄&am…

10G MAC层设计系列-(4)MAC TX模块

一、前言 MAC TX模块就是要将IP层传输过来的数据封装前导码、MAC地址、帧类型以及进行CRC校验&#xff0c;并与CRC值一块组成以太网帧。 二、模块设计 首先对输入的数据进行缓存&#xff0c;原因是在之后要进行封装MAC帧头&#xff0c;所以需要控制数据流的流动 FIFO_DATA_6…

基于K8S构建Jenkins持续集成平台

文章目录 安装和配置NFSNFS简介NFS安装 在Kubernetes安装Jenkins-Master创建NFS client provisioner安装Jenkins-Master Jenkins与Kubernetes整合实现Jenkins与Kubernetes整合构建Jenkins-Slave自定义镜像 JenkinsKubernetesDocker完成微服务持续集成拉取代码&#xff0c;构建镜…

茶树(山茶属)CCoAOMT基因家族的全基因组鉴定、表达分析和蛋白质相互作用分析-全基因组家族分析-文献精读13

Genome-wide identification, expression profiling, and protein interaction analysis of the CCoAOMT gene family in the tea plant (Camellia sinensis) 茶树&#xff08;山茶属&#xff09;CCoAOMT基因家族的全基因组鉴定、表达分析和蛋白质相互作用分析&#xff0c;一篇…

详解SDRAM基本原理以及FPGA实现读写控制(一)

文章目录 一、SDRAM简介二、SDRAM存取结构以及原理2.1 BANK以及存储单元结构2.2 功能框图2.3 SDRAM速度等级以及容量计算 三、SDRAM操作命令3.1 禁止命令&#xff1a; 4b1xxx3.2 空操作命令&#xff1a;4b01113.3 激活命令&#xff1a;4b00113.4 读命令&#xff1a;4b01013.5 写…

5分钟速通大语言模型(LLM)的发展与基础知识

✍️ 作者&#xff1a;哈哥撩编程&#xff08;视频号同名&#xff09; 博客专家全国博客之星第四名超级个体COC上海社区主理人特约讲师谷歌亚马逊演讲嘉宾科技博主极星会首批签约作者 &#x1f3c6; 推荐专栏&#xff1a; &#x1f3c5; 程序员&#xff1a;职场关键角色通识宝…

【UnityRPG游戏制作】Unity_RPG项目_玩法相关

&#x1f468;‍&#x1f4bb;个人主页&#xff1a;元宇宙-秩沅 &#x1f468;‍&#x1f4bb; hallo 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! &#x1f468;‍&#x1f4bb; 本文由 秩沅 原创 &#x1f468;‍&#x1f4bb; 收录于专栏&#xff1a;就业…

大语言模型教程与实践(开源)

1.简介 大语言模型&#xff08;Large Language Models, LLMs&#xff09;的兴起确实始于OpenAI在2018年发布的GPT&#xff08;Generative Pre-trained Transformer&#xff09;&#xff0c;这一开创性工作引领了自然语言处理领域的新纪元。随后&#xff0c;2022年底ChatGPT的横…