用Python3實現的Mycin專家系統簡單實例

  1 from sys import stderr
  2 #########################
  3 TRUE = 1 #定義返回值
  4 FALSE = 0
  5 FACT_LENGTH = 9  #'''前提與結論總數'''
  6 PRMS_LENGTH = 2  #'''每條規則的前提個數'''
  7 PREMISE = 7 #'''前提數量''' 
  8 RULE_LENGTH = 4  #'''規則數量'''
  9 LIMIT = 0.5      #'''結論閾值'''
 10 AND = 1         #'''規則前提邏輯關係'''
 11 OR = 0
 12 VH = 0.9       #'''規則前提可信度初始化'''
 13 H = 0.7
 14 M = 0.5
 15 #double Rule_CF[RULE_LENGTH]
 16 Rule_CF = [0.0]*(RULE_LENGTH+1)
 17 Str = ["E1", "E2", "E3", "E4", "E5",
 18 "E6", "E7", "H1", "H", "\0"]
 19 Fuzz = [None]*10
 20 Input = [None]*PREMISE
 21 Repeat = -111   #'''從新輸入變量'''
 22 
 23 #'''知識表達'''
 24 Sign=[0,0,0,0,0,0,0,0,1]
 25 Rulep=[[1,2,0],[4,5,0],[6,8,0],[3,7,0]]
 26 Rulec=[[9,'AND'],[8,'AND'],[7,'AND'],[9,'OR']]
 27 ##
 28 def Max(a, b): #  '''可信度計算'''
 29     return a if a>b else b
 30 def Min(a, b):  
 31     return b if a>b else a
 32 def Mix(x, y):
 33     return (x+y-x*y)
 34 
 35 class fact(object):  #'''定義事實類''' 
 36     def __init__(self,Num,NamInput):
 37         self.Number=Num    #'''事實編號'''
 38         self.Active=False  #'''記錄事實的激活狀態'''
 39         self.CF=0  #'''事實可信度'''
 40         self.SignNum=0  #'''輸出標記'''
 41         self.Name=NamInput  #'''事實內容'''
 42     def Fuzz(i):   #'''定義可信度模糊函數'''
 43         pass
 44 ###        
 45     def Input(self,int):
 46         pass
 47     def GetName(self):
 48         return self.Name    
 49     def GetNumber(self):
 50         return self.Number
 51     def GetAct(self):
 52         return self.Active
 53     def PutAct(self,Act):
 54         self.Active=Act
 55     def PutFunc(self,f):
 56         self.Fuzz=f
 57     def GetCF(self):
 58         return self.CF
 59     def PutCF(self,i):
 60         if isinstance(i,int):
 61             self.CF=self.Fuzz(i)
 62             return self.CF
 63         else:
 64             self.CF=i    
 65     def PutSign(self,i):
 66             self.Sign =i        
 67     def GetSign(self):
 68         return self.Sign
 69 
 70 
 71 
 72 class rule(object):   #'''定義規則類'''
 73 
 74     def GetConc():
 75         return self.Conc
 76     def GetName():
 77         return self.Name
 78     def __init__(self,P,C,Rule_CF_Val):  
 79          #'''構造規則函數''' 
 80         #print(P)
 81         self.List=[None]*2
 82         self.Name="Rule Name"   
 83         self.List[0]=P[0]
 84         self.List[1]=P[1]
 85         self.Logic=C[1]
 86         self.Conc=C[0]
 87         self.RCFi=Rule_CF_Val
 88         self.Next=None    
 89 
 90                
 91 
 92     def __del__(self):  #'''構造釋放規則空間函數'''
 93         #delete Name
 94         #delete []List
 95         pass
 96 
 97     def Query(self):  #  '''構造推理函數'''
 98         sign=0
 99         temps=['']*10
