[R] combinatorics again
Robin Hankin
r.hankin at noc.soton.ac.uk
Mon Mar 6 10:06:36 CET 2006
Hi
I want to enumerate all vectors of length "J", whose elements are
integers in the range 1 to S, without regard to ordering.
With J=S=3, the combinations are as follows:
[,1] [,2] [,3]
[1,] 1 1 1
[2,] 1 1 2
[3,] 1 1 3
[4,] 1 2 2
[5,] 1 2 3
[6,] 1 3 3
[7,] 2 2 2
[8,] 2 2 3
[9,] 2 3 3
[10,] 3 3 3
Note that (eg) c(1,2,1) is not on the list because we already have
c(1,1,2) which would be equivalent [because the problem is to
enumerate the cases without regard to ordering] and I do not want
repeats.
The best I can do is to create all S^J possibilities and weed out the
repeats, using unique() ; code below.
Why is this no good? Well, even for the tiny case of J=S=10, this
would require a matrix of 10^10 rows, and my little linux machine
refuses to cooperate, complaining about allocating a vector of
length 1410065408. For these values of J and S, I happen to know
that the are 6360 distinct combinations, which is eminently handleable.
Anyone got any better ideas?
allcomb <- function(J,S){
f <- function(...) {
1:S
}
out <- as.matrix(do.call("expand.grid", lapply(1:J, FUN = f)))
out <- t(apply(out,1,sort))
unique(out)
}
--
Robin Hankin
Uncertainty Analyst
National Oceanography Centre, Southampton
European Way, Southampton SO14 3ZH, UK
tel 023-8059-7743
More information about the R-help
mailing list