模糊推理(T-S系统)+C代码


一个模糊推理(T-S型系统)例子,如下:



代码的例子如下:


//制定推理规则:
//阀门的打开度数在[0, 90]
//定义:

// 关闭:0      开小:0~30  开中:30~60  开大:60~90
//R1:温度低,则关闭冷气阀门     if T is f1, then Y=0;    Y表示:温度高低对应需要打开的度数
//R2:温度较低,则开小冷气阀门   if T is f2, then Y=30/14*(T-10);
//R3:温度较高,则阀门开中       if T is f3, then Y=30/22*(T-14)+30;
//R4:温度高,则开大阀门         if T is f4, then Y=30/12*(T-24)+60;


代码实现如下:

(下面代码是按照个人理解和思路书写,正确与否尚且不知,从结果看还是有些合理的,欢迎大牛帮忙指正奋斗

#include "stdio.h"
#include "stdlib.h"
#include "math.h"


#define N 4


double A[N];
double Y[N];


double funA1(double x);  //A1温度低,的隶属度函数
double funA2(double x);  //A2温度较低,的隶属度函数
double funA3(double x);  //A3温度较高,的隶属度函数
double funA4(double x);  //A4温度高,的隶属度函数


void main()
{
double T, Z;
double sum=0;
int i;

//推理规则
//阀门的打开度数在[0, 90]
//定义开小:0~30  开中:30~60  开大:60~90
//R1:温度低,则关闭冷气阀门     if T is f1, then Y=0;    Y表示:温度高低对应需要打开的度数
//R2:温度较低,则开小冷气阀门   if T is f2, then Y=30/14*(T-10);
//R3:温度较高,则阀门开中       if T is f3, then Y=30/22*(T-14)+30;
//R4:温度高,则开大阀门         if T is f4, then Y=30/12*(T-24)+60;


for(T=0; T<50; T++)
{
A[0] = funA1(T);
A[1] = funA2(T);
A[2] = funA3(T);
A[3] = funA4(T);

//根据推理规则可计算
Y[0] = 0;
Y[1] = 30/14*(T-10);
Y[2] = 30/22*(T-14)+30;
Y[3] = 30/12*(T-24)+60;

//按加权求和法计算总输出
sum = 0;
for(i=0; i<N; i++)
{
sum += Y[i]*A[i];
}

printf("\n%0.2lf  %lf\n", T, sum);
}
}






//A1的隶属度函数
double funA1(double x)
{
if(x<=10)
return 1;


if(x>10 && x<14)
return (1-(x-10)/4);


if(x>=14)
return 0;
}




//A2的隶属度函数
double funA2(double x)
{
if(x<=10)
return 0;

if(x>10 && x<=14)
return (x-10)/4;

if(x>14 && x<=24)
return (1-(x-14)/10);


if(x>24)
return 0;
}


//A3的隶属度函数
double funA3(double x)
{
if(x<=14)
return 0;

if(x>14 && x<=24)
return (x-14)/10;

if(x>24 && x<=36)
return 1-(x-24)/12;


if(x>36)
return 0;
}


//A4的隶属度函数
double funA4(double x)
{
if(x<=24)
return 0;


if(x>24 && x<=36)
return (x-24)/12;


if(x>36)
return 1;
}

  • 2
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: T-S模糊建模是指根据Takagi-Sugeno模糊推理系统的原理,使用模糊逻辑方法建立的一种模糊模型。Matlab是一个强大的科学计算软件,可以用来实现T-S模糊建模。 T-S模糊建模的主要目的是对于给定的输入变量,建立一种模糊规则系统,通过模糊推理来进行预测或控制。这种模糊模型是由一系列模糊规则和输出函数组成的。 在Matlab中,我们可以使用fuzzy工具箱来实现T-S模糊建模。首先,需要定义输入变量和输出变量的模糊集合,在每个模糊集合中,可以设置若干个模糊集合函数,如三角形、梯形等。 然后,需要定义模糊规则,即输入变量与输出变量之间的关系。这些规则可以基于专家知识或者通过数据训练得到。在Matlab中,可以使用fuzzy工具箱提供的函数来定义和管理这些规则。 最后,需要定义输出函数,将模糊规则的结果映射到具体的输出值上。在Matlab中,可以通过设置模糊集合的隶属度函数来实现这一点。 通过以上步骤,我们就可以将T-S模糊建模应用到具体的问题中。根据输入数据,通过模糊推理系统,可以得到模糊的输出结果。如果需要,还可以通过去模糊化方法,将模糊的输出结果转化为具体的数值。 总之,T-S模糊建模是一种基于模糊逻辑的建模方法,通过Matlab中的fuzzy工具箱,我们可以方便地实现该方法,用于数据分析、预测和控制等领域。 ### 回答2: T-S模糊建模是一种常见的模糊控制方法,它在控制系统中应用广泛。T-S模糊建模基于“如果-那么”规则,通过将系统模型分解成一系列子模型,每个子模型通过模糊规则进行建模,从而实现对系统的有效控制。 在Matlab中,可以使用Fuzzy Logic Toolbox实现T-S模糊建模。首先,需要定义输入变量和输出变量的模糊集合及其隶属函数。输入隶属函数用于描述输入变量的模糊集合,例如“低”、“中”、“高”;输出隶属函数用于描述输出变量的模糊集合,例如“小”、“适中”、“大”。 然后,需要定义模糊规则。模糊规则是一种条件与结论之间的映射关系,用于描述输入变量与输出变量之间的关系。可以根据实际问题来确定模糊规则,例如:“如果输入变量A是低,并且输入变量B是中,则输出变量C是小”。 接下来,需要设计模糊推理机制。模糊推理将模糊规则与模糊集合进行组合,从而得到输出的模糊集合。常见的模糊推理方法包括最小最大法和加权平均法。最小最大法取各个规则输出的模糊集合的最小值,加权平均法则根据规则的权重对模糊集合进行加权平均。 最后,通过去模糊化处理将输出的模糊集合转化为具体的数值,以得到系统的控制输出。可以使用常见的去模糊化方法,如最大值法、中心加权平均法等。 总之,T-S模糊建模是一种通过将系统模型分解为多个子模型,通过模糊规则对子模型进行建模的方法。在Matlab中,可以利用Fuzzy Logic Toolbox来实现T-S模糊建模,并通过定义模糊集合、模糊规则、模糊推理和去模糊化等步骤来完成建模过程。这种方法在控制系统、模式识别等领域有着广泛的应用。 ### 回答3: T-S模糊建模是一种将模糊集理论应用于系统建模的方法,它结合了模糊集合和模糊逻辑控制的思想。在T-S模糊建模中,系统被分解为一系列局部模型,并利用隶属度函数描述系统的模糊性。 在Matlab中,我们可以使用模糊逻辑工具箱来实现T-S模糊建模。首先,我们需要明确系统的输入和输出变量,并确定它们的隶属度函数。然后,根据输入变量和输出变量之间的关系,建立一系列模糊规则。 在T-S模糊建模中,每个模糊子系统表示为一个模糊规则,规则由两个部分组成:前提部分和结论部分。前提部分是对输入变量的模糊描述,而结论部分是对输出变量的模糊描述。根据这些规则,我们可以用Matlab代码定义模糊推理过程。 模糊控制器的设计是T-S模糊建模的一个重要应用。在Matlab中,我们可以使用模糊控制器工具箱来设计模糊控制器。首先,我们需要确定输入和输出变量的隶属度函数,并定义一系列模糊规则。然后,我们可以使用模糊推理和去模糊方法来生成控制信号。 总之,T-S模糊建模是一种将模糊集合理论应用于系统建模的方法,在Matlab中可以使用模糊逻辑工具箱来实现。通过确定系统的输入和输出变量的隶属度函数,并建立模糊规则,我们可以进行模糊推理和控制。这种方法在各种实际应用中都具有广泛的应用前景。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值