100         choose=""
101         #fact* (*temp)=Fact
102         temp=Fact
103         while (sign<PRMS_LENGTH):
104             #for(;(*temp)!=NULL;temp=temp+1)
105             for index in range(len(temp)):
106                 if(temp[index].GetNumber()==self.List[sign]): break
107             if(temp[index]==None): return FALSE
108             if(temp[index].GetAct()>0):
109                 sign=sign+1
110                 temp=Fact
111             else:
112                 temp[index].Input(temp[index].GetNumber())
113                 choose=input() #scanf("%s",choose)
114                 # flushall()
115                 print()                
116                 if choose.lower()=="q":
117                     return TRUE
118                 if str(int(choose))!= choose :
119                     continue
120                 if temp[index].PutCF(int(choose))==int(Repeat):
121                     continue
122                 temp[index].PutAct(TRUE)
123         for index in range(len(temp)):
124             if(temp[index].GetNumber()==self.Conc): break
125         if(temp[index]==None): return FALSE
126         temp[index].PutCF(Mix(temp[index].GetCF(),self.CF()))
127         temp[index].PutAct(1)
128         return FALSE
129 
130     def CF(self):  #'''構造可信度推理函數'''
131         if self.Logic:
132             i=Min(Fact[self.List[0]-1].GetCF(),Fact[self.List[1]-1].GetCF())
133             i=i*self.RCFi
134             return i
135 
136      
137      #################
138 ##
139 Fact=[fact]*FACT_LENGTH
140 
141 #########################
142 def Init():  #'''初始化函數'''
143     DefFuncArray()
144     DefInput()
145     DefRule_CF()
146 
147 
148 def Input1(i):
149      print("按q或Q退出")
150      print("請輸入事實:E[",i,"的可信度")
151      print("可信度爲:") 
152      print(" [1]高")
153      print(" [2]中")
154      print(" [3]低")
155 
156 def Input2(i=3):
157      print("按q或Q退出")
158      print("請輸入事實 E[",i,"]數值[30-45]:")  
159 
160 def Input3(i=4):
161      print("按q或Q退出")
162      print("請輸入事實 E[",i,"]數值[60,160]:")
163 
164 def Fuzz1(sign):
165     switcher = {
166         1: VH,
167         2: H,
168         3: M,
169     }
170     if(sign in switcher.keys()):
171         return switcher[sign]
172     else:
173         stderr.write("請從新輸入!")
174         return Repeat    
175 
176 
177 def Fuzz2(sign):
178     if sign<30 or sign>45:
179         stderr.write("請從新輸入!")
180         return Repeat
181     i=(sign-37.0)/9.0
182     return i if i>0 else -i
183 
184 def Fuzz3(sign):
185     if sign<60 or sign>160:
186         stderr.write("請從新輸入!")
187         return Repeat
188 
189     i=(sign-60.0)/100.0
190     return(i)
191 
192 def DefFuncArray():
193     for i in range(4):
194         Fuzz[i]=Fuzz1
195     Fuzz[4]=Fuzz2
196     Fuzz[5]=Fuzz3
197 
198 def DefInput():
199     for i in range(4):
200         Input[i]=Input1
201     Input[4]=Input2
202     Input[5]=Input3
203 
204 #'''定義規則的可信度'''
205 def DefRule_CF():
206     Rule_CF[0]=0.9
207     Rule_CF[1]=1.0
208     Rule_CF[2]=0.9
209     Rule_CF[3]=0.9
210 
211 
212 def main():
213     #rule *Rule,*R    
214     #int i=0
215     Init()
216     #while(*Str[i]) #   '''激活事實對象集'''
217     for i in range(len(Fact)):
218         Fact[i]=fact((i+1),Str[i])
219         #print(Fact[i].GetName())
220         Fact[i].PutSign(Sign[i])
221     for s in range(PREMISE):
222         Fact[s].Input=Input[s]
223         Fact[s].PutFunc(Fuzz[s])
224 
225     Rule=None
226     for i in range(RULE_LENGTH-1,-1,-1): #'''激活規則對象集'''
227         if(i<0): return FALSE  
228         print(i)      
229         R=rule(Rulep[i],Rulec[i],Rule_CF[i])
230         R.Next=Rule
231         Rule=R
232 
233     R=Rule
234     while(True):
235            if(R.Query()): break
236            R=R.Next
237            if(not R): break
238 
239     #for(i=0;i<FACT_LENGTH;i++)  '''給出結論'''
240     for i in range(FACT_LENGTH):
241          if Fact[i].GetCF()>LIMIT and Fact[i].GetSign()==1:
242                 Fact[i].PutSign(0)
243                 print(" 結論爲:")
244                 print(Fact[i].GetName())
245                 print(" 其可信度爲:")
246                 print(Fact[i].GetCF())
247 
248     print("運行結束。")
249     input()
250     return TRUE
251 
252 if __name__=='__main__':
253     main() 
254  
相關文章
相關標籤/搜索