MATLAB实现二阶模糊逻辑控制系统仿真

news2025/2/2 18:06:06

1. 内容

假设某一工业过程可等效成以下二阶系统:

设计一个模糊控制器,使其能自动建立模糊规则库,保证控制规则如表1所示,这种规则可表示为:

式中,fix为取整函数;E为误差的模糊集;DE为误差导数的模糊集;α为常数。

表1 模糊控制规则

u     e


de

NB

NS

ZR

PS

PB

NB

PB

PB

PS

PS

ZR

NS

PB

PS

PS

ZR

ZR

ZR

PS

PS

ZR

ZR

NS

PS

PS

ZR

ZR

NS

NS

PB

ZR

ZR

NS

NS

NB

这样表示的模糊控制系统可以通过改变α值方便地修改如表1所示的模糊控制规则,从而自动建立系统的模糊规则库。
要求:

设计模糊控制器,使其能自动建立模糊规则库,保证系统输出尽快跟随系统输入。

要求建立脚本实现上述模糊逻辑控制系统。采样时间T=0.01秒;系统输入r(t)=1.0。观察不同α

取值时,阶跃响应的变化情况,找到匹配较佳动态性能的α

值,并进行详细的实验分析。

2. 过程

脚本:

clear all;
%被控系统建模
num=20;den=[8 6 1];
[A,b,c,d]=tf2ss(num,den);
%系统参数
T=0.01;h=T;
N=500;R=1.0*ones(1,N);
uu=zeros(1,N); yy=zeros(3,N);
ka=1;
for alpha=[0.45 0.75 0.90];
%定义输入/输出变量及其隶属度函数

fisMat=newfis('n4');
fisMat=addvar(fisMat,'input','e',[-6,6]);
fisMat=addvar(fisMat,'input','de',[-6,6]);
fisMat=addvar(fisMat,'output','u',[-6,6]);
fisMat=addmf(fisMat,'input',1, 'NB','trapmf',[-6 -6 -5 -3]);
fisMat=addmf(fisMat,'input',1,'NS','trapmf',[-5 -3 -2 0]);
fisMat=addmf(fisMat,'input',1,'ZR','trimf',[-2 0 2]);
fisMat=addmf(fisMat,'input',1,'PS','trapmf',[0 2 3 5]);
fisMat=addmf(fisMat,'input',1,'PB','trapmf',[3 5 6 6]);
fisMat=addmf(fisMat,'input',2,'NB','trapmf',[-6 -6 -5 -3]);
fisMat=addmf(fisMat,'input',2,'NS','trapmf',[-5 -3 -2 0]);
fisMat=addmf(fisMat,'input',2,'ZR','trimf',[-2 0 2]);
fisMat= addmf(fisMat,'input',2,'PS','trapmf',[0 2 3 5]);
fisMat=addmf(fisMat,'input',2,'PB','trapmf',[3 5 6 6]);
fisMat=addmf(fisMat,'output',1,'NB','trapmf',[-6 -6 -5 -3]);
fisMat=addmf(fisMat,'output',1,'NS','trapmf',[-5 -3 -2 0]);
fisMat=addmf(fisMat,'output',1,'ZR','trimf',[-2 0 2]);
fisMat=addmf(fisMat,'output',1,'PS','trapmf',[0 2 3 5]);
fisMat=addmf(fisMat,'output',1,'PB','trapmf',[3 5 6 6]);
%模糊规则矩阵
for i=1:5
         for j=1:5
                   rr(i,j)=round(alpha*i+(1-alpha)*j);
         end
end
rr=6-rr;
r1=zeros(prod(size(rr)),3);
k=1;
for i=1:size(rr,1)
         for j=1:size(rr,2)
                   r1(k,:)=[i,j,rr(i,j)];
                   k=k+1;
        end
end
[r,s]=size(r1);
r2=ones(r,2);
rulelist=[r1 r2];
fisMat=addrule(fisMat,rulelist);
%模糊控制系统仿真
Ke=30;Kd=0.2;
Ku=1.0;x=[0;0];
e=0;de=0;
for k=1:N
           e1=Ke*e;
           de1=Kd*de;
