【发布时间】:2020-06-13 22:12:47
【问题描述】:
我正在尝试使用 Sklearn 库在 Python 中使用 Kmean 算法。我的问题是,有什么方法可以按升序生成质心。 例如这是我的代码:
kmeanDataFrame = pd.DataFrame({'x':X,'y':Y})
kmean = KMeans(init='k-means++',n_clusters = 6,random_state=0, n_init=10)
kmean.fit(kmeanDataFrame)
print(kmean.labels_)
print(kmean.cluster_centers_)
这里X和Y是数组,我给出的是不同年份的国家人口排名数据。例如,当我给它 2011 年时,中心点会不断变化,它会生成如下所示的中心点:
[[ 4.22019639 2.88409457]
[ 1.15267995 0.7954897 ]
[ 2.49913831 1.64727509]
[-1.71104298 -1.54454861]
[ 6.99545873 6.08921786]
[ 0.20412018 0.0517948 ]]
当我在 2012 年通过时,它会生成如下:
[[ 0.94596298 0.64243913]
[ 4.2710023 3.0083124 ]
[-0.27485671 -0.35197801]
[ 2.41465001 1.59198646]
[-6.514922 -4.53656495]
[ 7.77638888 7.18733868]]
有什么方法可以像这样按升序生成质心(先是负点,然后是正点):
[[-1.71104298 -1.54454861],
[ 0.20412018 0.0517948 ],
[ 1.15267995 0.7954897 ],
[ 2.49913831 1.64727509],
[ 4.22019639 2.88409457],
[ 6.99545873 6.08921786]]
【问题讨论】:
-
为了讨论:这篇文章一般来说可能有帮助,但它不适用于 python stackoverflow.com/questions/17685327/…
标签: python algorithm scikit-learn k-means sklearn-pandas