当前位置:首页 > 单片机 > 单片机
[导读] 1 #include "reg52.h" 2 //------------------------------------------------------------------------------------ 3 // 定义差距输入常量 4 #define GAP_ZERO 0x00 5 #define GAP_VSMALL 0x01 6 #define GAP_

1 #include "reg52.h"

2 //------------------------------------------------------------------------------------

3 // 定义差距输入常量

4 #define GAP_ZERO 0x00

5 #define GAP_VSMALL 0x01

6 #define GAP_SMALL 0x02

7 #define GAP_MEDIUM 0x03

8 #define GAP_BIG 0x04

9 // 定义控制输出常量

10 #define TURN_ZERO 0x80

11 #define TURN_VSMALL 0x81

12 #define TURN_SMALL 0x82

13 #define TURN_MEDIUM 0x83

14 #define TURN_BIG 0x84

15 //-------------定义常量----------------------------------------------------------------

16 #define MU_MAX 0XFF //模糊度的最大值为0XFF代表面1

17 #define RULE_TOT 10 //规则数个数

18 #define MF_TOT 5 //成员函数的个数

19 #define IO_NUM 0x07

20 #define LABEL_NUM 0x70

21 #define DEFAULT_VALUE 0x00

22 //----------------定义数据库-----------------------------------------------------------

23 unsigned char code output_memf[MF_TOT]={0, 15, 35, 60, 102};// OUTPUT TURNING NUMBER:

24 // ZERO, VSMALL, SMALL, MEDIUM, BIG

25 // 输入功能函数以点斜式方式存储. 第一维成员函数标号第二维是点斜式数据

26 unsigned char code input_memf[MF_TOT][4]={ //距离功能函数

27 { 0x00, 0x00, 0x00, 0x0d }, // VSLOW

28 { 0x00, 0x0d, 0x14, 0x0d }, // SLOW

29 { 0x1e, 0x0d, 0x32, 0x0d }, // MEDIUM

30 { 0x3C, 0x0d, 0x50, 0x0d }, // FAST

31 { 0x50, 0x09, 0x6e, 0x00 } // VFAST

32 };

33 //-----------定义模糊系统规则-----------------------------------------------------------

34 unsigned char code rules[RULE_TOT]={

35 // if... then...

36 GAP_ZERO,TURN_ZERO,

37 GAP_VSMALL,TURN_VSMALL,

38 GAP_SMALL,TURN_SMALL,

39 GAP_MEDIUM,TURN_MEDIUM,

40 GAP_BIG,TURN_BIG

41 };

42 //-----------定义各变量-----------------------------------------------------------------

43 unsigned char outputs[MF_TOT],fuzzy_out; //模糊输出mu值

44 //-----------子程序函数头申明-----------------------------------------------------------

45 void fuzzy_engine(uchar);

46 uchar compute_memval(uchar,uchar);

47 void defuzzify(void);

48 /***************************************************************************************************************/

49 uchar compute_memval(uchar input,uchar label)

50 {

51 int data temp;

52 if (input < input_memf[label][0])

53 { // 如果输入不在曲线下u值为0

54 return 0;

55 }

56 else

57 {

58 if (input < input_memf[label][2])

59 {

60 temp=input; // 用点斜式计算mu

61 temp-=input_memf[label][0];

62 if (!input_memf[label][1])

63 {

64 temp=MU_MAX;

65 }

66 else

67 {

68 temp*=input_memf[label][1];

69 }

70 if (temp < 0x100)

71 { // 如果结果不超过1

72 return temp; // 返回计算结果

73 }

74 else

75 {

76 return MU_MAX; // 确保mu值在范围内

77 }

78 }

79 else

80 { // 输入落在第二条斜线上

81 temp=input; // 用点斜式方法计算 mu

82 temp-=input_memf[label][2];

83 temp*=input_memf[label][3];

84 temp=MU_MAX-temp;

85 if (temp < 0)

86 { // 确保结果不小于0

87 return 0;

88 }

89 else

90 {

91 return temp; // mu为正 – 返回结果

92 }

93 }

94 }

95 return 0;

96 }

97 /*******************************************************************************

98 Function: defuzzify

99 Description: 计算模糊输出的重心并调用函数把它

100 转换成可被系统使用的输出量

101 Parameters: 无.

102 Returns: 无.

103 Side Effects: outputs[][] 数组被清零.

104 *******************************************************************************/

105 void defuzzify(void)

106 {

107 unsigned long numerator, denominator;

108 unsigned char j;

109 numerator=0; // 恢复总数值

110 denominator=0;

111 for (j=0; j

112 { // 计算总和值

113 numerator+=(outputs[j]*output_memf[j]);

114 denominator+=outputs[j];

115 outputs[j]=0; // 清零输出作为参考使用

116 if (denominator)

117 { // 确保分母是0的情况不发生

118 fuzzy_out=numerator/denominator; // 确定 COG

119 }

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

9月2日消息,不造车的华为或将催生出更大的独角兽公司,随着阿维塔和赛力斯的入局,华为引望愈发显得引人瞩目。

关键字: 阿维塔 塞力斯 华为

加利福尼亚州圣克拉拉县2024年8月30日 /美通社/ -- 数字化转型技术解决方案公司Trianz今天宣布,该公司与Amazon Web Services (AWS)签订了...

关键字: AWS AN BSP 数字化

伦敦2024年8月29日 /美通社/ -- 英国汽车技术公司SODA.Auto推出其旗舰产品SODA V,这是全球首款涵盖汽车工程师从创意到认证的所有需求的工具,可用于创建软件定义汽车。 SODA V工具的开发耗时1.5...

关键字: 汽车 人工智能 智能驱动 BSP

北京2024年8月28日 /美通社/ -- 越来越多用户希望企业业务能7×24不间断运行,同时企业却面临越来越多业务中断的风险,如企业系统复杂性的增加,频繁的功能更新和发布等。如何确保业务连续性,提升韧性,成...

关键字: 亚马逊 解密 控制平面 BSP

8月30日消息,据媒体报道,腾讯和网易近期正在缩减他们对日本游戏市场的投资。

关键字: 腾讯 编码器 CPU

8月28日消息,今天上午,2024中国国际大数据产业博览会开幕式在贵阳举行,华为董事、质量流程IT总裁陶景文发表了演讲。

关键字: 华为 12nm EDA 半导体

8月28日消息,在2024中国国际大数据产业博览会上,华为常务董事、华为云CEO张平安发表演讲称,数字世界的话语权最终是由生态的繁荣决定的。

关键字: 华为 12nm 手机 卫星通信

要点: 有效应对环境变化,经营业绩稳中有升 落实提质增效举措,毛利润率延续升势 战略布局成效显著,战新业务引领增长 以科技创新为引领,提升企业核心竞争力 坚持高质量发展策略,塑强核心竞争优势...

关键字: 通信 BSP 电信运营商 数字经济

北京2024年8月27日 /美通社/ -- 8月21日,由中央广播电视总台与中国电影电视技术学会联合牵头组建的NVI技术创新联盟在BIRTV2024超高清全产业链发展研讨会上宣布正式成立。 活动现场 NVI技术创新联...

关键字: VI 传输协议 音频 BSP

北京2024年8月27日 /美通社/ -- 在8月23日举办的2024年长三角生态绿色一体化发展示范区联合招商会上,软通动力信息技术(集团)股份有限公司(以下简称"软通动力")与长三角投资(上海)有限...

关键字: BSP 信息技术
关闭
关闭