我试图让一个配方的工作,我在网上找到了做期望值最大化( http://code.activestate.com/recipes/577735-expectation-maximization/ )。 我遇到了以下错误:
Traceback (most recent call last):
File "./runem.py", line 7, in <module>
print expectation_maximization([[1,2,3,4,5],[2,3,4,5,6],[9,8,7,4,1]], 2)
File "/local/scratch-3/dk427/rp/em.py", line 83, in expectation_maximization
Px[o,c] = pnorm(t[o,:], params[c]['mu'], params[c]['sigma'])
File "/local/scratch-3/dk427/rp/em.py", line 18, in pnorm
xmt = np.matrix(x-m).transpose()
TypeError: __array_prepare__ must return an ndarray or subclass thereof which is otherwise identical to its input
必须有在算法的一些缺陷,或者我给它输入错误,但我找不到什么错。 我发现,错误是由减法造成的xm
,但是x.dtype=int64
和m.dtype=float64
,我认为应该工作。
有没有人有什么想法?