模糊PID算法及其MATLAB仿真(1)

模糊PID算法及其MATLAB仿真(1)目录1、PID控制2、模糊控制3、模糊PID简介4、模糊自整定PID的理论内容(重点内容)4.1基本原理4.2模糊子集及其论域的确定4.3模糊规则的建立4.4模糊推理1、PID控制PID控制是及其普遍的控制方法,主要分为位置式PID和增量式PID,主要方程大家可以查看其他资料,这里就不作详细的解释了,另外还需要了解阶跃响应曲线上面的超调…

大家好,又见面了,我是你们的朋友全栈君。

目录

1、PID控制基础

2、模糊控制

3、模糊PID简介

4、模糊自整定PID的理论内容(重点内容)

4.1 基本原理

4.2 模糊子集及其论域的确定

4.3 模糊规则的建立

4.4 模糊推理

4.5、解模糊化


2020 年4月2日  由于浏览数量的增加,这里做了一些增补及修改。有问题请大家指出。


1、PID控制基础

    PID控制是极其常用的控制方法,主要分为位置式PID和增量式PID,主要方程大家可以查看其他资料,这里就不作详细的解释了,另外还需要了解阶跃响应曲线上面的超调量、稳态误差等参数的意义。

2、模糊控制

    模糊控制的发展历史和相关的论证也不说了,百度百科也有。

    相关概念扫盲(不一定准确):

相关概念 简单理解
论域 类似于值域,一般是变量的变化范围
隶属度 一般的“属于”概念是相互独立的,属于你就不属于我。隶属度则定义来了既可以属于你,也可以属于我,只是可能更属于我或更属于你
模糊语言 正大、正中、正小、零、负大、负中、负小这些定性的描述词

    其实模糊控制的提出确实很有意义,对很多领域来说都是。模糊控制的提出者Zadeh还同时搞了个“软计算”的概念,使用计算机模拟人类的直觉并将其自动化,个人觉得这种将客观现实转换到人的逻辑水平进行推理,再在物理现实实现的过程一直令人着迷,就像大数定理、哥德尔定理。现在深度神经网络的发展其实远超出当时提出的“软计算”,但是感觉如果模糊规则足够庞大复杂,仍然可以达到很高的水平。

    模糊控制还常常与专家系统等结合在一起使用,其实要发论文的话还是要结合当前的一些机器学习内容来搞。

    大家用MATLAB做一下仿真其实是有利于理解模糊控制的。

    模糊控制的隶属度函数定义有相关的理论,但是实际是很灵活的,比如你认为在论域[0,10]里面,3可以是负中、可以负小、可以负大,甚至还有一部分可能是零,只是隶属度不同。

    另外,在模糊论域的选取过程中,我们常看到的是(-6,6)这样的区间,其实这并不重要,你如果想把自己的数据套用到这个算法里面,就可以做一下线性变换,把你的论域映射到这个区间。

3、模糊PID简介

    模糊PID其实有多种,并不是单一的方法。根据其结构主要分为三种 [1](目前我查到的资料只看到以下三种):

    (1)模糊控制和PID控制各自在相应的条件下执行自己的功能,条件作为一种开关(单刀双掷),当采用模糊控制好的时候则使用模糊控制,当使用PID控制器较好时则使用PID算法。

模糊PID算法及其MATLAB仿真(1)

具体我就不画了,直接截的图。

单独的模糊控制器具有较好的鲁棒性,但由于它是离散的规则控制(主要是基于语言变量),往往在工作点附近容易引起小辐震荡(稳态误差问题),使受控系统的静态误差较大。而单独PID控制鲁棒性较差,但其积分作用可以有效消除系统稳态误差,并且在工作点附近的小范围内有较好的调节效果。因此这种双模结构结合了两者的优点,做到的优势互补。

    (2)模糊自整定PID算法(名字多:模糊自组织PID,模糊自调节PID、模糊自适应PID…)

    这种方法比较常用,也就是使用模糊规则的方式进行PID三个参数的整定,至于它是否优于PID算法,个人持怀疑态度,后湖会提到。这种方法基本就是用计算机代替人进行PID参数整定。结构如下图:

模糊PID算法及其MATLAB仿真(1)

    Robot Model 是文献 [2] 中的控制模型,这里大家要用自己的模型代替。

    这种方法本质上是PID控制,对于参数变化范围大的对象,要获得良好的相应性能,就需要对PID参数进行在线调整,模糊自整定PID就是比较好的方法。

    (3)还有一种我也是在参考文献 [1] 才见过的,文中提到这有点类似冗余控制,这个大家可以自行参考研究。

模糊PID算法及其MATLAB仿真(1)

4、模糊自整定PID的理论内容(重点内容)

4.1 基本原理

典型PID控制器的传递函数(CSDN的公式编辑器不太好用,又截图了0.0):

