[R] Error: contrasts can be applied only to factors with 2 or more levels

arun smartpink111 at yahoo.com
Thu May 16 21:21:56 CEST 2013


Hi,
The example dataset only shows 1 level for ID.
chm
  id site plot rx rxg rxl t w     l spp inid inih d09  d10  d11  d12 h09 h10
1  1  C-H 2002  1   1  Mn N N 14.55  ac  9.6 74.5 9.6 13.0 13.5 14.2  96 109
2  1  C-H 2002  1   1  Mn N N 14.55  ac  7.4 69.5 6.0  9.8   NA 10.7  72  77
3  1  C-H 2003  1   1  Mn N N 13.34  ac  6.0 66.7 5.7  8.0 11.0 10.1  75  80
4  1  C-H 2003  1   1  Mn N N 13.34  ac  7.1 75.4 7.5 13.0 11.8 12.3 101 113
5  1  C-H 2003  1   1  Mn N N 13.34  ac  7.5 57.5 6.9   NA   NA   NA  58  NA
6  1  C-H 2008  2   1  Mc N N 11.63  ac  5.7 71.5 6.0  7.7   NA  8.5  84  89
  h11 h12
1 102 110
2  76  92
3  79  91
4 115 128
5  NA  NA
6  84  86


Using another dataset:
data(warpbreaks)
warpbreaks2<- warpbreaks
warpbreaks2$id<-rep(1:6,9)
warpbreaks2$id<- factor(warpbreaks2$id)
set.seed(45)
 warpbreaks2$inih<- rnorm(54,70)
 str(warpbreaks2)
#'data.frame':    54 obs. of  5 variables:
# $ breaks : num  26 30 54 25 70 52 51 26 67 18 ...
# $ wool   : Factor w/ 2 levels "A","B": 1 1 1 1 1 1 1 1 1 1 ...
# $ tension: Factor w/ 3 levels "L","M","H": 1 1 1 1 1 1 1 1 1 2 ...
# $ id     : Factor w/ 6 levels "1","2","3","4",..: 1 2 3 4 5 6 1 2 3 4 ...
# $ inih   : num  70.3 69.3 69.6 69.3 69.1 ...
library(lme4)
lmList(breaks~wool+tension+ inih|id,data=warpbreaks2)
#Call: lmList(formula = breaks ~ wool + tension + inih | id, data = warpbreaks2) 
#Coefficients:
#  (Intercept)      woolB   tensionM   tensionH      inih
#1   -170.9470  -6.634896  -7.214566  -9.376711  2.930854
#2    247.7175   5.363119  -1.958410 -10.652740 -3.183826
#3   -304.1479 -13.483864 -28.437529 -26.656611  5.120942
#4   -641.4617  -5.273322  -9.876885 -16.222166  9.670360
#5    476.4729  -6.296008 -10.416367 -16.337461 -6.256378
#6    335.3178 -14.219225 -17.714808 -13.488733 -4.054001
#Degrees of freedom: 54 total; 24 residual
#Residual standard error: 12.52028



warpbreaks3<- warpbreaks2
 warpbreaks3$id<- as.numeric(as.character(warpbreaks3$id))
 lmList(breaks~wool+tension+ inih|id,data=warpbreaks3)
#Call: lmList(formula = breaks ~ wool + tension + inih | id, data = warpbreaks3) 
#Coefficients:
#  (Intercept)      woolB   tensionM   tensionH      inih
#1   -170.9470  -6.634896  -7.214566  -9.376711  2.930854
#2    247.7175   5.363119  -1.958410 -10.652740 -3.183826
#3   -304.1479 -13.483864 -28.437529 -26.656611  5.120942
#4   -641.4617  -5.273322  -9.876885 -16.222166  9.670360
#5    476.4729  -6.296008 -10.416367 -16.337461 -6.256378
#6    335.3178 -14.219225 -17.714808 -13.488733 -4.054001
#
#Degrees of freedom: 54 total; 24 residual
#Residual standard error: 12.52028

A.K.





----- Original Message -----
From: "Belair, Ethan D" <ebelair at purdue.edu>
To: "r-help at R-project.org" <r-help at r-project.org>
Cc: 
Sent: Thursday, May 16, 2013 11:05 AM
Subject: [R] Error: contrasts can be applied only to factors with 2 or more
 levels

