glmmTMB with autocorrelation of irregular times

假如想象 提交于 2021-02-10 23:59:13

问题


I'm putting together a glmmTMB model. I have data collected at a single site over the course of May, every year, for 4 years. Time resolution within year can range from a few minutes (or even same minute) to days apart. The covariance vignette says that the ar1() structure requires a regular time series, but the ou(times + 0 | group) structure can handle irregular times. That said - it looks like the times argument is a factor - how does that work with irregular time structure??

So, for example, is this a correct use of the ou() structure?

df <- structure(list(DayYear = c(234, 220, 234, 231, 243, 229, 228, 
223, 220, 218, 234, 237, 234, 231, 241, 237, 241, 241, 233, 234, 
234, 232, 218, 227, 232, 229, 220, 223, 228, 224), DateTime =     structure(c(1495477980, 
1399590540, 1495479780, 1495225920, 1464631980, 1495052760, 1463324460, 
1494525780, 1494256560, 1494088440, 1495471320, 1495730940, 1495476960, 
1495225200, 1432919940, 1495725900, 1432924200, 1432918860, 1495384020, 
1495479900, 1463848140, 1495298820, 1399420080, 1463253000, 1463692920, 
1495037040, 1494275160, 1494510780, 1463348220, 1494597180), class =     c("POSIXct", 
"POSIXt"), tzone = ""), Year = c(2017, 2014, 2017, 2017, 2016, 
2017, 2016, 2017, 2017, 2017, 2017, 2017, 2017, 2017, 2015, 2017, 
2015, 2015, 2017, 2017, 2016, 2017, 2014, 2016, 2016, 2017, 2017, 
2017, 2016, 2017), N = c(2, 2, 7, 2, 6, 4, 1, 4, 1, 3, 1, 6, 
2, 2, 2, 2, 5, 5, 3, 5, 3, 2, 4, 1, 6, 2, 2, 3, 5, 2)), row.names = c(NA, 
-30L), class = c("tbl_df", "tbl", "data.frame"))

create sampling factor within year

df <- df %>%
    arrange(DateTime) %>%
    group_by(Year) %>%
    mutate(times = 1:n()) %>%
    ungroup() %>%
    mutate(YearF = as.factor(Year),
            times = numFactor(times))

mod1 <- glmmTMB(N ~ DayYear + YearF + 
            ou(times + 0 | YearF),
            family = nbinom2,
            data = df)

This particular model doesn't run too well because the toy dataset is so tiny (and probably doesn't show what I need showing) - but is that a correct specification of the autocorrelation structure under an irregular time series?


回答1:


No, it's not: you have to use decimal times/dates in numFactor. The way you've done it coerces the data set to be equally spaced. Below I use lubridate::decimal.date(DateTime) %% 1 to get the fraction-of-year variable that's used as the time coordinate.

library(dplyr)
library(lubridate)
library(glmmTMB)
df2 <- (df
    %>% arrange(DateTime)
    %>% group_by(Year)
    %>% mutate(times = lubridate::decimal_date(DateTime) %% 1)
    %>% ungroup()
)

df3 <- (df2
    %>% mutate(YearF = as.factor(Year),
               times = glmmTMB::numFactor(times))
    %>% select(N, DayYear, YearF, times)
)

mod1 <- glmmTMB(N ~ DayYear + YearF + 
            ou(times + 0 | YearF),
            family = nbinom2,
            data = df3)


来源:https://stackoverflow.com/questions/52918655/glmmtmb-with-autocorrelation-of-irregular-times

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!