原文:模糊系统架构和简单实现--AForge.NET框架的使用(四)

先说一下,为什么题目是简单实现,因为我实在没有弄出好的例子。

我原来用AForge.net做的项目中的模糊系统融入了神经网络和向量机,没法抽出来当例子,就用了个最老的自动车辆的例子。

模糊系统(Fuzzy System)架构

前面零零散散说来一下有关模糊系统和模糊理论的东西,这里来个总结。

模煳系统的基本架构如图8.1所示,其中主要的功能方块包括:(1)模煳化机构、(2)模煳规则库、(3)模煳推论引擎、以及(4)去模煳化机构。

模糊化机构是有关模糊集合和隶属度函数的内容。

模糊规则前文也有提及,去模糊化只涉及了重心法一种,这里简单说一下模糊推理引擎。

模糊推理引擎是模煳系统的核心,它可以藉由近似推论或模煳推论的进行,来模拟人类的思考决策模式,以达到解决问题的目地。

比如:

前提(premise)一:x is A’

前提(premise)二:if x is A,y is B

结论:y is B’

模糊推理系统的简单实现

在AForge.Net中的对应类是InferenceSystem。

在程序实现中一个模糊推理系统(Fuzzy Inference System )由数据库(Database)和规则库(Rulebase)组成,一般操作如下:

1.获取数值输入

2.通过数据库(Database)将数值输入转为语意含义

3.验证规则库(Rulebase)中的哪些规则被输入激活

4.组合被激活的规则,得到模糊输出(Fuzzy Output)

5.去模糊化(实现IDefuzzifier接口)

下面看看例子,这个例子是关于控制车辆避免正面冲撞的系统。

输入为距离,论域[0,120],隶属度函数

输出为角度,论域[-10,50],隶属度函数

核心代码:

// 隶属度函数(距离) 
FuzzySet fsNear = new FuzzySet("Near",
new TrapezoidalFunction(, , TrapezoidalFunction.EdgeType.Right));
FuzzySet fsMedium = new FuzzySet("Medium",
new TrapezoidalFunction(, , , ));
FuzzySet fsFar = new FuzzySet("Far",
new TrapezoidalFunction(, , TrapezoidalFunction.EdgeType.Left)); //绘制图像
int length1 =(int) (chart1.RangeX.Max - chart1.RangeX.Min);
double[,] NearValues = new double[length1, ];
for (int i = (int)chart1.RangeX.Min; i < chart1.RangeX.Max; i++)
{
NearValues[i, ] = i;
NearValues[i, ] = fsNear.GetMembership(i);
}
double[,] MediumValues = new double[length1, ];
for (int i = (int)chart1.RangeX.Min; i < chart1.RangeX.Max; i++)
{
MediumValues[i, ] = i;
MediumValues[i, ] = fsMedium.GetMembership(i);
}
double[,] FarValues = new double[length1, ];
for (int i = (int)chart1.RangeX.Min; i < chart1.RangeX.Max; i++)
{
FarValues[i, ] = i;
FarValues[i, ] = fsFar.GetMembership(i);
}
chart1.UpdateDataSeries("Near", NearValues);
chart1.UpdateDataSeries("Medium", MediumValues);
chart1.UpdateDataSeries("Far", FarValues); // 距离(输入)
LinguisticVariable lvFront = new LinguisticVariable("FrontalDistance", , );
lvFront.AddLabel(fsNear);
lvFront.AddLabel(fsMedium);
lvFront.AddLabel(fsFar); // 隶属度函数
FuzzySet fsZero = new FuzzySet("Zero",
new TrapezoidalFunction(-, , , ));
FuzzySet fsLP = new FuzzySet("LittlePositive",
new TrapezoidalFunction(, , , ));
FuzzySet fsP = new FuzzySet("Positive",
new TrapezoidalFunction(, , , ));
FuzzySet fsVP = new FuzzySet("VeryPositive",
new TrapezoidalFunction(, , TrapezoidalFunction.EdgeType.Left)); //绘制图像
int length2 = (int)(chart2.RangeX.Max - chart2.RangeX.Min);
double[,] ZeroValues = new double[length2, ];
for (int i = (int)chart2.RangeX.Min; i < chart2.RangeX.Max; i++)
{
ZeroValues[i + , ] = i;
ZeroValues[i + , ] = fsZero.GetMembership(i);
}
double[,] LittlePositiveValues = new double[length2, ];
for (int i = (int)chart2.RangeX.Min; i < chart2.RangeX.Max; i++)
{
LittlePositiveValues[i + , ] = i;
LittlePositiveValues[i + , ] = fsLP.GetMembership(i);
}
double[,] PositiveValues = new double[length2, ];
for (int i = (int)chart2.RangeX.Min; i < chart2.RangeX.Max; i++)
{
PositiveValues[i + , ] = i;
PositiveValues[i + , ] = fsP.GetMembership(i);
}
double[,] VeryPositiveValues = new double[length2, ];
for (int i = (int)chart2.RangeX.Min; i < chart2.RangeX.Max; i++)
{
VeryPositiveValues[i + , ] = i;
VeryPositiveValues[i + , ] = fsVP.GetMembership(i);
}
chart2.UpdateDataSeries("Zero", ZeroValues);
chart2.UpdateDataSeries("LittlePositive", LittlePositiveValues);
chart2.UpdateDataSeries("Positive", PositiveValues);
chart2.UpdateDataSeries("VeryPositive", VeryPositiveValues); //角度
LinguisticVariable lvAngle = new LinguisticVariable("Angle", -, );
lvAngle.AddLabel(fsZero);
lvAngle.AddLabel(fsLP);
lvAngle.AddLabel(fsP);
lvAngle.AddLabel(fsVP); //设置数据库
Database fuzzyDB = new Database();
fuzzyDB.AddVariable(lvFront);
fuzzyDB.AddVariable(lvAngle); // 创建模糊推理系统
InferenceSystem IS = new InferenceSystem(fuzzyDB, new CentroidDefuzzifier()); // 直行规则
IS.NewRule("Rule 1", "IF FrontalDistance IS Far THEN Angle IS Zero");
// 左转规则
IS.NewRule("Rule 2", "IF FrontalDistance IS Near THEN Angle IS Positive"); //开始推理 // 设定输入
IS.SetInput("FrontalDistance",float.Parse(inputBox.Text)); //打印输出
try
{
float newAngle = IS.Evaluate("Angle");
outputBox.Text = newAngle.ToString();
}
catch (Exception ex)
{
MessageBox.Show("error ===> "+ex.Message);
}

