【发布时间】:2020-05-22 15:18:09
【问题描述】:
我正在从包含平面上的点的数据集中读取数据。每个点都有 x 和 y 坐标。
with open('SJC324.txt') as f:
data=[]
for line in f:
x,y=(line.strip('\n').split())
data.append([int(x),int(y)])
initialisation(data)
然后我对这些点进行了 K-medoid 聚类。我已将中心点存储在列表中。然后我将检查距中心点特定半径内的点是什么。通过这种方式,我正在计算覆盖率。
def initialisation(data):
data=np.array(data)
D=pairwise_distances(data,metric='euclidean')
coverage=[]
for i in range(20):
covered_point=set()
M, C = kmedoids.kMedoids(D, len(data)//15)
medoid=data[M]
for temp in medoid:
for x in data:
if check_within_radius(temp,x):
covered_point.add(x)
coverage.append((len(covered_point)/len(data))*100)
print(coverage)
在这里,我正在检查哪些点位于这些中心点的特定半径内。
def check_within_radius(temp,x):
#temp is medoid point
#x is any random point
radius=10
if (((temp[0]-x[0])**2) + ((temp[1]-x[1])**2))< radius*radius:
return True
else:
return False
现在我收到以下错误。
<ipython-input-23-d04cdfb631a8> in initialisation(data)
16 for x in data:
17 if check_within_radius(temp,x):
---> 18 covered_point.add(x)
19 coverage.append((len(covered_point)/len(data))*100)
20 print(coverage)
TypeError: unhashable type: 'numpy.ndarray'
【问题讨论】:
标签: python python-3.x hashmap set hashtable