我正在从事与集群任务有关的任务。 DBSCAN拟合过程产生奇怪的结果,我不知道我的错误在哪里。我简化了代码,只留下了重要的部分:
clusters = pd.read_csv('cl.csv')
def stb_metric(mac1,mac2):
if mac1[0] == mac2[0]:
return 0
print(mac1[0],mac2[0])
return 1
X = clusters.mac.unique().reshape(-1,1)
db = DBSCAN(eps = 1,min_samples = 1,metric = stb_metric).fit(X)
在“ stb_metric”输出中,我观察到不存在的mac1或mac2。我已附上csv档案进行测试。输出如下:
(8.354702571827299e+18,2.9454553327798374e+17)
(8.354702571827299e+18,6.197480706091255e+17)
(8.354702571827299e+18,2.2314854373712773e+18)
(8.354702571827299e+18,2.5842000416550815e+18)
(8.354702571827299e+18,3.525512049236994e+18)
(8.354702571827299e+18,3.678065423036415e+18)
(8.354702571827299e+18,5.232482030018176e+18)
(8.354702571827299e+18,9.212176082078934e+18)
(8.354702571827299e+18,1.0293104245975763e+19)
(8.354702571827299e+18,1.2339113289676194e+19)
(8.354702571827299e+18,1.2848720441363968e+19) etc