0
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)}
4

1 回答 1

2

我会...像这样收集所有变量:

scorekm <- function(km, x, ...) {
  x.args <- list(...)
  out <- do.call("cbind", x.args)
  out
}

请注意,通过命名您的参数,您将“随用随取”给它一个列名。

> scorekm(km = 1, x = 2, x1 = runif(3), column2 = runif(3), variable3 = runif(3))
            x1    column2 variable3
[1,] 0.2106436 0.07142857 0.6466394
[2,] 0.3684540 0.16306419 0.9937268
[3,] 0.5230319 0.66318683 0.3020110
于 2013-07-22T10:30:33.370 回答