1.2 Correlated predictors
We can also simulate correlations between these predictors, as vcov
specifies the variance/covariance matrix of the predictors.
<- simulate_population(
squid_data n=2000,
response_name = "body_mass",
parameters=list(
intercept=10,
observation=list(
names=c("temperature","rainfall", "wind"),
mean = c(10,1 ,20),
vcov =matrix(c(
1, 0, 1,
0,0.1,0,
1, 0, 2
nrow=3 ,ncol=3,byrow=TRUE),
), beta =c(0.5,-3,0.4)
),residual=list(
vcov=1
)
)
)
<- get_population_data(squid_data)
data
library(scales)
par(mfrow=c(1,3))
plot(body_mass ~ temperature + rainfall + wind, data, pch=19, cex=0.5, col=alpha(1,0.5))
coef(lm(body_mass ~ temperature + rainfall + wind, data))
## (Intercept) temperature rainfall wind
## 10.1035658 0.4516304 -3.0698659 0.4221429
Matrices in R
To code a matrix in R we use the matrix
function (see ?matrix
). This takes a vector of values, and arranges then in a matrix, with dimensions specified with nrow
and ncol
. By default it fills the matrix by column, which can be changed to per row, by specifying byrow=TRUE
. For big matrices this can be petty annoying. TheTri2M()
function from the package MCMCglmm
allows you to just give the lower or upper half of the matrix, and it will fill the rest out for you. For example, we can make a correlation matrix using:
Tri2M(c(1,0.5,1,0.3,0.2,1), lower.tri = FALSE, diag=TRUE)
## [,1] [,2] [,3]
## [1,] 1.0 0.5 0.3
## [2,] 0.5 1.0 0.2
## [3,] 0.3 0.2 1.0
Instead of specifying a variance-covariance matrix (vcov
), we can also specify a variance-correlation matrix (variance on the diagonals and correlations on the off-diagonals), using vcorr
<- simulate_population(
squid_data n=2000,
response_name = "body_mass",
parameters=list(
intercept=10,
observation=list(
names=c("temperature","rainfall", "wind"),
mean = c(10,1,20),
vcorr =matrix(c(
1, -0.2, 0.5,
-0.2, 0.1, 0.3,
0.5, 0.3, 2
nrow=3 ,ncol=3,byrow=TRUE),
), beta =c(0.5,-3,0.4)
),residual=list(
vcov=1
)
)
)
<- get_population_data(squid_data)
data
cor(data[,c("temperature","rainfall", "wind")])
## temperature rainfall wind
## temperature 1.0000000 -0.2118314 0.5082047
## rainfall -0.2118314 1.0000000 0.2690873
## wind 0.5082047 0.2690873 1.0000000
Through simulating correlated predictors, we can also simulate more interesting phenomena. For example, we may want to simulate the effect of a correlated missing predictor. Here, rain and wind, but not temperature, affect adult body mass, but only temperature and rainfall are measured:
<- simulate_population(
squid_data n=2000,
response_name = "body_mass",
parameters=list(
intercept=10,
observation=list(
names=c("temperature","rainfall", "wind"),
mean = c(10,1 ,20),
vcov =matrix(c(
1, 0, 1,
0,0.1,0,
1, 0, 2
nrow=3 ,ncol=3,byrow=TRUE),
), beta =c(0.5,-3,0.4)
),residual=list(
vcov=1
)
)
)
<- get_population_data(squid_data)
data
library(scales)
par(mfrow=c(1,3))
plot(body_mass ~ temperature + rainfall + wind, data, pch=19, cex=0.5, col=alpha(1,0.5))
coef(lm(body_mass ~ temperature + rainfall, data))
## (Intercept) temperature rainfall
## 13.944305 0.913508 -3.088825
coef(lm(body_mass ~ temperature + rainfall + wind, data))
## (Intercept) temperature rainfall wind
## 9.7004101 0.4747701 -3.0718309 0.4308823
We can also use this to induce measurement error in a predictor - we can simulate the true variable with a certain effect on the response, and another correlated variable - the measured variable - with no direct effect on the response. The correlation between these two variables represents the measurement error (the repeatability of the variable is the correlation squared).