找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 2476|回复: 0
打印 上一主题 下一主题
收起左侧

陀螺仪模糊控制2维三角形算法程序源码

[复制链接]
跳转到指定楼层
楼主
ID:302522 发表于 2018-4-5 20:31 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
互相交流

模糊控制2维三角形算法如下:
  1. #include "Fuzzy.h"
  2. //二维模糊控制系统
  3. //输入方向偏差与陀螺仪Y轴数据,控制输出方向P

  4. float  Angle_E[3]  = {5,10,15};   //角度偏差
  5. float  Gyro_E[3] = {10,15,30};           //角速度数据
  6. float  Shell_P[3]  = {10,15,40};  //外层比例控制系数

  7. //由于所测数据均为单向数据,故规则表拟定为单向
  8. int rule[3][3]=
  9.         {
  10.           {2,1,0},
  11.           {1,1,0},
  12.           {0,0,0},
  13.         };

  14. float Fuzzy_Shell_P(float E_angle,float E_gyro);                        

  15. float Fuzzy_Shell_P(float E_angle,float E_gyro)
  16. {
  17.   float  angle_err=0,gyro_err=0;
  18.   int angle_N=0,gyro_N=0; //隶属语言值
  19.   int  num=0;
  20.   float fuzzy_P=0;
  21.    //记录隶属函数的输出值
  22.   float  Angle_Fzy[2] ={0.0,0.0};
  23.   float  Gyro_Fzy[2] ={0.0,0.0};

  24.   float  Shell_P_Fzy[3] ={0.0,0.0,0.0};
  25.   // /*----- 数据更新-----*/
  26.   // Shell_P[1]  = P_Direction_low;
  27.   // Shell_P[2]  = P_Direction_high;


  28.   //将数据取绝对值,数据的正负仅代表左右        
  29.         ABS_val(E_angle,angle_err);
  30.         ABS_val(E_gyro,gyro_err);

  31.   /*-----   Angle 隶属函数描述-----*/
  32.         if(angle_err<Angle_E[0]) //1
  33.         {
  34.                 Angle_Fzy[0] =1.0;
  35.                 angle_N = 0;
  36.         }
  37.         else if(angle_err<Angle_E[1])  //2
  38.         {
  39.                 Angle_Fzy[0] = (Angle_E[1]-angle_err)/(Angle_E[1]-Angle_E[0]);
  40.                 angle_N = 0;
  41.         }
  42.         else if(angle_err<Angle_E[2])  //3
  43.         {
  44.                 Angle_Fzy[0] = (Angle_E[2]-angle_err)/(Angle_E[2]-Angle_E[1]);
  45.                 angle_N = 1;
  46.         }
  47.         else
  48.         {
  49.                 Angle_Fzy[0] =0;//4
  50.                 angle_N =1;
  51.         }
  52.         Angle_Fzy[1] = 1.0 - Angle_Fzy[0];//隶属函数输出值

  53.   /*----- Pre_dirr 变化隶属函数描述-----*/
  54.    if(gyro_err<Gyro_E[0])//当陀螺仪Y轴数据小于40时,对应三角隶属函数的隶属度为1,方向量度模糊等级为0级
  55.         {
  56.                 Gyro_Fzy[0] =1;
  57.                 gyro_N = 0;
  58.         }
  59.         else if(gyro_err<Gyro_E[1])//当陀螺仪Y轴数据小于70时,对应三角隶属函数的隶属度根据公式得出,方向量度模糊等级为0级,此时为40三角形的右边一半
  60.         {
  61.                 Gyro_Fzy[0] = (Gyro_E[1] - gyro_err)/(Gyro_E[1]-Gyro_E[0]);
  62.                 gyro_N = 0 ;
  63.         }
  64.         else if(gyro_err<Gyro_E[2])//当陀螺仪Y轴数据小于160时,对应三角隶属函数的隶属度根据公式得出,方向量度模糊等级为1级,此时为70三角形的左边一半
  65.         {
  66.                 Gyro_Fzy[0] = (Gyro_E[2] - gyro_err)/(Gyro_E[2]-Gyro_E[1]);
  67.                 gyro_N = 1;
  68.         }
  69.         else                     //当陀螺仪Y轴数据大于160时,对应三角隶属函数的隶属度根据公式得出,方向量度模糊等级为1级,此时为70三角形的右边一半
  70.         {
  71.                 Gyro_Fzy[0] =0.0;
  72.                 gyro_N = 1;
  73.         }
  74.         //一个数据在三角形隶属度函数中对应着两个相邻三角形中的隶属度,两个隶属度和为1
  75.         Gyro_Fzy[1] = 1.0 - Gyro_Fzy[0];

  76.         /*查询模糊规则表*/
  77.         //查表的时候不单单查询一个规则,而是向右向下拓展成一个规则正方形查询
  78.         num =rule[gyro_N][angle_N];
  79.         Shell_P_Fzy[num] += Gyro_Fzy[0]*Angle_Fzy[0];

  80.         num =rule[gyro_N+1][angle_N];
  81.         Shell_P_Fzy[num] += Gyro_Fzy[1]*Angle_Fzy[0];

  82.         num =rule[gyro_N][angle_N+1];
  83.         Shell_P_Fzy[num] += Gyro_Fzy[0]*Angle_Fzy[1];

  84.         num =rule[gyro_N+1][angle_N+1];
  85.         Shell_P_Fzy[num] += Gyro_Fzy[1]*Angle_Fzy[1];

  86.         /*面积中心法解模糊*/
  87.         fuzzy_P=Shell_P_Fzy[0]*Shell_P[0]+Shell_P_Fzy[1]*Shell_P[1]+Shell_P_Fzy[2]*Shell_P[2];
  88.   return(fuzzy_P);
  89. }
复制代码

所有资料51hei提供下载:
Fuzzy.zip (1.27 KB, 下载次数: 19)


分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏1 分享淘帖 顶 踩
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表