demo/stkrige-prediction.R

###########################################################
# note that demo(stkrige) needs to be run before this one #
###########################################################

# libraries
library(sp)
library(spacetime)
library(gstat)
library(rgdal)

animate <- FALSE

# interpolation
# build a grid over Germany
gridDE <- SpatialGrid(GridTopology(DE_RB_2005@sp@bbox[,1]%/%10000*10000, c(10000,10000),
                                   cells.dim=ceiling(apply(DE_RB_2005@sp@bbox,1,diff)/10000)))
proj4string(gridDE) <- CRS("+init=epsg:32632")
fullgrid(gridDE) <- F

ind <- over(gridDE, as(DE_NUTS1,"SpatialPolygons"))
gridDE <- gridDE[!is.na(ind)]

# back scale vgms:
fitSepModel$space$range <- fitSepModel$space$range*1000

fitProdSumModel$space$range <- fitProdSumModel$space$range*1000

fitMetricModel$joint$range <- fitMetricModel$joint$range*1000
fitMetricModel$stAni <- fitMetricModel$stAni*1000

fitSimpleSumMetricModel$space$range <- fitSimpleSumMetricModel$space$range*1000
fitSimpleSumMetricModel$joint$range <- fitSimpleSumMetricModel$joint$range*1000
fitSimpleSumMetricModel$stAni <- fitSimpleSumMetricModel$stAni*1000

fitSumMetricModel$space$range <- fitSumMetricModel$space$range*1000
fitSumMetricModel$joint$range <- fitSumMetricModel$joint$range*1000
fitSumMetricModel$stAni <- fitSumMetricModel$stAni*1000

if(animate) {
  DE_pred <- STF(gridDE, DE_RB_2005@time)
  
  predMat <- matrix(NA,0,2)
  for (rd in 15:180) { # rd <- 15
    predMat <- rbind(predMat,
                     krigeST(PM10~1, data=DE_RB_2005[,rd+(-5:5)], # start: 12:24
                         newdata=DE_pred[,rd,drop=F], computeVar=T,
                         fitSumMetricModel, # nmax=50,
                         stAni=linStAni*1000/24/3600)@data)
  }
  
  DE_pred_winter <- DE_pred[,15:180]
  DE_pred_winter <- addAttrToGeom(DE_pred_winter, predMat)
  
  for(i in 1:length(DE_pred_winter@time)) { # i <- 1
    pnt <- spplot(DE_pred_winter[,i], "var1.pred", col.regions=bpy.colors(160)[-(1:9)], scales=list(draw=F),
                  at=c(-5,0:150),
                  sp.layout = list(list("sp.polygons", DE_NUTS1, first=FALSE, col=gray(0.5)),
                                   list("sp.points", DE_RB_2005[,i+14], col=gray(0.25), pch=3, cex=.5)),
                  main=as.character(index(DE_pred_winter[,i,drop=F]@time)))
  
    png(file=paste("vignettes/figures/animate/pred",i,".png", sep=""), width=6, height=6, "in", res=150)
    print(pnt)
    dev.off()
  }
}

DE_pred <- STF(gridDE, DE_RB_2005@time[smplDays])
tIDS <- unique(pmax(1,pmin(as.numeric(outer(-5:5, smplDays, "+")), 365)))

sepPred <- krigeST(PM10~1, data=DE_RB_2005[,tIDS], 
                   newdata=DE_pred, fitSepModel, nmax=50,
                   stAni=fitMetricModel$stAni/24/3600)
psPred <- krigeST(PM10~1, data=DE_RB_2005[,tIDS], 
                  newdata=DE_pred, fitProdSumModel, nmax=50,
                  stAni=fitMetricModel$stAni/24/3600)
metPred <- krigeST(PM10~1, data=DE_RB_2005[,tIDS], 
                   newdata=DE_pred, fitMetricModel, nmax=50,
                   stAni=fitMetricModel$stAni/24/3600)
sumPred <- krigeST(PM10~1, data=DE_RB_2005[,tIDS], 
                   newdata=DE_pred, fitSumMetricModel, nmax=50,
                   stAni=fitMetricModel$stAni/24/3600)
smplSumPred <- krigeST(PM10~1, data=DE_RB_2005[,tIDS], # start: 12:24
                       newdata=DE_pred,  fitSimpleSumMetricModel, nmax=50,
                       stAni=fitMetricModel$stAni/24/3600)

# pure spatial prediction
pureSpPred <- matrix(NA, nrow=length(gridDE), length(smplDays))
col <- 1
for(i in smplDays) { # i <- 1
  pureSpPred[,col] <- krige(PM10~1, as(DE_RB_2005, "STSDF")[,i],
                            gridDE, model=spVgmMod, nmax=50)$var1.pred
  col <- col+1
}

pureSpPred <- STFDF(gridDE, DE_RB_2005@time[smplDays], data.frame(var1.pred = as.numeric(pureSpPred)))

DE_RB_2005 <- as(DE_RB_2005, "STFDF")

if(paper) {
  stpl <- stplot(smplSumPred, col.regions=bpy.colors(120)[-(1:20)], scales=list(draw=F),
                 main=NULL, at=0:70, # "spatio-temporal sum-metric model"
                 sp.layout = list(list("sp.polygons", DE_NUTS1, first=FALSE, col=gray(0.5)),
                                  list("sp.points", DE_RB_2005@sp, col=gray(0.25), pch=3, cex=.5)))
  
  png(file="vignettes/figures/pred_daily_means_PM10.png", width=9, height=6, "in", res=150)
  print(stpl)
  dev.off()
} else {
  stplot(pureSpPred, col.regions=bpy.colors, scales=list(draw=F),
         main="pure spatial daily prediction")
  stplot(sepPred, col.regions=bpy.colors(), scales=list(draw=F),
         main="spatio-temporal separable model")
  stplot(psPred, col.regions=bpy.colors, scales=list(draw=F),
         main="spatio-temporal product-sum model")
  stplot(metPred, col.regions=bpy.colors, scales=list(draw=F),
         main="spatio-temporal metric model")
  stplot(sumPred, col.regions=bpy.colors, scales=list(draw=F),
         main="spatio-temporal sum-metric model")
  stplot(smplSumPred, col.regions=bpy.colors, scales=list(draw=F),
         main="spatio-temporal simple sum-metric  model")
}
edzer/gstat documentation built on March 27, 2024, 12:26 p.m.