智能控制 第2章 模糊控制仿真简介(2)讲解

上传人:我** 文档编号:116810221 上传时间:2019-11-17 格式:PPT 页数:77 大小:2.08MB
返回 下载 相关 举报
智能控制 第2章 模糊控制仿真简介(2)讲解_第1页
第1页 / 共77页
智能控制 第2章 模糊控制仿真简介(2)讲解_第2页
第2页 / 共77页
智能控制 第2章 模糊控制仿真简介(2)讲解_第3页
第3页 / 共77页
智能控制 第2章 模糊控制仿真简介(2)讲解_第4页
第4页 / 共77页
智能控制 第2章 模糊控制仿真简介(2)讲解_第5页
第5页 / 共77页
点击查看更多>>
资源描述

《智能控制 第2章 模糊控制仿真简介(2)讲解》由会员分享,可在线阅读,更多相关《智能控制 第2章 模糊控制仿真简介(2)讲解(77页珍藏版)》请在金锄头文库上搜索。

1、2.3模糊控制系统仿真简介参考文献:石辛民编著.模糊控制及其MATLAB仿真.北京:清华大学出版社北京交通大学出版社2008.32.3.1MATLAB模糊逻辑工具箱工具命令行函数(以.m文件存放)图形交互工具(GUIGraphicalUserInterface)(图形用户界面)接口仿真逻辑模块(Simulink环境)建立模糊逻辑推理系统一、图形交互工具箱提供的图形化工具有五类:模糊推理系统编辑器Fuzzy隶属度函数编辑器Mfedit(Membershipfunction)模糊规则编辑器Ruleedit模糊规则观察器Ruleview模糊推理输入输出曲面视图Surfview(Surface)模糊推

2、理系统编辑器Fuzzy处理最顶层构建问题,例如输入输出变量的数目、变量名等激活(进入)方法:命令窗口(commandwindow)执行Fuzzy命令。激活模糊推理系统系统编辑器:组成输入模糊变量图形框双击Mfedit模糊规则图形框双击Ruleedit输出模糊变量图形框双击Mfedit基本属性基本属性包括:1.模糊集合合成运算(连接词的运算)andmin(最小法)prod(乘积法)ormax(最大法)prober(概率法)prober(ab)=a+b-ab2.蕴涵计算(Implication)minprod(乘积法)3.输出的合成计算Aggregation(模糊规则综合采用的方法)Aggrega

3、tionmaxprober(概率法)sum(求和法)prober(ab)=a+b-ab4.逆模糊化计算(Defuzzification)centroid(重心法)mom(平均最大隶属度法)som(最大隶属度函数中的取最小值法)bisector(面积平分法)lom(最大隶属度函数中的取最大值法)在命令窗口键入mfedit可激活隶属度函数编辑器二、命令函数1、隶属度函数函数trimf(仅介绍该函数)格式:y=trimf(xabc)其中:参数x指定变量论域范围,参数ab和c指定三角形函数的形状,该函数在b点处取最大值1,ac点为0。例:建立三角形隶属度函数并绘制曲线。x=0:0.1:10y=trim

4、f(x368)plot(xy)xlable(trimfP=368)功能:建立三角形隶属度函数。函数trapmf(trap表示trapezium梯形)格式:y=trapmf(xabcd)其中:参数x指定变量论域范围,参数abc和d指定梯形隶属度函数的形状,该函数在bc点处取最大值1,ad点为0。功能:建立梯形隶属度函数。例:x=0:0.1:10y=trapmf(x1578)plot(xy)xlable(trapmfP=1578)函数gaussmf格式:y=gaussmf(xsigc)功能:建立高斯型隶属度函数。其中:参数x指定变量论域范围,参数c决定了函数的中心点,sig决定了函数曲线的宽度。高

