代码有点复杂,抱歉。请关注parallel_p
功能。虽然sign
是一个元组,但Python抱怨道:
if sign in hashtable
并提供TypeError
。为什么sign
是numpy.ndarray
而不是元组?我把它创建为一个元组。
p_dist = dict()
def parallel_prog(hashtable):
def wrapper(func):
if parallel_programming:
@wraps(func)
def parallel_p(*args, **kwargs):
sign = tuple(args)
print type(sign)
if sign in hashtable:
r = hashtable[sign] # hit.
return r
r = func(*args, **kwargs)
hashtable[tuple(sign)] = r # register for future hits.
return r
return parallel_p
else:
return func
return wrapper
@parallel_prog(p_dist)
def euclidean(a, b, signature=None):
val = np.sqrt(np.add.reduce((a - b)**2))
return val
class similartyTest(unittest.TestCase):
def setUp(self):
self.t = np.array([1,2,3,4])
self.t1 = np.array([0, 0, 0, 0])
self.t2 = np.array([4,3,2,1])
self.h1 = [1,0,0,1,1]
self.h2 = [1,1,1,1,1]
def test_euclidean(self):
self.failUnless(euclidean(self.t, self.t) == 0)
self.failUnless(euclidean(self.t, self.t1) == sqrt(30))
<type 'tuple'>`
TypeError: unhashable type: 'numpy.ndarray`
答案 0 :(得分:14)
并非每个元组都可以播放。包含不可清洗项目的元组不可清除:
>>> x = ([], [])
>>> hash(x)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: unhashable type: 'list'
你的元组显然包含一个NumPy数组,这个数组远不像一个类型那样可以清理。
答案 1 :(得分:1)
元组只有在持有可引用的引用时才可以清除。
t1 = (7, 'A')
t2 = (7, 'A', {1, 2, 3})
t1是可清除的,但t2不是。
以下链接提供了更详细的说明: https://www.quora.com/Are-tuples-hashable-in-Python/answer/Luciano-Ramalho?srid=T4aW