我想在R中使用mgcv
包来运行模型
df <- as.data.frame(spdf)
mod <- gam(y ~ s(geoid, bs = 'mrf', xt = list(nb = nb), k = 20) +
s(month, bs = 'cc', k = 12),
data = df,
method = 'REML',
family = Gamma(link = log))
其中spdf是SpatialPolygonDataFrame。
我在理解如何创建nb
对象时遇到了问题,因为数据df
具有重复的geoid
值(每个月一个)和运行时
nb <- poly2nb(spdf, row.names = spdf@data@geoid)
我得到了错误
Error in poly2nb(spdf, row.names = spdf@data@geoid): non-unique row.names given
谢谢
答案 0 :(得分:1)
邻居对象不需要与数据一样多的行,而与geoid
一样多。
如果要从数据中使用geoid
,则需要首先对对象进行子集化,以包含非重复的geoid
值。在[
的{{1}}元素上使用典型的子集方法(duplicated()
)和@data
可以为您提供一组独特的SpatialPolygonsDataFrame
来构建邻域对象。