效果:

如果要输出模糊结论可以使用:

FuzzyOutput fuzzyOutput = IS.ExecuteInference("Angle");

foreach (FuzzyOutput.OutputConstraint oc in fuzzyOutput.OutputList) 
{
Console.WriteLine(oc.Label + " - " + oc.FiringStrength.ToString());
}

模糊推理系统的扩展和完善

借助AForge.Net我们可以很快构建一个系统,但是AForge.Net也不是十全十美的。

首先它的合成运算子没有实现完全,有些常用的,比如最大边界算子就没有。

其次其去模糊化的实现只有一种,可以考虑实现自己补充一下算法:

1.最大平均法 (modified mean of maxima defuzzifier)

2.修正型最大平均法 (modified mean of maxima defuzzifier)

3.中心平均法 (modified center average defuzzifier)

4.修正型重心法 (modified center average defuzzifier)

5.权重式平均法(weighted average method)结合了启动强度,使用更为广泛


不过AForge.Net的接口和设计比较好,扩展也是很方便的。

其实模糊系统的话,matlab也是可以做到的,但是一来matlab不开源,二来扩展确实不方便,所以没有使用,如果确实没有替代品,可以考虑混编。

模糊系统的使用本身也有一些不方便,主要是规则库的建立。

第一种也是最直接的方式就是经由询问人类专家而得。但是人类专家往往无法完整地提供所有必需的语意式模煳规则,以致于规则库的不完全。

而模糊系统的效果主要受规则和隶属度函数影响,所以有时候规则库的不全对系统的效果是毁灭性伤害。

第二种取得语意式模煳规则的方式,则是经由训练法则,从数值型资料(numerical data)中取得模煳规则,此种作法往往牵涉如何分割输入及输出变数空间。常用的就是神经网络。

AForge.Net也有神经网络相关的东西,所以使用起来很方便的。

最后附上整个项目的下载地址:http://www.ctdisk.com/file/4512079

