-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathinference.py
172 lines (153 loc) · 5.18 KB
/
inference.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
#
## '''推理机头文件inference'''
import kb
class fact(object): #'''定义事实类'''
def __init__(self,Num,NamInput):
self.Number=Num #'''事实编号'''
self.Active=False #'''记录事实的激活状态'''
self.CF=0 #'''事实可信度'''
self.Sign=0 #'''输出标记'''
self.Name=NamInput #'''事实内容'''
def Fuzz(i): #'''定义可信度模糊函数'''
pass
###
def Input(int):
pass
def GetName():
return self.Name
def GetNumber():
return self.Number
def GetAct():
return self.Active
def PutAct(Act):
self.Active=Act
def PutFunc(f):
self.Fuzz=f
def GetCF():
return self.CF
def PutCF(i):
if isinstance(i,int):
self.CF=self.Fuzz(i)
return self.CF
else:
self.CF=i
def PutSign(i):
self.Sign=i
def GetSign():
return self.Sign
# private:
# int Number; '''事实编号'''
# char *Name; '''事实内容'''
# double CF; '''事实可信度'''
# int Active; '''记录事实的激活状态'''
# int Sign; '''输出标记'''
# double (*Fuzz)(int i); '''定义可信度模糊函数'''
# public:
# void (*Input)(int); '''输入函数'''
# fact(int Num, *L) '''初始化事实'''
# Name=(char*) malloc(strlen(L)+1)
# strcpy(Name,L)
# Number=Num
# Active=FALSE
# CF=0
# Sign=0
# char* GetName()
# char *L
# L=new char(strlen(Name)+1)
# if L!=NULL) strcpy(L,Name:
# return L
# int GetNumber(){return Number;
# int GetAct(){return Active;
# void PutAct( int Act){Active=Act;
# void PutFunc(double(*f)(int)){Fuzz=f;
# double GetCF(){return CF;
# int PutCF(int i) '''处理用户输入'''
# CF=Fuzz(i)
# return CF
# void PutCF(double d) '''置可信度计算结果标记'''
# CF=d
# void PutSign(int i) '''置输出标记'''
# Sign=i
# int GetSign(){return Sign;
#fact *Fact[FACT_LENGTH+1]
Fact =[]*(FACT_LENGTH+1)
#for i in range(FACT_LENGTH+1):
# Fact.append()
class rule(object): #'''定义规则类'''
# private:
# char *Name; '''规则名'''
# int List[PRMS_LENGTH]; '''同一规则的所有前提链表'''
# int Logic; '''定义规则间的逻辑关系'''
# int Conc; '''规则结论'''
# double RCFi; '''规则可信度'''
# public:
#???? rule *Next
# rule( int P[], C[], Rule_Cf)
# ~rule()
# int Query()
# char *GetName(){return Name;
# double CF()
def GetConc():
return self.Conc
def GetName():
return self.Name
def __init__(P,C,Rule_CF): #'''构造规则函数'''
self.Name="Rule Name"
self.List[0]=P[0]
self.List[1]=P[1]
self.Logic=C[1]
self.Conc=C[0]
self.RCFi=Rule_CF
self.Next=None
def __del__(self): #'''构造释放规则空间函数'''
#delete Name
#delete []List
pass
def Max(a, b): # '''可信度计算'''
return a if a>b else b
def Min(a, b):
return b if a>b else a
def Mix(x, y):
return (x+y-x*y)
def Query(): # '''构造推理函数'''
sign=0
temps=['']*10
choose=""
#fact* (*temp)=Fact
temp=Fact
while (sign<PRMS_LENGTH):
#for(;(*temp)!=NULL;temp=temp+1)
for index in range(len(temp)):
if(temp[index].GetNumber()==self.List[sign]): break
if(temp[index]==None): return FALSE
if(temp[index].GetAct()>0):
sign=sign+1
temp=Fact
else:
temp[index].Input(temp[index].GetNumber())
choose=input() #scanf("%s",choose)
# flushall()
print()
if choose.lower()=="q":
return TRUE
if str(int(choose))!= choose :
continue
if temp[index].PutCF(int(choose))==int(Repeat):
continue
temp[index].PutAct(TRUE)
for index in range(len(temp)):
if(temp[index].GetNumber()==self.Conc): break
if(temp[index]==None): return FALSE
temp[index].PutCF(Mix(temp[index].GetCF(),self.CF()))
temp[index].PutAct(1)
return FALSE
def CF(): #'''构造可信度推理函数'''
if self.Logic:
i=Min(Fact[List[0]-1].GetCF(),Fact[List[1]-1].GetCF())
i=i*RCFi
return i
def Init(self): #'''初始化函数'''
DefFuncArray()
DefInput()
DefRule_CF()
Fact[FACT_LENGTH]=None;