第6章 模糊逻辑

6.1 隶属函数

6.1.1 高斯隶属函数

函数 gaussmf

格式 y=gaussmf(x,[sig c])

说明 高斯隶属函数的数学表达式为:,其中为参数,x为自变量,sig为数学表达式中的参数。

例6-1

>>x=0:0.1:10;

>>y=gaussmf(x,[2 5]);

>>plot(x,y)

>>xlabel('gaussmf, P=[2 5]')

结果为图6-1。

图6-1

6.1.2 两边型高斯隶属函数

函数 gauss2mf

格式 y = gauss2mf(x,[sig1 c1 sig2 c2])

说明 sig1、c1、sig2、c2为命令1中数学表达式中的两对参数

例6-2

>>x = (0:0.1:10)';

>>y1 = gauss2mf(x, [2 4 1 8]);

>>y2 = gauss2mf(x, [2 5 1 7]);

>>y3 = gauss2mf(x, [2 6 1 6]);

>>y4 = gauss2mf(x, [2 7 1 5]);

>>y5 = gauss2mf(x, [2 8 1 4]);

>>plot(x, [y1 y2 y3 y4 y5]);

>>set(gcf, 'name', 'gauss2mf', 'numbertitle', 'off');

结果为图6-2

6.1.3 建立一般钟型隶属函数

函数 gbellmf

格式 y = gbellmf(x,params)

说明 一般钟型隶属函数依靠函数表达式

这里x指定变量定义域范围,参数b通常为正,参数c位于曲线中心,第二个参数变量params是一个各项分别为a,b和c的向量。

例6-3

>>x=0:0.1:10;

>>y=gbellmf(x,[2 4 6]);

>>plot(x,y)

>>xlabel('gbellmf, P=[2 4 6]')

结果为图6-3。

图6-2图6-3

6.1.4 两个sigmoid型隶属函数之差组成的隶属函数

函数 dsigmf

格式 y = dsigmf(x,[a1 c1 a2 c2])

说明 这里sigmoid型隶属函数由下式给出

x是变量,a,c是参数。dsigmf使用四个参数a1,c1,a2,c2,并且是两个sigmoid型函数之差:,参数按顺序列出。

例6-4

>>x=0:0.1:10;

>>y=dsigmf(x,[5 2 5 7]);

>>plot(x,y)

结果为图6-4

图6-4

6.1.5 通用隶属函数计算

函数 evalmf

格式 y = evalmf(x, mfParams, mfType)

说明 evalmf可以计算任意隶属函数,这里x是变量定义域,mfType是工具箱提供的一种隶属函数,mfParams是此隶属函数的相应参数,如果你想创建自定义的隶属函数,evalmf仍可以工作,因为它可以计算它不知道名字的任意隶属函数。

例6-5

>>x=0:0.1:10;

>>mfparams = [2 4 6];

>>mftype = 'gbellmf';

>>y=evalmf(x,mfparams,mftype);

>>plot(x,y)

>>xlabel('gbellmf, P=[2 4 6]')

结果为图6-5。

图6-5

6.1.6 建立П型隶属函数

函数 primf

格式 y = pimf(x,[a b c d])

说明 向量x指定函数自变量的定义域,该函数在向量x的指定点处进行计算,参数[a,b,c,d]决定了函数的形状,a和d分别对应曲线下部的左右两个拐点,b和c分别对应曲线上部的左右两个拐点。

例6-6

>>x=0:0.1:10;

>>y=pimf(x,[1 4 5 10]);

>>plot(x,y)

>>xlabel('pimf, P=[1 4 5 10]')

结果为图6-6。

6.1.7 通过两个sigmoid型隶属函数的乘积构造隶属函数

函数 psigmf

格式 y = psigmf(x,[a1 c1 a2 c2])

说明 这里sigmoid型隶属函数由下式给出

x是变量,a,c是参数。psigmf使用四个参数a1,c1,a2,c2,并且是两个sigmoid型函数之积:,参数按顺序列出。

例6-7

>>x=0:0.1:10;

>>y=psigmf(x,[2 3 -5 8]);

>>plot(x,y)

>>xlabel('psigmf, P=[2 3 -5 8]')

结果为图6-7。

图6-6图6-7

6.1.8 建立Sigmoid型隶属函数

函数 sigmf

格式 y = sigmf(x,[a c])

说明 ,定义域由向量x给出,形状由参数a和c确定。

例6-8

>>x=0:0.1:10;

>>y=sigmf(x,[2 4]);

>>plot(x,y)

>>xlabel('sigmf, P=[2 4]')

结果为图6-8。

图6-8

例6-9

>>x = (0:0.2:10)’;

>>y1 = sigmf(x,[-1 5]);

>>y2 = sigmf(x,[-3 5]);

