资源简介
两输入单输出模糊控制c语言程序.c文件,c语言编写,此程序原为本人用在模糊PID上
代码片段和文件信息
#include “common.h“
#include “include.h“
float Fuzzy(float Pfloat D)
{
/*输入量P语言值特征点*/
float PFF[7]={-24-12-6061224};
/*输入量D语言值特征点*/
float DFF[5]={-6.5-3036.5};
/*输出量U语言值特征点*/
float UFF[7]={01520355080120};
/*规则表*/
int8 rule[7][5]={
// -2 -1 0 1 2 ec e
{ 1 1 1 0 0} // -3
{ 4 2 1 0 0} // -2
{ 6 4 1 1 0} // -1
{ 3 3 0 3 3} // 0
{ 0 1 1 4 6} // 1
{ 0 0 1 2 4} // 2
{ 0 0 1 1 1} // 3
};
/*输出值的精确量*/
float U=0;
/*偏差偏差微分以及输出值的隶属度*/
float PF[2]={0}DF[2]={0}UF[4]={0};
int8 Pn=0Dn=0Un[4]={0};
float t1=0t2=0t3=0t4=0temp1=0temp2=0;
/*****隶属度的确定*****/
/*根据P的指定语言值获得有效隶属度*/
if(P>PFF[0] && P {
if(P<=PFF[1])
{
Pn=-2;
PF[0]=(PFF[1]-P)/(PFF[1]-PFF[0]);
}
else if(P<=PFF[2])
{
Pn=-1;
PF[0]=(PFF[2]-P)/(PFF[2]-PFF[1]);
}
else if(P<=PFF[3])
{
Pn=0;
PF[0]=(PFF[3]-P)/(PFF[3]-PFF[2]);
}
else if(P<=PFF[4])
{
Pn=1;
PF[0]=(PFF[4]-P)/(PFF[4]-PFF[3]);
}
else if(P<=PFF[5])
{
Pn=2;
PF[0]=(PFF[5]-P)/(PFF[5]-PFF[4]);
}
else if(P<=PFF[6])
{
Pn=3;
PF[0]=(PFF[6]-P)/(PFF[6]-PFF[5]);
}
}
else if(P<=PFF[0])
{
Pn=-2;
PF[0]=1;
}
else if(P>=PFF[6])
{
Pn=3;
PF[0]=0;
}
PF[1]=1-PF[0];
/*根据D的指定语言值获得有效隶属度*/
if(D>DFF[0]&&D {
if(D<=DFF[1])
{
Dn
- 上一篇:基于mpu9250的磁力计校准算法
- 下一篇:校园卡信息管理系统
相关资源
- C++中头文件与源文件的作用详解
- C语言代码高亮html输出工具
- 猜数字游戏 c语言代码
- C语言课程设计
- 数字电位器C语言程序
- CCS FFT c语言算法
- 使用C语言编写的病房管理系统
- 通信过程中的RS编译码程序(c语言)
- 计算机二级C语言上机填空,改错,编
- 用回溯法解决八皇后问题C语言实现
- 简易教务管理系统c语言开发文档
- 操作系统课设 读写者问题 c语言实现
- 小波变换算法 c语言版
- C流程图生成器,用C语言代码 生成C语
- 3des加密算法C语言实现
- 简单的C语言点对点聊天程序
- 单片机c语言源程序(51定时器 八个按
- 个人日常财务管理系统(C语言)
- c语言电子商务系统
- 小甲鱼C语言课件 源代码
- 将图片转换为C语言数组的程序
- C语言实现的一个内存泄漏检测程序
- DES加密算法C语言实现
- LINUX下命令行界面的C语言细胞游戏
- 用单片机控制蜂鸣器播放旋律程序(
- 学校超市选址问题(数据结构C语言版
- 电子时钟 有C语言程序,PROTEUS仿真图
- 尚观培训linux许巍老师关于c语言的课
- 算符优先语法分析器(C语言编写)
- 基于C语言的密码锁程序
评论
共有 条评论