5、斯函数的表达式为:例:x=0:0.1:10y=gaussmf(x25)plot(xy)xlable(gaussmfP=25)函数zmf格式:y=zmf(xab)功能:建立Z型隶属度函数。说明:曲线在(ab)之间是光滑的样条曲线,在a左段为1,b右段为0跳跃点是(a+b)2。参数x指定变量论域范围。例:x=0:0.1:10y=zmf(x28)plot(xy)xlable(zmfP=28)函数smf格式:y=smf(xab)功能:建立S型隶属度函数。说明:曲线在(ab)之间是光滑的样条曲线,在a左段为0,b右段为1跳跃点是(a+b)2。参数x指定变量论域范围。例:x=0:0.1:10y=smf(x

6、28)plot(xy)xlable(smfP=28)2、模糊逻辑系统输入输出变量及隶属度函数的添加函数addvar功能:向模糊推理系统中添加语言变量。格式:a=addvar(avarTypevarNamevarBounds)说明:参数列表中,a为模糊推理系统对应的矩阵变量名,varType用于指定语言变量的类型为字符型(如或output);varName用于指定语言变量的名;varBounds用于指定语言变量的论域范围。注意:对于添加到同一个模糊推理系统的语言变量,按先后顺序自动编号,编号从1开始,逐渐递增。对于分属于输入与输出的不同语言变量则独立地分别编号。例:a=newfis(tipper

7、)创建并返回一个新的FIS系统a=addvar(aservice010)getfis(a1)取得FIS的部分或全部属性函数addmf功能:向模糊推理系统的语言变量添加隶属度函数。格式:a=addmf(avarTypevarIndexmfNamemfTypemfParams)说明:隶属度函数只能为模糊推理系统中已经存在的某一语言变量的语言值添加隶属度函数。参数列表中,a为模糊推理系统对应的矩阵变量名,varType指定语言变量类型的字符串(如或output);varIndex指定语言变量编号的数字;mfName指定隶属度函数名称;mfType指定隶属度函数类型;mfParams指定隶属度函数的参

8、数。注意:对于每个语言变量的隶属度函数按该函数被添加的顺序编号,编号从1开始,依次递增。例:a=newfis(tipper)a=addvar(aservice010)a=addmf(a1poorguassmf1.50)a=addmf(a1goodguassmf1.55)a=addmf(a1excellentguassmf1.510)plot(a1)3、FIS系统相关操作函数newfis功能:创建并返回一个新的模糊推理系统。格式:a=newfis(fisName)函数readfis功能:从磁盘中读出并返回模糊推理系统结构变量。格式:Fismat=readfis(filename)例:fismat

9、=readfis(tipper)tipper.fis已经存在说明:打开一个由filename指定的数据文件(.fis),并将其加载到当前的工作空间(Workspace)中的变量Fismat中。函数getfis功能:取得模糊推理系统的部分或全部属性。格式:getfis(a)显示系统所有属性getfis(afisprop)显示系统某一属性getfis(avartypevarindexvarprop)例:a=readfis(tipper)getfis(a)输出结果:Name=tipperType=mamdaniNums=2例:getfis(a1)注:属性为或output时,后面的第三个参数指定某一个

10、输入或输出语言变量。输出结果:Name=serviceNumMFs=3MFLabels=poorgoodexcellentRange=010例:getfis(a1name)输出结果:service函数showfis功能:以分行的形式显示模糊推理系统矩阵的所有属性。格式:showfis(fismat)函数writefis功能:将以矩阵形式保存在内存中的模糊推理系统的数据写入磁盘文件中。格式:writefis(fismatfilename)例:writefis(amy_file)typemy_file.fis函数setfis功能:设置、改变模糊推理系统的属性。格式:FIS2=setfis(fis1

11、fispropnamenewPropValue)说明:参数fis1指明模糊推理系统的名称;fispropname指明模糊推理系统的全局属性;newPropValue指明此属性的新值。例:a=readfis(tipper)a2=setfis(aDefuzzmom)Defuzzification:centroid(重心法:系统默认)mom(平均最大隶属度法)som(最大隶属度函数中的取最小值法)bisector(面积平分法)lom(最大隶属度函数中的取最大值法)4、系统图形显示函数函数plotfis功能:绘制模糊推理系统的推理过程结构框图。例:plotfis(tipper)函数plotmf功能:绘