>>y3 = sigmf(x,[4 5]);

>>y4 = sigmf(x,[8 5]);

>>subplot(2,1,1),plot(x,[y1 y2 y3 y4]);

>>y1 = sigmf(x,[5 2]);

>>y2 = sigmf(x,[5 4]);

>>y3 = sigmf(x,[5 6]);

>>y4 = sigmf(x,[5 8]);

>>subplot(2,1,2),plot(x,[y1 y2 y3 y4]);

结果为图6-9。

图6-9

6.1.9 建立S型隶属函数

函数 smf

格式 y = smf(x,[a b]) % x为变量,a为b参数,用于定位曲线的斜坡部分。

例6-10

>>x=0:0.1:10;

>>y=smf(x,[1 8]);

>>plot(x,y)

结果为图6-10。

图6-10

例6-11

>>x = 0:0.1:10;

>>subplot(3,1,1);plot(x,smf(x,[2 8]));

>>subplot(3,1,2);plot(x,smf(x,[4 6]));

>>subplot(3,1,3);plot(x,smf(x,[6 4]));

结果为图6-11。

图6-11

6.1.10 建立梯形隶属函数

函数 trapmf

格式 y = trapmf(x,[a b c d])

说明 这里梯形隶属函数表达式:

或 f(x;a,b,c,d) = max(min(,定义域由向量x确定,曲线形状由参数a,b,c,d确定,参数a和d对应梯形下部的左右两个拐点,参数b和c对应梯形上部的左右两个拐点。

例6-12

>>x=0:0.1:10;

>>y=trapmf(x,[1 5 7 8]);

>>plot(x,y)

>>xlabel('trapmf, P=[1 5 7 8]')

结果为图6-12。

例6-13

>>x = (0:0.1:10)’;

>>y1 = trapmf(x,[2 3 7 9]);

>>y2 = trapmf(x,[3 4 6 8]);

>>y3 = trapmf(x,[4 5 5 7]);

>>y4 = trapmf(x,[5 6 4 6]);

>>plot(x,[y1 y2 y3 y4]);

结果为图6-13。

图6-12图6-13

6.1.11 建立三角形隶属函数

函数 trimf

格式 y = trimf(x,params)

y = trimf(x,[a b c])

说明 三角形隶属函数表达式:

或者f(x;a,b,c,) = max(min(

定义域由向量x确定,曲线形状由参数a,b,c确定,参数a和c对应三角形下部的左右两个顶点,参数b对应三角形上部的顶点,这里要求a,生成的隶属函数总有一个统一的高度,若想有一个高度小于统一高度的三角形隶属函数,则使用trapmf函数。

例6-14

>>x=0:0.1:10;

>>y=trimf(x,[3 6 8]);

>>plot(x,y)

>>xlabel('trimf, P=[3 6 8]')

结果为图6-14。

图6-14

例6-15

>>x = (0:0.2:10)’;

>>y1 = trimf(x,[3 4 5]);

>>y2 = trimf(x,[2 4 7 ]);

>>y3 = trimf(x,[1 4 9]);

>>subplot(2,1,1),plot(x,[y1 y2 y3 ]);

>>y1 = trimf(x,[2 3 5]);

>>y2 = trimf(x,[3 4 7]);

>>y3 = trimf(x,[4 5 9]);

>>subplot(2,1,2),plot(x,[y1 y2 y3 ]);

结果为图6-15。

图6-15

6.1.12 建立Z型隶属函数

函数 zmf

格式 y = zmf(x,[a b]) % x为自变量,a和b为参数,确定曲线的形状。

例6-16

>>x=0:0.1:10;

>>y=zmf(x,[3 7]);

>>plot(x,y)

>>xlabel('zmf, P=[3 7]')

结果为图6-16。

例6-17

>>x = 0:0.1:10;

>>subplot(3,1,1);plot(x,zmf(x,[2 8]));

>>subplot(3,1,2);plot(x,zmf(x,[4 6]));

>>subplot(3,1,3);plot(x,zmf(x,[6 4]));

结果为图6-17。

图6-16图6-17

6.1.13 两个隶属函数之间转换参数

函数 mf2mf

格式 outParams = mf2mf(inParams,inType,outType)

说明 此函数根据参数集,将任意内建的隶属函数类型转换为另一种类型,inParams为你要转换的隶属函数的参数,inType为你要转换的隶属函数的类型的字符串名称,outType:你要转换成的目标隶属函数的字符串名称。

例6-18

>>x=0:0.1:5;

>>mfp1 = [1 2 3];

>>mfp2 = mf2mf(mfp1,'gbellmf','trimf');

>>plot(x,gbellmf(x,mfp1),x,trimf(x,mfp2))

结果为图6-18。

6.1.14 基本FIS编辑器

函数 fuzzy

格式 fuzzy %弹出未定义的基本FIS编辑器

fuzzy(fismat) %使用fuzzy('tipper'),弹出下图FIS编辑器。

编辑器是任意模糊推理系统的高层显示,它允许你调用各种其它的编辑器来对其操作。此界面允许你方便地访问所有其它的编辑器,并以最灵活的方式与模糊系统进行交互。

方框图:窗口上方的方框图显示了输入、输出和它们中间的模糊规则处理器。单击任意一个变量框,使选中的方框成为当前变量,此时它变成红色高亮方框。双击任意一个变量,弹出隶属度函数编辑器,双击模糊规则编辑器,弹出规则编辑器。

图6-19

菜单项:FIS编辑器的菜单棒允许你打开相应的工具,打开并保存系统。

·File菜单包括:

New mamdani FIS … 打开新mamdani型系统;

New Sugeno FIS … 打开新Sugeno型系统;

Open from disk … 从磁盘上打开指定的.fis文件系统;

Save to disk 保存当前系统到磁盘上的一个.fis文件上;

Save to disk as … 重命名方式保存当前系统到磁盘上;

Open from workspace … 从工作空间中指定的FIS结构变量装入一个系统;

Save to workspace … 保存系统到工作空间中当前命名的FIS结构变量中;

Save to workspace as … 保存系统到工作空间中指定的FIS结构变量中;

Close windows 关闭GUI;

·Edit菜单包括:

Add input 增加另一个输入到当前系统中;

Add output 增加另一个输出到当前系统中;

Remove variable 删除一个所选的变量;

Undo 恢复当前最近的改变;

·View 菜单包括:

Edit MFs … 调用隶属度函数编辑器;

Edit rules … 调用规则编辑器;

Edit anfis … 只对单输出Sugeno型系统调用编辑器;

View rules … 调用规则观察器;

View surface … 调用曲面观察器。

弹出式菜单:用五个弹出式菜单来改变模糊蕴含过程中五个基本步骤的功能:

·And method:为一个定制操作选择min、prod或Custom;

·Or method:为一个定制操作选择max、probor(概率)或Custom;

·Implication method:为一个定制操作选择min、prod或Custom;此项对Sugeno型模糊系统不可用。

·Aggregation method:为一个定制操作选择max、sum、probor或Custom。此项对Sugeno型模糊系统不可用。

·Defuzzification method:对Mamdani型推理,为一个定制操作选择centroid(面积中心法)、bisector(面积平分法)、mom(平均最大隶属度法)、som(最大隶属度最小值法)、lom(最大隶属度最大值法)或Custom。对Sugeno型推理,在wtaver(加权平均)或wtsum(加权和)之间选择。

6.1.15 隶属函数编辑器

函数 mfedit

格式 mfedit('a')

mfedit(a)

mfedit

说明 mfedit('a')生成一个隶属函数编辑器,他允许你检查和修改存储在文件a.fis中FIS结构的所有隶属函数。如图,mfedit('tank')以这种方式打开隶属函数编辑器并装入tank.fis中存储的所有隶属函数。

mfedit(a)对于FIS结构操作一个MATLAB工作空间变量a。Mfedit可单独弹出没有装入FIS的隶属函数编辑器

图6-20

菜单项:在ANFIS编辑器GUI上,有一个菜单棒允许你打开相关的GUI工具、打开和保存系统等。File菜单与FIS编辑器上的File菜单功能相同。

·Edit菜单项包括:

Add MF… 为当前语言变量增加隶属度函数;

Add custom MF… 为当前语言变量增加定制的隶属度函数;

Remove current MF 删除当前的隶属度函数;

Remove all MFS 删除当前语言变量的所有隶属度函数;

Undo 恢复当前最近的改变。

·View菜单项包括:

Edit FIS properties… 调用FIS编辑器;

Edit rules… 调用规则编辑器;

View rules… 调用规则观察器;

View surface… 调用曲面观察器。

matlab打开界面模糊,matlab模糊逻辑(一)相关推荐

  1. matlab打开界面模糊,模糊PID(fuzzy PID)仿真举例

    模糊控制提出至今已有半个世纪,但在控制领域至今仍未工程上广泛应用.但学习了解还是很有必要的,matlab/simulink有专门的模糊控制的库,足以说明其重要性,本文通过简单的simulink模糊PI ...

  2. matlab打开界面模糊,如何在人机界面GUI的M文件中嵌入模糊FIS模块

    本帖最后由 martintsai 于 2011-4-12 11:05 编辑 我在进行汽车悬架系统的Simulink仿真毕业设计. 我之前已经完成mdl的设计,并建立模糊模块,mohu.fis,expo ...

  3. 解决低版本matlab打开高版本Matlab的.m文件时,出现中文乱码的问题。

    问题: 低版本matlab打开高版本Matlab的.m文件时,出现中文乱码. 比如下图: 原因: 编码格式不统一问题.Matlab高版本(2017a以上)默认保存编码格式是UTF-8格式,而低版本是G ...

  4. matlab 可视化界面,[转载]Matlab 的可视化界面设计(上)

    一个可发布的应用程序通常都需要具备一个友好的图形界面(比如,我们开课时或给学生上课而使用课件时,我们一般就会用到可视化界面).这样用户不需要知道应用程序究竟是怎样执行各种命令的, 而只需要了解可见界面 ...

  5. matlab 雷达系统界面,基于Matlab的雷达系统仿真软件包设计与实现

    0 引言    近些年来国际上相继发展了一些雷达仿真系统,而国内相控阵雷达系统和脉冲压缩雷达系统仿真软件的研究已经成为一个热点.对于一个复杂的雷达系统,系统建模与仿真技术是雷达系统设计和研究的一个重要 ...

  6. matlab初始化界面卡住,Matlab初始化initializing极慢解决方法

    Matlab初始化initializing极慢解决方法 Matlab升级以后,功能的确丰富了好多,有些函数也更加人性话了,好多bug也没有了.但是可恼的是,这个该死的家伙却一天比一天肥,MATLAB7 ...

  7. tdms用matlab打开,关于用Matlab 打开tdms文件的问题

    这是分析波形的程序,波形是存在tdms文件里的.这段程序下的另一段程序是打开tdms文件的程序.为什么我在我的电脑上怎么都不能运行起,在师姐的电脑上就可以?求各位大神帮助!:handshake cle ...

  8. matlab打开网页输入密码,MATLAB GUI 密码输入

    该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 function varargout = zhanghao(varargin) % ZHANGHAO MATLAB code for zhanghao.f ...

  9. 用matlab打开ppt模板,Matlab语言及其在电子信息工程中的应用ppt模板

    PPT内容 这是一个关于Matlab语言及其在电子信息工程中的应用ppt模板,主要介绍多项式.符号表达式和符号矩阵的创建.符号矩阵的基本运算.函数画图.求导.求零点.极值.欢迎点击下载哦. Matla ...

  10. 2023Matlab初级教程- 第一章 初识Matlab与界面介绍

    第一章 Matlab 初识Matlab与界面介绍 文章目录 第一章 Matlab 初识Matlab与界面介绍 Matlab初级教程 1.课程介绍 2.初识Matlab与界面介绍 2.1Matlab介绍 ...

最新文章

  1. Ubuntu16.04 ROS 深度学习_传智播客 智能机器人软件开发 学习路线图出炉!首发优惠!!...
  2. python pip下载安装教程_Python下的常用下载安装工具pip的安装方法
  3. 深度学习修炼(五)——基于pytorch神经网络模型进行气温预测
  4. 2021年中国数字化采购研究报告
  5. PowerBuilder 9日历控件展示,下载(附带源码)2
  6. 管家婆 凭证查找 Date exceeds maximum of 19-12-31 报错解决办法
  7. 【java实现地图经纬度逆编码】通过使用百度/高德地图的开放平台 实现经纬度与中文地址的转换(附代码方法)
  8. 计算机上的小键盘,电脑小键盘关闭方法有哪些 小键盘上的六个键都有什么用...
  9. 多点移动电子地图定位
  10. Jira实战 | 界面管理策略
  11. 3ds MAX 2014安装指南
  12. win10控制面板快捷键_你没玩过的全新版本Win10,这些操作你知多少?
  13. Compose Android 开发终极挑战赛: 天气应用
  14. 计算机之父阿兰·图灵传奇的一生
  15. ssh、git环境配置
  16. 沙巴克服务器占用,传奇怎么设置传奇服务端沙巴克自动攻城
  17. 盘点5款超棒的电脑软件
  18. 安卓来电归属地_头条:富士康或将成为电动车界的安卓
  19. Unity(11)-游戏退出实现
  20. UnityWebRequest 加载网络图片当作贴图给物体

热门文章

  1. python决策树分箱_分箱方法 - 静静的白桦林_andy - 博客园
  2. linux设备模型五(device和device_driver)
  3. Python从入门到PY交易,基础语法,散记(一)
  4. 循环卷积和线性卷积的关系
  5. ensp 移动主机搜索不到AP信道_有颜值更有才华,乘风破浪的天融信面板AP接受硬核实测...
  6. 记一次失败的机械键盘拆机换轴经历(含失败的经验总结)
  7. win10去快捷方式箭头
  8. 微服务: 立志做个伟大的项目
  9. google map 地图图标大全
  10. 【转】js高德地图图标合集