0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

MATLAB學(xué)習(xí)筆記之模糊算法3

jf_78858299 ? 來(lái)源:滑小稽筆記 ? 作者:電子技術(shù)園地 ? 2023-02-27 14:28 ? 次閱讀

1.4.2 C語(yǔ)言代碼

#include 
#include 
#include 
#define  N  7                      //定義量化論域模糊子集的個(gè)數(shù)
//模糊語(yǔ)言定義
#define  NB  -3
#define  NM  -2
#define  NS  -1
#define  ZO  0
#define  PS  1
#define  PM  2
#define  PB  3
struct
{
  //規(guī)則表
  int rule[ N ][ N ] ;                //模糊規(guī)則表
  //隸屬度函數(shù)
  char *f_type_e ;                  //e的隸屬度函數(shù)類型
  char *f_type_de ;                  //de的隸屬度函數(shù)類型
  char *f_type_u ;                  //u的隸屬度函數(shù)類型
  float paras_e[ 3*N ] ;                //e的隸屬度函數(shù)的參數(shù)
  float paras_de[ 3*N ] ;              //de的隸屬度函數(shù)的參數(shù)
  float paras_u[ 3*N ] ;                //u的隸屬度函數(shù)的參數(shù)
  //模糊運(yùn)算參數(shù)
  float Ke ;                    //Ke=n/emax,量化論域?yàn)閇-3,-2,-1,0,1,2,3]
  float Kde ;                    //Ke=n/demax,量化論域?yàn)閇-3,-2,-1,0,1,2,3]
  float Ku ;                    //Ke=umax/n,量¢化論域?yàn)閇-3,-2,-1,0,1,2,3]
  float umax ;                    //輸出的上限
  float emax ;                    //誤差基本論域上限
  float demax ;                    //誤差變化率基本論域的上限
  //控制目標(biāo)參數(shù)
  float target ;                  //控制目標(biāo)
  float actual ;                  //實(shí)際值
  float e ;                    //誤差
  float e_pre ;                    //上一次的誤差
  float de ;                    //誤差的變化率
}_fuzzy_;
/*******************************************************
Name      :trimf
Function    :三角隸屬度函數(shù)
Parameter  :
      x:自變量
      (a,b,c):定義域
Return    :結(jié)果
*******************************************************/
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    :正態(tài)隸屬度函數(shù)
Parameter  :
      x:自變量
      ave:均值
      sigma:方差
Return    :結(jié)果
*******************************************************/
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    :梯形隸屬度函數(shù)
Parameter  :
      x:自變量
      (a,b,c,d):定義域