%将模糊控制器的输入变量变换到论域
      if e1>=6
             e1=6;
      elseif e1<=-6
             e1=-6;
      end
      if de1>=6;
            de1=6;
      elseif de1<=-6
             de1=-6;
      end
%计算模糊控制器的输出
      in=[e1 de1];
      uu(1,k)=Ku*evalfis(in,fisMat);
      u=uu(1,k);
      %利用四阶龙格-库塔法计算系统输出
      K1=A*x+b*u;
      K2=A*(x+h*K1/2)+b*u;
      K3=A*(x+h*K2/2)+b*u;
      K4=A*(x+h*K3)+b*u;
      x=x+(K1+2*K2+2*K3+K4)*h/6;
      y=c*x+d*u;
      yy(ka,k)=y;
%计算误差和误差微分
      e1=e;e=y-R(1,k);
      de=(e-e1)/T;
    end
    ka=ka+1;
end
%绘制结果曲线
kk=[1:N]*T;
plot(kk,yy(1,:),'r:',kk,yy(2,:),'r-.',kk,yy(3,:),'k--',kk,R,'m');
xlabel('时间');ylabel('输出');
legend('alpha=0.45','alpha=0.75','alpha=0.90');
grid on;

初始num:20

模糊系统中参数初始值:Ke=30,Kd=0.2,Ku=1.0

运行结果:

图1 alpha为0.45,0.75,0.90时的系统阶跃响应曲线

接下来修改alpha的值来进行探究:

图2 alpha=1

图3 alpha=0.5

图4 alpha=0.3

图5 alpha=0.3 开环增益(num值)为50

图6 alpha=0.3,num=20,模糊系统中Ke=50

图7 alpha=0.3,num=20,模糊系统中Ke=50,Ku=10

图8 alpha=0.3,num=20,模糊系统中Ke=100,Ku=10

图9 alpha=0.3,num=20,模糊系统中Ke=100,Ku=10,Kd=0.8

图10 alpha=0.3,num=20,模糊系统中Ke=50,Ku=10,Kd=1

图11 alpha=0.25

图12 alpha=0.251

3. 分析

从图1中我们可以看出,alpha为0.9的时候超调量最大,但是调节时间也相对较大,而为0.45的时候调节时间较小。在alpha值增加至1如图2时,与图1中0.9的曲线基本一致,继续减小alpha的值,如图3,图4所示,随着值的减小,调节时间也在减小,振荡频率在降低,但是稳态误差始终没有降低,所以在alpha值减小值0.3后,我开始改变其它参数,首先改变了开环增益num的值,如图5所示,调节时间略有减小,但是稳态误差还是没有变化,然后我开始考虑模糊系统中的Ke,Kd,Ku这三个参数的调节,首先增大Ke值,如图6所示,稳态误差终于减小了,但是同时系统超调也有增加,再增大Ku的值为1,图7所示曲线上升时间加快,振荡频率加大,但是稳态误差没有改变,此时若继续增大Ke值为100,图8所示曲线稳态误差继续减小,超调也会增加,保持此时的状态,我开始逐渐再增加Kd的值,如图9和图10所示,系统超调减小,但是响应时间增加了。将参数恢复初始状态,当alpha值减小到0.25后,如图11所示曲线先上升然后一直下降趋向于0,但是我将alpha调整为0.251如图12时,曲线还接近alpha为0.3时的曲线,也就是说alpha在0.25的时候会有一次较大的改变。综上所述,我们可以推测,Ke变大缩短上升时间,但是增大系统超调。Kd变大减小系统超调,但是响应速率变慢。Ku过小,系统的动态响应过程变长,Ku过大会导致系统震荡。我们需要综合调整以上三个因子,获得所需要的控制性能。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

惯性导航---常用坐标系

惯性导航—常用坐标系 捷联惯导系统的导航解算中&#xff0c;常用到四个坐标系&#xff0c;接下来介绍四个坐标系定义及其表示符号。 1 地心惯性坐标系&#xff08;i系&#xff09; 惯性传感器的输出是以该坐标系为参考基准的。 原点X轴Z轴Y轴地球中心赤道平面内&#xff0c…

