expand.grid的动态参数

时间:2013-10-16 17:13:28

标签: r combinations

我正在使用expand.grid来生成向量的所有元素对,例如:

v <- 1:3
expand.grid(v,v)

给出了:

  Var1 Var2
1    1    1
2    2    1
3    3    1
4    1    2
5    2    2
6    3    2
7    1    3
8    2    3
9    3    3

现在,说我想要同样的东西,但我使用的是三胞胎

expand.grid(v,v,v)

我如何将此概括为n元组,以便我可以使用new.expand.grid(v,5)并得到expand.grid(v,v,v,v,v)的结果?

3 个答案:

答案 0 :(得分:12)

expand.grid可以输入list作为输入,那么replicate呢?

expand.grid(replicate(3, v, simplify=FALSE))

为了好玩,作为一个功能(虽然我知道你会知道如何做到这一点):

new.expand.grid <- function(input, reps) {
  expand.grid(replicate(reps, input, simplify = FALSE))
}

new.expand.grid(c(1, 2), 4)
#    Var1 Var2 Var3 Var4
# 1     1    1    1    1
# 2     2    1    1    1
# 3     1    2    1    1
# 4     2    2    1    1
# 5     1    1    2    1
# 6     2    1    2    1
# 7     1    2    2    1
# 8     2    2    2    1
# 9     1    1    1    2
# 10    2    1    1    2
# 11    1    2    1    2
# 12    2    2    1    2
# 13    1    1    2    2
# 14    2    1    2    2
# 15    1    2    2    2
# 16    2    2    2    2

答案 1 :(得分:5)

do.call是将动态参数集传递给函数的标准方法:

new.expand.grid <- function(vec,nrep) do.call(expand.grid,rep(list(vec),nrep))

示例:new.expand.grid(letters[1:2],4)

   Var1 Var2 Var3 Var4
1     a    a    a    a
2     b    a    a    a
3     a    b    a    a
4     b    b    a    a
5     a    a    b    a
6     b    a    b    a
7     a    b    b    a
8     b    b    b    a
9     a    a    a    b
10    b    a    a    b
11    a    b    a    b
12    b    b    a    b
13    a    a    b    b
14    b    a    b    b
15    a    b    b    b
16    b    b    b    b

答案 2 :(得分:1)

我认为最简单(也是最短)的解决方案如下:

expand.grid(rep(list(1:3), 2)) 
  Var1 Var2
1    1    1
2    2    1
3    3    1
4    1    2
5    2    2
6    3    2
7    1    3
8    2    3
9    3    3