模糊语意变数、规则和模糊运算--AForge.NET框架的使用(二)

简介: 原文:模糊语意变数、规则和模糊运算--AForge.NET框架的使用(二) 语意变数(Linguistic Variable) 语意变数存储了数个语意量(标签),每个语意量包含一个识别名和模糊集合。

原文:模糊语意变数、规则和模糊运算--AForge.NET框架的使用(二)

语意变数(Linguistic Variable)

语意变数存储了数个语意量(标签),每个语意量包含一个识别名和模糊集合。在宣告陈述时每个语意量只能和在同一变数中的语意比较。

举个很简单的例子,我们有一个名为temperature的语意变数,它包含4个语意量,名为cold、cool、warm、hot,这也是各自的标签名,同时它们还有各自的隶属度函数。

那么我们就在接下来的系统中使用诸如temperature is hot或者temperature is not hot等等了。

 

//语意变数的声明
LinguisticVariable lvTemperature = new LinguisticVariable("Temperature", 0, 50);

//模糊集合和隶属度函数
TrapezoidalFunction function1 = new TrapezoidalFunction(10, 15, TrapezoidalFunction.EdgeType.Right);
FuzzySet fsCold = new FuzzySet("Cold", function1);
TrapezoidalFunction function2 = new TrapezoidalFunction(10, 15, 20, 25);
FuzzySet fsCool = new FuzzySet("Cool", function2);
TrapezoidalFunction function3 = new TrapezoidalFunction(20, 25, 30, 35);
FuzzySet fsWarm = new FuzzySet("Warm", function3);
TrapezoidalFunction function4 = new TrapezoidalFunction(30, 35, TrapezoidalFunction.EdgeType.Left);
FuzzySet fsHot = new FuzzySet("Hot", function4);

//添加标签
lvTemperature.AddLabel(fsCold);
lvTemperature.AddLabel(fsCool);
lvTemperature.AddLabel(fsWarm);
lvTemperature.AddLabel(fsHot);

//获取隶属度
Console.WriteLine("Input; Cold; Cool; Warm; Hot");
for (float x = 0; x < 50; x += 1f)
{
float y1 = lvTemperature.GetLabelMembership("Cold", x);
float y2 = lvTemperature.GetLabelMembership("Cool", x);
float y3 = lvTemperature.GetLabelMembership("Warm", x);
float y4 = lvTemperature.GetLabelMembership("Hot", x);

Console.WriteLine(String.Format("{0:N}; {1:N}; {2:N}; {3:N}; {4:N}",x, y1, y2, y3, y4));
}

 

fuzzy2-1

 

模糊规则(Fuzzy Rule)与数据库(Fuzzy Database)

在拥有语意变数后,我们就创建表述(Statement),它是一种表达,可以做成判断,比如什么是什么,什么不是什么。

而规则(Rule)是可以被模糊系统执行的语意指令。如什么是什么时,就怎么。最简单的就是这种:

IF antecedent THEN consequent

前提(antecedent )一般由多个由模糊运算符连接的子句组成。如:

...Clause1 AND (Clause2 OR Clause3) AND NOT Clause4 ...

结果(consequent)一般由赋值子句组成,这里的赋值不光是Variable1 IS Value1,Variable1 IS Not Value1同样支持。

举个例子,再创建一个语意变数,Wind,标签有Strong、BreezeAirless。

那么一下规则就是有效的:

IF Wind IS Strong THEN Temperature IS Cold

IF Wind IS AirlessTHEN Temperature IS NOT Cold

数据库(Fuzzy Database)是一个包含语意变数和相应规则的资料集合,它可以被模糊推理系统(Fuzzy Inference System)使用。

 

//语意变数的声明 
LinguisticVariable lvTemperature = new LinguisticVariable("Temperature", 0, 50);

//模糊集合和隶属度函数
TrapezoidalFunction function1 = new TrapezoidalFunction(10, 15, TrapezoidalFunction.EdgeType.Right);
FuzzySet fsCold = new FuzzySet("Cold", function1);
TrapezoidalFunction function2 = new TrapezoidalFunction(10, 15, 20, 25);
FuzzySet fsCool = new FuzzySet("Cool", function2);
TrapezoidalFunction function3 = new TrapezoidalFunction(20, 25, 30, 35);
FuzzySet fsWarm = new FuzzySet("Warm", function3);
TrapezoidalFunction function4 = new TrapezoidalFunction(30, 35, TrapezoidalFunction.EdgeType.Left);
FuzzySet fsHot = new FuzzySet("Hot", function4);

//添加标签
lvTemperature.AddLabel(fsCold);
lvTemperature.AddLabel(fsCool);
lvTemperature.AddLabel(fsWarm);
lvTemperature.AddLabel(fsHot);