Return    :結(jié)果
*******************************************************/
float trapmf( float x, float a, float b, float c, float d )
{
  float u ;
  if( ( x>=a )&&( xelse if( ( x>=b )&&( x

**
最終代碼運(yùn)行結(jié)果如下圖所示。

參考于CDSN

**

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 模糊控制
    +關(guān)注

    關(guān)注

    2

    文章

    260

    瀏覽量

    25476
  • 模糊算法
    +關(guān)注

    關(guān)注

    0

    文章

    16

    瀏覽量

    8734
  • 自然語(yǔ)言
    +關(guān)注

    關(guān)注

    1

    文章

    282

    瀏覽量

    13314
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    matlabdsp學(xué)習(xí)

    matlabdsp學(xué)習(xí)
    發(fā)表于 07-05 17:20

    FCM聚類算法以及改進(jìn)模糊聚類算法用于醫(yī)學(xué)圖像分割的matlab源程序

    FCM聚類算法以及改進(jìn)模糊聚類算法用于醫(yī)學(xué)圖像分割的matlab源程序
    發(fā)表于 05-11 23:54

    算法圖解學(xué)習(xí)筆記分享

    算法圖解學(xué)習(xí)筆記03:分而治之
    發(fā)表于 06-05 17:42

    PID算法模糊PID 精選資料推薦

    這方面的需求而設(shè)計(jì)的。專家算法模糊算法都?xì)w屬于智能算法的范疇,智能算法最大的優(yōu)點(diǎn)就是在控制模型未知的情況下,可以對(duì)模型進(jìn)行控制。這里需要注
    發(fā)表于 07-19 06:29

    求大佬分享MatLab學(xué)習(xí)筆記

    求大佬分享MatLab學(xué)習(xí)筆記
    發(fā)表于 11-19 07:00

    PID算法學(xué)習(xí)筆記分享

    最近在學(xué)習(xí)與無(wú)人機(jī)有關(guān)的一些控制算法,在這里做一些筆記,今天學(xué)的是有關(guān)于PID的算法。什么是PID首先關(guān)于PID的定義,因?yàn)槲冶旧聿皇亲詣?dòng)控制專業(yè)出身所以對(duì)于概念這個(gè)東西比較
    發(fā)表于 01-14 06:50

    模糊PID控制及其MATLAB仿真

    模糊PID控制及其MATLAB仿真,主要是MATLAB仿真,對(duì)于研究模糊PID算法有借鑒意義
    發(fā)表于 11-12 17:15 ?0次下載

    模糊推理的Mamdani算法及其Matlab實(shí)現(xiàn)

    模糊濾波的mamdani算法及其Matlab實(shí)現(xiàn)
    發(fā)表于 11-17 18:23 ?40次下載

    基于模糊高斯學(xué)習(xí)策略的粒子群進(jìn)化融合算法

    針對(duì)粒子群優(yōu)化(PSO)算法存在的開(kāi)發(fā)能力不足,導(dǎo)致算法精度不高、收斂速度慢以及微分進(jìn)化算法具有的探索能力偏弱,易陷入局部極值的問(wèn)題,提出一種基于模糊高斯
    發(fā)表于 11-27 17:35 ?1次下載

    流形學(xué)習(xí)LLE算法的配套Matlab源碼匯總

    流形學(xué)習(xí)LLE算法的配套Matlab源碼匯總
    發(fā)表于 08-25 09:30 ?1次下載

    OpenStackCinder學(xué)習(xí)筆記

    OpenStackCinder學(xué)習(xí)筆記(開(kāi)關(guān)電源技術(shù)教程ppt)-該文檔為OpenStackCinder學(xué)習(xí)
    發(fā)表于 09-23 12:40 ?5次下載
    OpenStack<b class='flag-5'>之</b>Cinder<b class='flag-5'>學(xué)習(xí)</b><b class='flag-5'>筆記</b>

    基于深度學(xué)習(xí)的圖像去模糊算法及應(yīng)用

    當(dāng)前,絕大部分基于深度學(xué)習(xí)的圖像去模糊算法是不區(qū)分場(chǎng)景的,也就是他們是對(duì)常見(jiàn)的自然與人為設(shè)計(jì)的場(chǎng)景進(jìn)行去模糊。但是,在現(xiàn)實(shí)生活中,經(jīng)常會(huì)遇到一些特定場(chǎng)景的圖像去
    的頭像 發(fā)表于 10-28 16:00 ?2399次閱讀

    MATLAB學(xué)習(xí)筆記模糊算法1

    所謂模糊控制,就是對(duì)難以用已有規(guī)律描述的復(fù)雜系統(tǒng),采用自然語(yǔ)言(如大,中,小)加以描述,借助定性的,不精確的以及模糊的條件語(yǔ)句來(lái)表達(dá),模糊控制是一種基于語(yǔ)言的智能控制。
    的頭像 發(fā)表于 02-27 14:28 ?2559次閱讀
    <b class='flag-5'>MATLAB</b><b class='flag-5'>學(xué)習(xí)</b><b class='flag-5'>筆記</b><b class='flag-5'>之</b><b class='flag-5'>模糊</b><b class='flag-5'>算法</b>1

    MATLAB學(xué)習(xí)筆記模糊算法2

    所謂模糊控制,就是對(duì)難以用已有規(guī)律描述的復(fù)雜系統(tǒng),采用自然語(yǔ)言(如大,中,?。┘右悦枋?,借助定性的,不精確的以及模糊的條件語(yǔ)句來(lái)表達(dá),模糊控制是一種基于語(yǔ)言的智能控制。
    的頭像 發(fā)表于 02-27 14:28 ?1620次閱讀
    <b class='flag-5'>MATLAB</b><b class='flag-5'>學(xué)習(xí)</b><b class='flag-5'>筆記</b><b class='flag-5'>之</b><b class='flag-5'>模糊</b><b class='flag-5'>算法</b>2

    MATLAB學(xué)習(xí)筆記WM算法

    在現(xiàn)代智能控制算法中,模糊控制是在實(shí)際控制系統(tǒng)設(shè)計(jì)中使用比較成熟的一種方法。模糊控制可以使用在一些無(wú)法建立系統(tǒng)模型的場(chǎng)合,根據(jù)專家經(jīng)驗(yàn)確定模糊規(guī)則,實(shí)現(xiàn)對(duì)系統(tǒng)的控制。
    的頭像 發(fā)表于 02-27 14:40 ?1170次閱讀
    <b class='flag-5'>MATLAB</b><b class='flag-5'>學(xué)習(xí)</b><b class='flag-5'>筆記</b><b class='flag-5'>之</b>WM<b class='flag-5'>算法</b>