# 路径展示角度defbrute_force_algorithm( target = [] ,path = '' ,prob ='' , pre = -1):
ret = []
path_tmp = ''
prob_tmp = ''for k,v inenumerate(Q):
path_tmp = '{}/{}'.format(path , v)
if prob == '':
prob_tmp = '{}/{},{}'.format(prob , Pi[k] , B[k][target[0]] )
else:
prob_tmp = '{}/{},{}'.format( prob , A[pre][k] , B[k][target[0]] )
iflen(target) > 1:
tmp = brute_force_algorithm(target[1:] , path_tmp ,prob_tmp , pre = k )
ret.extend( tmp )
eliflen(target) == 1:
ret.append([path_tmp , prob_tmp])
return ret
# 总概率展示角度defbrute_force_algorithm( target = [] ,path = '' ,prob = 0 , pre = -1):
ret = 0for k,v inenumerate(Q):
prob_tmp = prob
path_tmp = '{}/{}'.format(path , v)
if pre == -1 :
prob_tmp += Pi[k] * B[k][target[0]] # joint 联合概率局部else:
prob_tmp *= A[pre][k] * B[k][target[0]]
iflen(target) > 1:
ret += brute_force_algorithm(target[1:] , path_tmp ,prob_tmp , pre = k )
eliflen(target) == 1:
ret += prob_tmp
return ret
Forward 前向算法,时间复杂度:
defforward_algorithm( target = [] ):
prob = [ [ 0for i in Q] for j in target ]
for t ,o inenumerate(target):
if t == 0 :
for i inrange( len(Q) ):
prob[0][i] = Pi[i] * B[i][o]
else:
forid , q inenumerate(Q):
for k,v inenumerate(prob[t-1]):
print( v , A[k][id] , prob , prob[t][id] )
prob[t][id] += (v * A[k][id] * B[id][o] )
print(prob)
return prob
Backend后向算法,计算复杂度:
defbackend_algorithm( target = [] ):
prob = [ [ 0.0for i in Q] for j in target ]
length = len(target)
for t inrange( length-1 , -1 , -1):
if t == length-1 :
for i inrange( len(Q) ): # 后向计算有点问题
prob[t][i] = 1else:
o = target[t+1]
forid , q inenumerate(Q):
if t == 0:
for k,v inenumerate(prob[t+1]):
prob[t][id] *= 1000
prob[t][id] += ( v * A[id][k] * B[k][o] ) * 1000
prob[t][id] /= 1000else:
for k,v inenumerate(prob[t+1]):
prob[t][id] += v * A[id][k] * B[k][o]
for k,v inenumerate(prob[0]):
prob[0][k] = v * Pi[k] * B[k][target[0]]
return prob