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个为一个单位。我应该使用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)}