12、制语言变量所有语言值的隶属度函数曲线。格式:plotmf(fismatvarTypevarIndex)说明:参数fismat指明模糊推理系统的对应矩阵变量名称;varType指明变量类型(或output);varIndex指明输入或输出语言变量的编号。例:plotmf(a2)5、模糊规则建立函数addrule功能:向模糊推理系统添加模糊规则。格式:a=addrule(arulelist)说明:参数a为模糊推理系统对应的矩阵变量名称,rulelist以向量的形式给出需要添加的模糊规则。如果模糊推理系统有m个输入语言变量和n个输出语言变量,则向量rulelist的列数必须为m+n+2,而行数等于需

13、要添加的规则数目。在rulelist的每一行中,前m个数字表示各输入语言变量的语言值(隶属度函数的编号),随后的n个数字表示输出语言变量的语言值,第n+m+1个数字是该规则的权重,权重的值在0到1之间,一般设定为1;第n+m+2个数字为0或1两者之一,为1表示模糊规则各输入语言变量之间是and关系,为0则表示是or关系。函数showrule格式:showrule(fis)showrule(fisindexlist)showrule(fisindexlistat)说明:fis为模糊推理系统矩阵变量的名称;indexlist为规则编号,可以以向量形式指定显示多条规则;at为显示方式,有三种显示方式

14、,即语句方式(verbose),符号方式(symbolic)和索引方式(indd)。例:showrule(a1:2indd)输出结果:11,1(1):112,2(1):16、计算模糊推理输出结果函数fis格式:y=fis(UFIS)说明:参数U是输入数据,FIS是模糊推理矩阵。U的每一行是一个特定的输入向量,Y的每一行是一个特定的输出向量。如果输入U是MN矩阵,则系统是N输入的,返回的Y是ML矩阵,L是系统的输出的数目。例:fis=readfis(tipper)out=fis(2149fis)输出结果:out=7.016919.68102.3.2、MATLAB模糊控制设计实例1(用图形交互工具

15、箱)一、设计目的:了解用MATLAB模糊工具箱的图形界面可视化工具实现模糊控制系统的方法。二、系统设计要求:1、输入变量:偏差e、偏差变化率de;输出变量:u相应隶属度函数为:2、规则要求:3、反模糊化方法:平均最大隶属度函数法mom。三、设计步骤:1、进入MATLAB系统,在MATLAB命令窗口执行fuzzy命令即可激活基本模糊推理系统编辑器,首先增加一个输入变量。2、在图形界面中通过鼠标双击就能激活隶属度函数编辑器和模糊规则编辑器等相应的编辑窗口,在窗口中进行相应属性设置即可;再在模糊推理系统编辑器中设置反模糊化方法。3、进入Ruleview观察器,观察模糊推理系统的输出情况。四、设计结果

16、要求1、记录模糊规则编辑器Ruleedit中索引indd方式显示的规则。2、记录Ruleview观察器中模糊推理系统的输出情况:当e=2,de=1时u为多少?当e=1,de=2时u为多少?激活模糊推理系统编辑器:增加一个输入变量:双击进入Mfedit:修改每个变量的论域和隶属度函数:trimf三角形(triangularmembershipfunction)trapmf(trapezium梯形)Gaussmf(高斯型)zmf(Z型)smf(S型)NB选哪种Type增加隶属度函数个数:PB选哪种Typetrapmf(trapezium梯形)Gaussmf(高斯型)zmf(Z型)smf(S型)添加规则:语句表示的规则:规则显示方式:Verbose:语句

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 高等教育 > 大学课件

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号