scorekm <- function(km, x1,x2,x3,x4) {
data<-matrix(c(x1,x2,x3,x4),nrow=1)
k <- nrow(km$centers)
n <- nrow(data)
d <- as.matrix(dist(rbind(km$centers, data)))[-(1:k),1:k]
d <- matrix(d,nrow=1)
out <- apply(d, 1, which.min)
return(out)
}
これが私の本来の機能です。現在、いくつかのパラメーター (4 つだけでなく、おそらく 8、12、...) があり、4 つごとに 1 つの単位があります。forループを使用する必要がありますか? for ループでは、どうすればパラメータに到達できますか?また、パラメータの数を知るにはどうすればよいですか?
scorekm <- function(km,x...){}
関数はこのようにする必要があります。
km<-kmeans(iris,3)
scorekm<-
function(km, x,...)
{
result=NULL
for(i in 1:nargs()-1)
{
data<-matrix(c(args[[i+1]],args[[i+2]],args[[i+3]],args[[i+4]]),nrow=1)
k <- nrow(km$centers)
d <- as.matrix(dist(rbind(km$centers, data)))[-(1:k),1:k]
d <- matrix(d,nrow=1)
out <- apply(d, 1, which.min)
result<-cbind(out,result)
i<-i+4
}
return(result)}