模糊PID算法及其MATLAB仿真(1)

 其中 Kp , Ti , Td 分别是比例增益、积分和微分时间常数。PID控制器的设计和参数整定放在模糊规则里。

4.2 模糊子集及其论域的确定

     一般PID参数在整定的时候常采用 Ziegler-Nichols 方法,这种方法对于线性或者参数变化较小的对象有良好的响应性能,但参数变化较大时则需要另外调整。Ziegler-Nichols 方法一般设:

模糊PID算法及其MATLAB仿真(1)

其中Ku、Tu分别是在比例(只有比例)控制下,系统临界稳定状态时控制器的增益和系统响应震荡周期;alpha为常数通常取 

alpha = 4。经大量的仿真计算验证,Kp、Td的调整范围由下确定:

模糊PID算法及其MATLAB仿真(1)

则对于模糊控制器的设计时论域采用如下:

模糊PID算法及其MATLAB仿真(1)

归一化处理:

模糊PID算法及其MATLAB仿真(1)

对于 alpha 值也要进行论域划分 alpha = {2,3,4,5}。

这里隶属度函数的定义就比较灵活了,我参考的书(《模糊控制原理与应用(第二版)》机械工业出版社)上面采用S,B,并经过多次调整得到隶属度函数:

模糊PID算法及其MATLAB仿真(1)

其中的 x 就可以用 Td’ 和 Kp’ 代替。而误差 e 和误差变化率 ec 可以取7语言变量,为了便于记住(其实记住会在后续步骤比较方便),NL,NM,NS,ZE,PS,PM,PL,分别对应负大、负中、负小、零、正小、正中、正大,对应的大家考虑英语怎么表示就行。隶属度函数通常取三角。

4.3 模糊规则的建立

    模糊规则主要由“if …… and……then……”的形式给出,例如:

Ri:if e is Ai and ec is Bi then Kp’ is Ci and Td’ is Di and alpha is Ei

表示第i条推理规则为当误差e在隶属度中为Ai且误差变化率ec在隶属度中为Bi时,比例系数Kp’就为Ci,微分系数就为Di并且alpha为Ei。这种推理规则大家可以从一些文献中查找,文献[2]给出了一种设计方式(不过是关于PID三个参数的)。

    模糊规则通常来源于专家知识、经验等。其本质上是一个查找表。即给定e,ec ,得出相对应的输出模糊变量。这里要注意的是 数量 的问题:对于单输入单输出(SISO)系统,假设划分为 7 * 7 的规则,那么总共可以得到 49 条不同 e 和 ec 的输出。那么对于多输入单输出(MISO)的情况下,那么模糊规则中你可以设计他们之间的关系为 and 、or 等,这时,有多少个输入,就应该有多少个模糊规则表。对于多输入多输出(MIMO)系统,则涉及到的问题就比较多了。随着输出的增加,模糊规则数会呈现指数形式增加,因此也有一些降维的解决方案,这里不做叙述。

个人揣测:模糊规则库是模糊控制的关键所在,但也是模糊控制的难点。所以很多研究模糊控制的优化都针对模糊规则的涉及。也就是所谓的专家系统、神经网络模糊之类的。

4.4 模糊推理

    模糊推理主要为根据模糊运算规则将模糊规则库中的 if then 转化成某种映射。模糊运算的规则实际上是有数学理论支撑的。最常见的运算方法有以下几种:

(1)最小运算法

    最小运算法也称 Mamdani 方法,即取隶属度函数极小值。

(2)积运算

    积运算也称 Larsen 方法,故名思意,就是取隶属度函数的乘积。

(3)算数运算

    算数运算也称 Zadeh 方法,没错,就是发明模糊控制的那个人。算数运算可以表示为:

模糊PID算法及其MATLAB仿真(1)

另外还有最大最小运算、布尔运算、标准法运算等。

    其实需要注意的主要就是模糊运算与常规的运算之间的区别。比如在模糊控制中看起来可能是交运算符(^),但是实际上是个取极小值运算。

4.5、解模糊化

    解模糊化就是要把经过模糊推理后的结果在系统中进行应用,因为模糊推理所得到的输出可能是“较大”、“适中”、“负小”这样的结果,你直接告诉你的系统是不行的。因此这里需要把这个模糊输出进行清晰化,因此解模糊也称为清晰化、去模糊化。

    解模糊化最常用的就是重心法。另外还有最大隶属度法等。其实如果你从数学的角度进行理解就懂了,模糊输出是一个类似高斯分布的隶属度函数,你想让你的系统输出准确,就应该取那个隶属度尽可能大的值,其实也就是均值或者中心。

 

参考文献:

[1] 高福学, 李伯全, 丁丽娟, et al. 链篦机篦床温度场模糊PID控制的研究与仿真[J]. 微计算机信息, 2009, 25(16):42-43.

