日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

模糊控制作业c语言,单片机 模糊控制 算法 c语言

發布時間:2024/9/19 编程问答 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 模糊控制作业c语言,单片机 模糊控制 算法 c语言 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

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; j112 { // 計算總和值

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 }

總結

以上是生活随笔為你收集整理的模糊控制作业c语言,单片机 模糊控制 算法 c语言的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。