//语意变数的声明
LinguisticVariable lvWind = new LinguisticVariable("Wind", 0, 50);

//模糊集合和隶属度函数
TrapezoidalFunction functionw1 = new TrapezoidalFunction(25, 40, TrapezoidalFunction.EdgeType.Right);
FuzzySet fsStrong = new FuzzySet("Strong", function1);
TrapezoidalFunction functionw2 = new TrapezoidalFunction(10, 15, 25, 30);
FuzzySet fsBreeze = new FuzzySet("Breeze", function2);
TrapezoidalFunction functionw3 = new TrapezoidalFunction(5,10,TrapezoidalFunction.EdgeType.Left);
FuzzySet fsAirless = new FuzzySet("Airless", function3);

//添加标签
lvWind.AddLabel(fsStrong);
lvWind.AddLabel(fsBreeze);
lvWind.AddLabel(fsAirless);

//创建数据库
Database db = new Database();
db.AddVariable(lvTemperature);
db.AddVariable(lvWind);

//书写规则
Rule r1 = new Rule(db, "Thinking1", "IF Wind IS Strong THEN Temperature IS Cold");
Rule r2 = new Rule(db, "Thinking2", "IF Wind IS AirlessTHEN Temperature IS NOT Cold");

模糊运算

以下全是数学相关物…不喜者勿入。

模糊运算主要针对模糊集合,有3种:联集(union)、补集(complement)与交集(intersection),而依照不同定义有不同的型态。

1.交集中:

标准交集(standard intersection):t (p,q) = min (p,q)

代数乘积(algebraic product):t (p,q) = pq

有界差异(bounded different):t (p,q) = max (0, p+q-1)

彻底交集(drastic intersection):

fuzzy2-2

2.联集中:

标准联集(standard intersection):s (p,q) = max (p,q)

代数加法(algebraic product): s (p,q) = p + q -pq

有界加法(bounded different): s (p,q) = min (1, p+q)

彻底联集(drastic intersection):

fuzzy2-3

 

本来还想写模糊合成的…但是没找到可以画矩阵的软件,matlab画出来太丑了。

 

写在最后:

1.本文参考了很多文档和资料,特别是相关英文的对应翻译上,主要参考http://www.academia.edu相关讨论和台湾一些院校的研究报告。

2.有个不错的PPT,可以看一下:http://www.ctdisk.com/file/4479740

目录
相关文章
|
11天前
|
数据可视化 网络协议 C#
C#/.NET/.NET Core优秀项目和框架2024年3月简报
公众号每月定期推广和分享的C#/.NET/.NET Core优秀项目和框架(每周至少会推荐两个优秀的项目和框架当然节假日除外),公众号推文中有项目和框架的介绍、功能特点、使用方式以及部分功能截图等(打不开或者打开GitHub很慢的同学可以优先查看公众号推文,文末一定会附带项目和框架源码地址)。注意:排名不分先后,都是十分优秀的开源项目和框架,每周定期更新分享(欢迎关注公众号:追逐时光者,第一时间获取每周精选分享资讯🔔)。
|
2月前
|
开发框架 JavaScript 前端开发
5个.NET开源且强大的快速开发框架(帮助你提高生产效率)
5个.NET开源且强大的快速开发框架(帮助你提高生产效率)
|
29天前
|
开发框架 网络协议 .NET
深入.net框架
深入.net框架
11 0
|
2月前
|
算法 BI API
C#/.NET/.NET Core优秀项目和框架2024年1月简报
C#/.NET/.NET Core优秀项目和框架2024年1月简报
|
3月前
|
PHP Windows
php扩展com_dndnet(PHP与.NET框架进行交互)
php扩展com_dndnet(PHP与.NET框架进行交互)
php扩展com_dndnet(PHP与.NET框架进行交互)
|
3月前
|
开发框架 前端开发 JavaScript
一款基于.NET Core的快速开发框架、支持多种前端UI、内置代码生成器
一款基于.NET Core的快速开发框架、支持多种前端UI、内置代码生成器
|
3月前
|
SQL JavaScript NoSQL
3个.NET开源简单易用的任务调度框架
3个.NET开源简单易用的任务调度框架
103 0
|
3月前
|
数据采集 开发框架 JavaScript
C#/.NET/.NET Core优秀项目和框架2023年12月简报
C#/.NET/.NET Core优秀项目和框架2023年12月简报
|
4月前
|
C# Android开发 iOS开发
9 个 .NET UI 框架,您的选择是?
介绍 9 款 .NET UI 框架,有你的菜麽。
197 1
9 个 .NET UI 框架,您的选择是?
|
4月前
|
SQL 数据库 开发工具
“.NET视频总结:认识框架的结构和组件,掌握开发工具的奥妙“
“.NET视频总结:认识框架的结构和组件,掌握开发工具的奥妙“
55 0