[2] S. krishna, S. Vasu,Fuzzy PID based adaptive control on industrial robot system,Materials Today: Proceedings,Volume 5, Issue 5, Part 2,2018,Pages 13055-13060.

[3] Kudinov Y I , Kolesnikov V A , Pashchenko F F , et al. Optimization of Fuzzy PID Controller’s Parameters ☆[J]. Procedia Computer Science, 2017, 103:618-622.

[4] A tuning proposal for direct fuzzy PID controllers oriented to industrial continuous processes

[5] Khan A A , Rapal N . [IEEE 2006 IEEE International Conference on Engineering of Intelligent Systems – Islamabad, Pakistan (22-23 April 2006)] 2006 IEEE International Conference on Engineering of Intelligent Systems – Fuzzy PID Controller: Design, Tuning and Comparison with Conventional PID Controller[J]. 2006:1-6.

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/136184.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • Android 对apk进行重签名和查看签名(window 和mac)及生成签名

    Android 对apk进行重签名和查看签名(window 和mac)及生成签名标题实际上说了二个问题:查看签名和重签名先说一个简单的查看签名:第一步:将apk解压第二步:找到META-INF下的.RSA文件第三步:在mac终端或者window控制器上输入命令:keytool-printcert-filexxx.RSA回车,即可查看签名文件.将.RSA文件拖入到-file后面,即可查看:如下图重新签名…

  • 从壹开始前后端分离【 .NET Core2.0/3.0 +Vue2.0 】框架之十三 || DTOs 对象映射使用,项目部署Windows+Linux完整版[通俗易懂]

    从壹开始前后端分离【 .NET Core2.0/3.0 +Vue2.0 】框架之十三 || DTOs 对象映射使用,项目部署Windows+Linux完整版[通俗易懂]本文3.0版本文章本文内容,和netcore2.0一样,不需要更新。更新很多小伙伴在用IIS发布的时候,总是会有一些问题,文章下边 #autoid-6-0-0 我也简单的

  • 玩转电源设计,8个优选逆变电源参考方案大合辑

    玩转电源设计,8个优选逆变电源参考方案大合辑利用晶闸管电路把直流电转变成交流电,这种对应于整流的逆向过程,定义为逆变。例如:应用晶闸管的电力机车,当下坡时使直流电动机作为发电机制动运行,机车的位能转变成电能,反送到交流电网中去。又如运转着的直流电动机,要使它迅速制动,也可让电动机作发电机运行,把电动机的动能转变为电能,反送到电网中去。1、基于STM32单片机SPWM逆变电源设计功能描述:单片机采用:STM32单片机(型号:STM32F030F4P6)输出:正弦波频率:可调;幅值:可调;SPWM逆变原理:单片机SPWM驱动H桥+后级滤

  • 解决启动IIS发生意外错误 0x8ffe2740「建议收藏」

    解决启动IIS发生意外错误 0x8ffe2740「建议收藏」有时候也不知怎么搞的,你会突然间发现你的IIS启动不了了,提示“发生意外错误0x8ffe2740”这样的东东主要原因是80端口被程序占用了,请确认一下有没有程序占用了80端口,不知道怎么确认?可以用TcpView查看占用的端口然后终止这人端口其实大多情况下都是因为Xunlei或者数据库(SqlServer,Oracle)占用了,所以先把X…

  • http://mail.163.com/help/help_spam_16.htm?ip=118.186.207.7&hostid=smtp5&time=1358341921

    http://mail.163.com/help/help_spam_16.htm?ip=118.186.207.7&hostid=smtp5&time=13583419210INRMumLsiQwT0xVgvYVmNCBWS7mV8LzSeLOZGHzflL3ziBSx+iej3G1syAeYvPZxqagQ0P7mgdX/qgnEWWuIcv4cTR6ZI5QNmqULAGtRkCtCNsphAD7cLBiV7UpV7yvURpKw6H8jHyDDZc8zP5P8QF9abbRoeoTcPcDs/Ij0+JSX9fkdkqCvmUFYzy/GBb+hMWJ

  • 一文搞懂Spark的Task调度器(TaskScheduler)[通俗易懂]

    一文搞懂Spark的Task调度器(TaskScheduler)[通俗易懂]TaskScheduler的核心任务是提交TaskSet到集群运算并汇报结果。为TaskSet创建和维护一个TaskSetManager,并追踪任务的本地性及错误信息。遇到Straggle任务会放到其他结点进行重试。向DAGScheduler汇报执行情况,包括在Shuffle输出丢失时报告fetchfailed错误等信息。TaskScheduler底层调度器1.TaskScheduler原理剖析2.TaskScheduler源代码解析2.1TaskScheduler实例化源代码.

    2022年10月10日

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号