[R] R: generating independent vectors
Chuck Cleland
ccleland at optonline.net
Fri Mar 11 13:58:20 CET 2005
You might try mvrnorm() in MASS.
library(MASS)
mvrnorm(n=10, mu=rep(0, 3), Sigma=diag(3), empirical=TRUE)
Clark Allan wrote:
> hi all
>
> i would like to generate independent vectors. i have included the code
> below. i display the correlation matrix of the n*p (n=the number of
> samples, p= the number of variables) matrix.
> what i find is that as n increases, the correlation matrix tends to an
> identity matrix. i.e. independence. for small samples (see examples
> below, for n=20, p=5 ; n=50,p=5, n=100,p=5; n=10000,p=5) the variables
> does not appear to be independent. note that i have not tested this
> statement statistically.
>
> ARE these variables independent? by setting the seed for each variable
> run i HOPE that the variables are now independent. IS this true??? if
> not does anyone know how to generate these independent variables?
>
> how does R generate its random variables? does it use the box muller
> technique? if so how does it generate the random uniform variables?
>
> thanking you in advance!!!
> ***
> allan
>
>
>
> IND<-function(rows.=10,col.=3)
> {
> a<-matrix(nrow=rows.,ncol=col.)
> for (j in 1:col.)
> {
> set.seed(j)
> r<-rnorm(rows.)
> a[,j]<-r
> }
> #list(a=a,cor=cor(a))
> cor(a)
> }
> IND(rows.=10,col.=3)
>
>
>
>
>>IND(rows.=20,col.=5)
>
> [,1] [,2] [,3] [,4] [,5]
> [1,] 1.00000000 0.25677165 -0.14882130 -0.09190797 0.1562481
> [2,] 0.25677165 1.00000000 0.02585515 0.13735712 -0.1443301
> [3,] -0.14882130 0.02585515 1.00000000 -0.11311416 0.1437001
> [4,] -0.09190797 0.13735712 -0.11311416 1.00000000 0.1833647
> [5,] 0.15624807 -0.14433011 0.14370006 0.18336467 1.0000000
>
>
>
>>IND(rows.=50,col.=5)
>
> [,1] [,2] [,3] [,4] [,5]
> [1,] 1.0000000000 0.07915025 0.0009239851 -0.14102117 -0.07335342
> [2,] 0.0791502463 1.00000000 -0.1764530631 0.10021081 0.19742285
> [3,] 0.0009239851 -0.17645306 1.0000000000 0.02968062 0.14543350
> [4,] -0.1410211698 0.10021081 0.0296806188 1.00000000 0.07234953
> [5,] -0.0733534183 0.19742285 0.1454335014 0.07234953 1.00000000
>
>
>>IND(rows.=100,col.=5)
>
> [,1] [,2] [,3] [,4] [,5]
> [1,] 1.00000000 -0.1537208 -0.023741715 -0.135245915 0.01961224
> [2,] -0.15372076 1.0000000 -0.141796984 0.157219334 0.15518443
> [3,] -0.02374171 -0.1417970 1.000000000 0.005865698 0.19118563
> [4,] -0.13524592 0.1572193 0.005865698 1.000000000 0.07345299
> [5,] 0.01961224 0.1551844 0.191185627 0.073452993 1.00000000
>
>
>>IND(rows.=10000,col.=5)
>
> [,1] [,2] [,3] [,4] [,5]
> [1,] 1.000000000 0.015928444 -0.008288940 -0.005646904 0.006936662
> [2,] 0.015928444 1.000000000 -0.005444611 0.005242395 -0.008246009
> [3,] -0.008288940 -0.005444611 1.000000000 0.007277489 0.012299247
> [4,] -0.005646904 0.005242395 0.007277489 1.000000000 0.001918704
> [5,] 0.006936662 -0.008246009 0.012299247 0.001918704 1.000000000
>
>
> ------------------------------------------------------------------------
>
> ______________________________________________
> R-help at stat.math.ethz.ch mailing list
> https://stat.ethz.ch/mailman/listinfo/r-help
> PLEASE do read the posting guide! http://www.R-project.org/posting-guide.html
--
Chuck Cleland, Ph.D.
NDRI, Inc.
71 West 23rd Street, 8th floor
New York, NY 10010
tel: (212) 845-4495 (Tu, Th)
tel: (732) 452-1424 (M, W, F)
fax: (917) 438-0894
More information about the R-help
mailing list