1.4.2 C語言代碼
#include
#include
#include
#define N 7 //定義量化論域模糊子集的個數
//模糊語言定義
#define NB -3
#define NM -2
#define NS -1
#define ZO 0
#define PS 1
#define PM 2
#define PB 3
struct
{
//規則表
int rule[ N ][ N ] ; //模糊規則表
//隸屬度函數
char *f_type_e ; //e的隸屬度函數類型
char *f_type_de ; //de的隸屬度函數類型
char *f_type_u ; //u的隸屬度函數類型
float paras_e[ 3*N ] ; //e的隸屬度函數的參數
float paras_de[ 3*N ] ; //de的隸屬度函數的參數
float paras_u[ 3*N ] ; //u的隸屬度函數的參數
//模糊運算參數
float Ke ; //Ke=n/emax,量化論域為[-3,-2,-1,0,1,2,3]
float Kde ; //Ke=n/demax,量化論域為[-3,-2,-1,0,1,2,3]
float Ku ; //Ke=umax/n,量¢化論域為[-3,-2,-1,0,1,2,3]
float umax ; //輸出的上限
float emax ; //誤差基本論域上限
float demax ; //誤差變化率基本論域的上限
//控制目標參數
float target ; //控制目標
float actual ; //實際值
float e ; //誤差
float e_pre ; //上一次的誤差
float de ; //誤差的變化率
}_fuzzy_;
/*******************************************************
Name :trimf
Function :三角隸屬度函數
Parameter :
x:自變量
(a,b,c):定義域
Return :結果
*******************************************************/
float trimf( float x, float a, float b, float c )
{
float u ;
if( ( x>=a )&&( x<=b ) )
u = ( x-a )/( b-a ) ;
else if( ( x>b )&&( x<=c ) )
u = ( c-x )/( c-b ) ;
else
u = 0 ;
return u ;
}
/*******************************************************
Name :gaussmf
Function :正態隸屬度函數
Parameter :
x:自變量
ave:均值
sigma:方差
Return :結果
*******************************************************/
float gaussmf( float x, float ave, float sigma )
{
float u ;
if( sigma<0 )
printf("方差不允許小于0\\n");
else
u = exp( -pow( ( ( x-ave )/sigma ), 2 ) ) ;
return u ;
}
/*******************************************************
Name :trapmf
Function :梯形隸屬度函數
Parameter :
x:自變量
(a,b,c,d):定義域
Return :結果
*******************************************************/
float trapmf( float x, float a, float b, float c, float d )
{
float u ;
if( ( x>=a )&&( xelse if( ( x>=b )&&( x
**
最終代碼運行結果如下圖所示。
參考于CDSN
**
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。
舉報投訴
-
模糊控制
+關注
關注
2文章
261瀏覽量
25500 -
模糊算法
+關注
關注
0文章
16瀏覽量
8740 -
自然語言
+關注
關注
1文章
288瀏覽量
13347
發布評論請先 登錄
相關推薦
PID算法之模糊PID 精選資料推薦
這方面的需求而設計的。專家算法和模糊算法都歸屬于智能算法的范疇,智能算法最大的優點就是在控制模型未知的情況下,可以對模型進行控制。這里需要注
發表于 07-19 06:29
PID算法學習筆記分享
最近在學習與無人機有關的一些控制算法,在這里做一些筆記,今天學的是有關于PID的算法。什么是PID首先關于PID的定義,因為我本身不是自動控制專業出身所以對于概念這個東西比較
發表于 01-14 06:50
基于模糊高斯學習策略的粒子群進化融合算法
針對粒子群優化(PSO)算法存在的開發能力不足,導致算法精度不高、收斂速度慢以及微分進化算法具有的探索能力偏弱,易陷入局部極值的問題,提出一種基于模糊高斯
發表于 11-27 17:35
?1次下載
基于深度學習的圖像去模糊算法及應用
當前,絕大部分基于深度學習的圖像去模糊算法是不區分場景的,也就是他們是對常見的自然與人為設計的場景進行去模糊。但是,在現實生活中,經常會遇到一些特定場景的圖像去
MATLAB學習筆記之模糊算法1
所謂模糊控制,就是對難以用已有規律描述的復雜系統,采用自然語言(如大,中,小)加以描述,借助定性的,不精確的以及模糊的條件語句來表達,模糊控制是一種基于語言的智能控制。
MATLAB學習筆記之模糊算法2
所謂模糊控制,就是對難以用已有規律描述的復雜系統,采用自然語言(如大,中,小)加以描述,借助定性的,不精確的以及模糊的條件語句來表達,模糊控制是一種基于語言的智能控制。
評論