《数字化运维路线图》第三部分-数字化运维转型平台 震撼发布!

数字化转型已不再是企业追求效益最大化的手段&#xff0c;而是成为经济发展变革、提升国家数字竞争的核心动力。在此背景下&#xff0c;博睿数据继续发力&#xff0c;隆重推出「数字化运维转型平台」&#xff0c;汇聚了我们对数字化转型的深刻洞见与实践经验&#xff0c;以期为…

【android】 android->profile 查看内存泄露

目录 实例讲解 各字段解释 实例讲解 各字段解释 在 Android Studio 的 Profile 视图中&#xff0c;Arrange by Stack 用于对内存分配和释放事件进行堆栈排列&#xff0c;以便更好地了解内存使用情况。以下是表上各列的一般含义&#xff1a; 1. **Call Chart (调用图)**: …

开发桌面端应用,使用electron-vite构建项目真的是一绝!

技术栈&#xff1a;electron v28.2.1、react v18.2.0 构建工具&#xff1a;electron-vite v2.0.0 项目打包&#xff1a;electron-builder v24.9.1 本教程为项目工程的搭建&#xff0c;相关技术的知识请各自学习。 Vite在当下绝对是非常卓越的前端构建工具&#xff0c;很多项目…

小型内衣裤洗衣机哪个牌子好?家用小型洗衣机推荐

相信对于很多用户而言&#xff0c;宁愿强撑着疲惫的身子手洗内衣裤&#xff0c;也不愿把内衣裤与外穿衣物一起放进洗衣机洗。内衣裤与外穿衣物的脏污情况不同&#xff0c;内衣裤是贴身衣物&#xff0c;上面留有人体的汗液和分泌物&#xff0c;有可能带有大量真菌。而外衣上则是…

springboot146基于Spring Boot的可盈保险合同管理系统的设计与实现

可盈保险合同管理系统 摘 要 现代经济快节奏发展以及不断完善升级的信息化技术&#xff0c;让传统数据信息的管理升级为软件存储&#xff0c;归纳&#xff0c;集中处理数据信息的管理方式。本可盈保险合同管理系统就是在这样的大环境下诞生&#xff0c;其可以帮助管理者在短时…

MtfLive直播导航PHP源码,附带系统搭建教程

将自动采集斗鱼、虎牙、触手、YY、章鱼、电视直播按分类/关键词聚合&#xff0c;用户选择分类&#xff0c;可以观看到全网该关键词下正在直播的内容。 特点 PC站和H5移动站自适应 自动缓存&#xff0c;避免频繁抓取数据 自定义抓取采集规则&#xff0c;同时支持HTML和JSON …

【C++游戏开发-01】推箱子

C游戏开发 文章目录 C游戏开发[TOC](文章目录) 前言一、逻辑分析1.1地图实现1.2人物的移动1.2.1小人移动1.2.2其他移动 1.3墙壁的碰撞1.4箱子的推动1.4.1什么时候推箱子1.4.2什么情况可以推箱子 1.5胜利的判断1.6卡关的处理1.7关卡的切换 二、DEMO代码2.1游戏框架2.2各功能函数…

C++学习Day01之using声明以及using编译指令

目录 一、程序1.1 using声明1.2 using声明与就近原则1.3 using编译指令与就近原则1.4 多个using编译指令 二、分析与总结 一、程序 1.1 using声明 #include<iostream> using namespace std;namespace KingGlory {int sunwukongId 1; } void test01() {//1、using声明u…

立体车库行业分析:未来3-5年将保持每年25%-40%左右的增速

机械式的停车库的采用从节省土地资源、有效利用空间为目的的单一需求&#xff0c;向节能、环保、美化环境、节省投资等很多的有用方式来进行用途性转变&#xff0c;从被动的形式到主动的来进行一定的变化&#xff0c;也因此提高了这种停车形式的使用性价值点。 中国机械停车设备…

vit细粒度图像分类(六)FBSD学习笔记