模糊系统架构和简单实现--AForge.NET框架的使用(四)的更多相关文章

  1. 源码学习之Spring (系统架构简单解析)

    Spring Framework 系统架构总览图 Spring Framework的模块依赖关系图 Spring Framework各个模块功能说明 Spring核心模块 模块名称 主要功能 Spri ...

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

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

  3. vivo商城促销系统架构设计与实践-概览篇

    一.前言 随着商城业务渠道不断扩展,促销玩法不断增多,原商城v2.0架构已经无法满足不断增加的活动玩法,需要进行促销系统的独立建设,与商城解耦,提供纯粹的商城营销活动玩法支撑能力. 我们将分系列来介绍 ...

  4. (系统架构)标准Web系统的架构分层

    标准Web系统的架构分层 1.架构体系分层图 在上图中我们描述了Web系统架构中的组成部分.并且给出了每一层常用的技术组件/服务实现.需要注意以下几点: 系统架构是灵活的,根据需求的不同,不一定每一层 ...

  5. 千万pv大型web系统架构,学习从点滴开始

     架构,刚开始的解释是我从知乎上看到的.什么是架构?有人讲, 说架构并不是一 个很 悬 乎的 东西 , 实际 上就是一个架子 , 放一些 业务 和算法,跟我们的生活中的晾衣架很像.更抽象一点,说架构其 ...

  6. [网站性能1]对.net系统架构改造的一点经验和教训

    文章来源:http://www.admin10000.com/document/2111.html 在互联网行业,基于Unix/Linux的网站系统架构毫无疑问是当今主流的架构解决方案,这不仅仅是因为 ...

  7. 异构(兼容dubbo)SOA系统架构(.net)优化升级

    前面一片文章已经提到我司的异构(兼容dubbo)SOA系统架构,解决了不少技术痛点,也还算比较完善,也顺利推广开来. 但作为项目的开发者,自己产品的问题心里是清楚的,离自己满意还是有不小的距离. 在推 ...

  8. 浅谈大型web系统架构

    动态应用,是相对于网站静态内容而言,是指以c/c++.php.Java.perl..net等服务器端语言开发的网络应用软件,比如论坛.网络相册.交友.BLOG等常见应用.动态应用系统通常与数据库系统. ...

  9. 性能测试知多少---系统架构分析 转自https://yq.aliyun.com/articles/35147?spm=5176.100239.blogcont24251.8.lS96At

    摘要: 有些事儿一旦放一放就难再拾起来,突然发现<性能测试知多少>这个系列两月没更新,关键时我都不知道啥时候放下的,总容易被各种技术所吸引走,如饥似渴的想学更多的东西,这几天一直有朋友问我 ...

随机推荐

  1. @Resource 和 @Autowired注解的异同

    @Resource 和 @Autowired注解的异同 @Autowired 默认按类型装配,默认情况下必须要求依赖对象必须存在,如果要允许null值,可以设置它的required属性为false 例 ...

  2. HDU1863 畅通project 【最小生成树Prim】

    畅通project Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total ...

  3. QT 仓库管理系统 开放源代码

    IT 要走多久,要怎么走. IT 要走多久,要怎么走.这些问题,在我已经快毕业了一个年头的如今,又又一次浮如今我的脑海里.一边是工作的了了模块,一边是能够自己无聊打发的时间.这不是我当初要的路,如今的 ...

  4. [Javascript] Add a browser build to an npm module

    In this lesson, we're going to use webpack to create a UMD (Universal Module Definition) build of ou ...

  5. EEPlat 的 后台业务处理模型

    后台处理包括数据处理.业务逻辑及业务流程等服务端操作的部分.相关的元模型包括业务对象元模型.业务对象属性元模型.服务元模型.參数元模型.业务规则元模型.工作流元模型.例如以下图所看到的:   业务对象 ...

  6. cocos2d-x 3.6版连连看载入资源

    网上找了一个梦幻连连看的资源.大家能够百度一下.然后整理一下加到project里面去.包含声音和图片文件.后面解释怎样整理能够方便管理. 我不推荐在代码里面直接引用资源文件名称,我称之为硬编码. 做i ...

  7. 综合使用LruCache和DiskLruCache 缓存图片

    Activity public class MainActivity extends Activity {     private GridView mPhotoWall;     private P ...

  8. ASP.NET-FineUI开发实践-5

    1.tree的右键事件和单击事件 页面就不写了,准备一个树和一个菜单控件,随便写点啥 JS:注意注释 var menuSettings = F('menuSettings'); var tree = ...

  9. 国内使用google地图的初级使用

    <!DOCTYPE html><html><head><title>Simple Map</title><meta name=&quo ...

  10. zendstudio正则匹配查询

    Ctrl+H之后,显示的File Search标签页为Containing text. Alt+/ 帮助提示正则匹配的语法. 例子如下: select type from table where id ...