[R-meta] Accounting for uncertainty in a mixed-effects regression

Cesar Terrer Moreno cesar.terrer at me.com
Tue Feb 6 12:14:27 CET 2018


Dear Wolfgang, 

I seem to be close to running your suggested analysis, but I get an error in predict.rma:

### MODEL ###
summary(ECMmv <- rma(es, var, data=df.ecm, mods= ~ MAP + MAT*CO2dif + Biome))
> colnames(ECMmv$X)[-1]
[1] "MAP"                  "MAT"                  "CO2dif"              
[4] "BiomeBoreal_Forest"   "BiomeTropical_Forest" "MAT:CO2dif” 

### GLOBAL DATASET ###
ECM.matrix <- model.matrix(~ MAP + MAT*CO2dif + Biome, data=s.df.ecm)
> colnames(ECM.matrix)[-1]
[1] "MAP"                  "MAT"                  "CO2dif"              
[4] "BiomeBoreal_Forest"   "BiomeTropical_Forest" "MAT:CO2dif”

### PREDICT ###
ECMpred.mv <- predict(ECMmv, newmods = ECM.matrix[,-1])
Error in predict.rma(ECMmv, newmods = ECM.matrix[, -1]) : 
  Multiple matches for the same variable name.

As you can see, the names of the columns match in the model and newmods, so I am not really sure what this error means.

Many thanks for your help.
Best wishes,
Cesar

> On 5 Feb 2018, at 15:22, Viechtbauer Wolfgang (SP) <wolfgang.viechtbauer at maastrichtuniversity.nl> wrote:
> 
> Careful with using rma.mv(). It requires that you specify all random effects, including the one that is automatically added in RE models fitted with the rma() function. See:
> 
> http://www.metafor-project.org/doku.php/tips:rma.uni_vs_rma.mv
> 
> So right now, the model below is not a random-effects model.
> 
> Leaving this aside, if you have a dataset that includes the same predictor variables (with the same names) as the model that you fitted, then you should be able to just do this:
> 
> model.matrix(~ 1 + MAP + MAT*CO2dif + Biome, data=s.df)
> 
> to construct the matrix you need to give to 'newmods' of predict(). If the variable names differ, the safest approach is to just rename the variables in 's.df' so they match exactly the names of the predictors you used in rma.mv().
> 
> Best,
> Wolfgang
> 
>> -----Original Message-----
>> From: Cesar Terrer Moreno [mailto:cesar.terrer at me.com]
>> Sent: Monday, 05 February, 2018 13:26
>> To: Viechtbauer Wolfgang (SP)
>> Cc: r-sig-meta-analysis at r-project.org
>> Subject: Re: [R-meta] Accounting for uncertainty in a mixed-effects
>> regression
>> 
>> Hi Wolfgang,
>> 
>> Thanks for your response.
>> 
>> Yes, including “Biome” as a moderator seems like a reasonable approach to
>> force the model to predict larger SE values when the sample size in a
>> certain biome is low.
>> 
>> My model would thus be:
>> 
>> ECMmv <- rma.mv(es, var, data=ecm.df, mods= ~ 1 + MAP + MAT*CO2dif +
>> Biome)
>> 
>> Biome has six levels:
>>> levels(s.df$Biome)
>> [1] "Grassland"        "Boreal_Forest"    "Cropland"         "Shrubland"
>> [5] "Temperate_Forest" "Tropical_Forest"
>> 
>> Now I don’t know how to use the predict function using a dataset that
>> includes data for all predictors on a per pixel basis:
>> 
>>> head(s.df)
>>        x      y temperature precipitation     Biome CNr
>> 1 -179.875 89.875          NA            NA Grassland  NA
>> 2 -179.625 89.875          NA            NA Grassland  NA
>> 3 -179.375 89.875          NA            NA Grassland  NA
>> 4 -179.125 89.875          NA            NA Grassland  NA
>> 5 -178.875 89.875          NA            NA Grassland  NA
>> 6 -178.625 89.875          NA            NA Grassland  NA
>> 
>> CO2inc <- 300 # ppm
>> 
>> ECMpred.mv <- predict(ECMmv,
>>                     newmods = cbind(s.df$precipitation,
>> s.df$temperature, CO2inc, s.df$temperature*CO2inc,s.df$Biome))
>> 
>> How would you configure “predict” to predict ES and SE per row as a
>> function of Biome type?
>> Thanks a lot
>> César
>> 
>>> On 4 Feb 2018, at 13:57, Viechtbauer Wolfgang (SP)
>> <wolfgang.viechtbauer at maastrichtuniversity.nl> wrote:
>>> 
>>> Yes, I just wanted to tie up those loose ends before getting to the
>> more recent discussion.
>>> 
>>> As James indicated, you cannot predict for a level that was not
>> included in the original dataset. Also, factors are turned into a bunch
>> of dummy variables, so if you want to use predict(), you have to specify
>> the values of the dummy variables instead of including a factor/character
>> variable in 'newmods'. See:
>>> 
>>> http://www.metafor-project.org/doku.php/tips:testing_factors_lincoms
>>> 
>>> As for the actual problem:
>>> 
>>> In levels of 'Biome' with a small number of studies, the SE should tend
>> to be larger (all else equal, a larger k for a level will lead to a
>> decrease in the SE for the level). So in that sense, the model should
>> reflect the larger uncertainty in levels of 'Biome' with little
>> information.
>>> 
>>> For example:
>>> 
>>> library(metafor)
>>> dat <- get(data(dat.bcg))
>>> dat <- escalc(measure="RR", ai=tpos, bi=tneg, ci=cpos, di=cneg,
>> data=dat.bcg)
>>> res <- rma(yi, vi, mods = ~ alloc - 1, data=dat)
>>> res
>>> plot(c(table(dat$alloc)), res$se, pch=19)
>>> 
>>> So, before thinking about other methods, how does that pan out in your
>> data?
>>> 
>>> Best,
>>> Wolfgang



More information about the R-sig-meta-analysis mailing list