1.摘要 从判别局部区域学习特征表示在细粒度视觉分类中起着关键作用。利用注意机制提取零件特征已成为一种趋势。然而&#xff0c;这些方法有两个主要的局限性:第一&#xff0c;它们往往只关注最突出的部分&#xff0c;而忽略了其他不明显但可区分的部分。其次&#xff0c;他们…

MySQL亿级数据的查询优化-历史表该如何建

前端时间在知乎上看到一个问题&#xff0c;今天有空整理并测试了一下&#xff1a; 这个问题很具体&#xff0c;所以还是可以去尝试优化一下&#xff0c;我们基于InnoDB并使用自增主键来讲。 比较简单的做法是将历史数据存放到另一个表中&#xff0c;与最近的数据分开。那是不是…

解决nginx: [error] open() "/usr/local/nginx/logs/nginx.pid" failed错误

在往nginx.conf文件中添加tcp负载均衡的配置之后&#xff0c;使用./nginx -s reload启动&#xff0c;发现报错。 遂搜寻解决方法&#xff0c;最后通过nginx -c指定nginx.conf文件的路径&#xff0c;解决了问题。 /usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.…

2024 高级前端面试题之 HTTP模块 「精选篇」

该内容主要整理关于 HTTP模块 的相关面试题&#xff0c;其他内容面试题请移步至 「最新最全的前端面试题集锦」 查看。 HTTP模块精选篇 1. HTTP 报文的组成部分2. 常见状态码3. 从输入URL到呈现页面过程3.1 简洁3.2 详细 4. TCP、UDP相关5. HTTP2相关6. https相关7. WebSocket的…

数据库建模之PowerDesigner创建概念模型

数据模型&#xff08;Data Model&#xff09;是数据特征的抽象&#xff0c;它从抽象层次上描述了系统的静态特征、动态行为和约束条件&#xff0c;为数据库系统的信息表示与操作提供一个抽象的框架。数据模型所描述的内容有三部分&#xff0c;分别是数据结构、数据操作和数据约…

Qwen-VL 技术报告总结

感谢如此优秀的开源工作,仓库链接 Qwen-VL 权重分为 Qwen-VL && Qwen-VL-Chat,区别文档稍后介绍 训练过程 在第一阶段中主要使用224X224分辨率训练,训练数据主要来源是公开数据集,经过清洗,数据总量大约是1.4B,中文数据和英文j训练目标是视觉语言和文本语言对齐。…

【MySQL】——用SQL语句实现数据库和基本表的创建

&#x1f383;个人专栏&#xff1a; &#x1f42c; 算法设计与分析&#xff1a;算法设计与分析_IT闫的博客-CSDN博客 &#x1f433;Java基础&#xff1a;Java基础_IT闫的博客-CSDN博客 &#x1f40b;c语言&#xff1a;c语言_IT闫的博客-CSDN博客 &#x1f41f;MySQL&#xff1a…

Windows Server 2019 Web服务器搭建

系列文章目录 提示&#xff1a;这里可以添加系列文章的所有文章的目录&#xff0c;目录需要自己手动添加 例如&#xff1a;第一章 Python 机器学习入门之pandas的使用 提示&#xff1a;写完文章后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目…

【Java】实现图书管理系统

文章目录 1. 设计背景2. 需求分析3. 设计思路4. 实现4.1 book包4.1.1 Book类4.1.2 BookList类(书架) 4.2 user包4.2.1 User 类4.2.2 AdminUser类&#xff08;管理员用户&#xff09;4.2.3 NormalUser类&#xff08;普通用户&#xff09; 4.3 operation包4.3.1 IOPeration接口4.…

产学研交流 | 广东轻工职业技术学院莅临调研

产学研融合是当前教育发展的重要趋势&#xff0c;通过学校与企业之间的深度合作&#xff0c;提高学生的实践能力和创新精神&#xff0c;同时促进企业的技术进步和产业升级。 近日&#xff0c;广东轻工职业技术学院杨军主任、骨干教师丁向荣莅临科东软件&#xff0c;双方就“产学…