我正在尝试将数据点(通过欧几里德距离)分配给已知的、预定义的一组中心点,将点分配给最接近的固定中心点。
我有一种感觉,我可能过于复杂/缺少一些基本的东西,但我已经尝试使用具有预定中心且没有迭代的 kmeans 实现来做到这一点。但是,根据下面的代码,并且可能因为算法将进行一次迭代,这无法正常工作(cl$centers 已“移动”并且不等于原始质心)
是否有另一种简单的方法可以将矩阵 X 中的点分配给最近的中心?
非常感谢提前,W
x <- rbind(matrix(rnorm(100, sd = 0.3), ncol = 2), matrix(rnorm(100, mean = 1, sd = 0.3), ncol = 2))
colnames(x) <- c("x", "y")
vector=c(0.25,0.5,0.75,1)
ccenters <- as.matrix(cbind(vector,vector))
colnames(ccenters) <- c("x", "y")
ccenters
(cl <- kmeans(x, centers=ccenters,iter.max=1))
plot(x, col = cl$cluster)
points(cl$centers, col = 1:4, pch = 8, cex = 2)
cl$centers
cl$centers==ccenters