I have a dataframe that I am attempting to analyze using the lmList() function in package lme4. I'm using this funciton to select which parameters in this model wqarrant random effects. I have a subset of the data below. I input data and change class of necessary items so that I have several factors and several numeric variables. I then run lmList using id as a grouping factor, which produces an error. This only occurs using id as grouping factor, other IV's work fine. R says contrasts can only be applied to factors of 2 or more levels. The entire data set contains 48 levels of id, this subset contains 3, yet the error persists.

I'm relatively new to R and this is my first question posted. I apologize if I've not followed the posting rules exactly, I'm trying to do so, but find coding quite difficult.

Thank you in advance for any help.

> library(lme4)
> chm <- dput(head(chm))
structure(list(id = structure(c(1L, 1L, 1L, 1L, 1L, 1L), .Label = c("1",
"2", "3", "4", "5", "6", "7", "8", "9", "10", "11", "12", "13",
"14", "15", "16", "17", "18", "19", "20", "21", "22", "23", "24",
"25", "26", "27", "28", "29", "30", "31", "32", "33", "34", "35",
"36", "37", "38", "39", "40", "41", "42", "43", "44", "45", "46",
"47", "48"), class = "factor"), site = structure(c(1L, 1L, 1L,
1L, 1L, 1L), .Label = c("C-H", "M"), class = "factor"), plot = structure(c(2L,
2L, 3L, 3L, 3L, 8L), .Label = c("2001", "2002", "2003", "2004",
"2005", "2006", "2007", "2008", "2009", "2010", "2011", "2012",
"2013", "2014", "2015", "2016", "2017", "2018", "2019", "2020",
"2021", "2022", "2023", "2024", "2025", "2026", "2027", "2028",
"2029", "2030", "2031", "2032", "2033", "2034", "2035", "2036",
"2037", "2038", "2039", "2040", "2041", "2042", "2043", "2044",
"2045"), class = "factor"), rx = structure(c(1L, 1L, 1L, 1L,
1L, 2L), .Label = c("1", "2", "3", "4", "5", "6"), class = "factor"),
    rxg = structure(c(1L, 1L, 1L, 1L, 1L, 1L), .Label = c("1",
    "6"), class = "factor"), rxl = structure(c(5L, 5L, 5L, 5L,
    5L, 3L), .Label = c("C", "H", "Mc", "McH", "Mn", "MnH"), class = "factor"),
    t = structure(c(1L, 1L, 1L, 1L, 1L, 1L), .Label = c("N",
    "Y"), class = "factor"), w = structure(c(1L, 1L, 1L, 1L,
    1L, 1L), .Label = c("N", "Y"), class = "factor"), l = c(14.55,
    14.55, 13.34, 13.34, 13.34, 11.63), spp = structure(c(1L,
    1L, 1L, 1L, 1L, 1L), .Label = c("ac", "rm", "ro", "sm"), class = "factor"),
    inid = c(9.6, 7.4, 6, 7.1, 7.5, 5.7), inih = c(74.5, 69.5,
    66.7, 75.4, 57.5, 71.5), d09 = c(9.6, 6, 5.7, 7.5, 6.9, 6
    ), d10 = c(13, 9.8, 8, 13, NA, 7.7), d11 = c(13.5, NA, 11,
    11.8, NA, NA), d12 = c(14.2, 10.7, 10.1, 12.3, NA, 8.5),
    h09 = c(96, 72, 75, 101, 58, 84), h10 = c(109, 77, 80, 113,
    NA, 89), h11 = c(102, 76, 79, 115, NA, 84), h12 = c(110,
    92, 91, 128, NA, 86)), .Names = c("id", "site", "plot", "rx",
"rxg", "rxl", "t", "w", "l", "spp", "inid", "inih", "d09", "d10",
"d11", "d12", "h09", "h10", "h11", "h12"), row.names = c(NA,
6L), class = "data.frame")

> chm$id = as.factor(chm$id)
> chm$spp = as.factor(chm$spp)
> chm$h12 = as.numeric(chm$h12)
> str(chm)

> ch.list <- lmList(h12~spp+t+w+l+inih|id, data=mydata)

Thanks!
Ethan

    [[alternative HTML version deleted]]

______________________________________________
R-help at r-project.org mailing list
https://stat.ethz.ch/mailman/listinfo/r-help
PLEASE do read the posting guide http://www.R-project.org/posting-guide.html
and provide commented, minimal, self-contained, reproducible code.




More information about the R-help mailing list