https://github.com/cran/spacetime
Tip revision: 1d22771abb448e5bcdde604c8e187e6fb9426b2f authored by Edzer Pebesma on 05 November 2012, 15:05:48 UTC
version 1.0-0
version 1.0-0
Tip revision: 1d22771
stplot.R
if (!isGeneric("stplot"))
setGeneric("stplot", function(obj, ...)
standardGeneric("stplot"))
stplot.STFDF = function(obj, names.attr = as.character(index(obj@time)),
..., as.table = TRUE, at, cuts = 15, scales = list(draw = FALSE),
animate = 0, mode = "xy", scaleX = 0,
auto.key = TRUE, key.space = "right", type = 'l', do.repeat = TRUE) {
ind = sp.ID = NULL # keep R CMD check happy in R 2.13
z = names(obj@data)[1]
if (missing(at))
at = seq(min(obj[[z]], na.rm = TRUE), max(obj[[z]], na.rm = TRUE),
length.out = cuts + 1)
if (mode == "ts") { # multiple time series
if (!is.null(scales$draw) && scales$draw == FALSE)
scales$draw = TRUE
if (length(names(obj@data)) > 1) # , stack, add | which.var
xyplot(values ~ time | ind, stack(obj), groups = sp.ID,
type = type, auto.key = auto.key, as.table = as.table,
scales = scales, ...)
else
xyplot(as.formula(paste(z, "~", "time")),
as.data.frame(obj), groups = sp.ID,
type = type, auto.key = auto.key, as.table = as.table,
scales = scales, ...)
} else if (mode == "tp") { # time series in multiple panels
if (ncol(obj@data) == 1)
xyplot(as.formula(paste(z, "~ time | sp.ID")),
as.data.frame(obj), type = type, auto.key = auto.key,
key.space = key.space, as.table = as.table, ...)
else {
n = names(obj@data)
df = as.data.frame(obj)
st = stack(df, n) # values ~ ind
st$time = df$time
st$sp.ID = df$sp.ID
xyplot(as.formula(paste("values ~ time | sp.ID")),
st, type = type, groups = ind,
key.space = key.space, auto.key = auto.key,
as.table = as.table, ...)
}
} else if (mode == "xt") { # space-time cross section == Hovmoeller
if (missing(scales))
scales = list(draw=TRUE)
else
scales$draw = TRUE
s = sp:::longlat.scales(obj@sp, scales = scales, xlim = bbox(obj@sp)[1,], ylim = bbox(obj@sp)[2,])
cn = coordnames(obj@sp)
if (scaleX == 1) {
scales["x"] = s["x"]
f = as.formula(paste(z, "~", cn[1], "+ time"))
} else if (scaleX == 2) {
scales["x"] = s["y"]
f = as.formula(paste(z, "~", cn[2], "+ time"))
} else
f = as.formula(paste(z, "~ sp.ID + time"))
dots = list(...)
dots$scales = scales
dots = append(list(f, as.data.frame(obj), at = at,
cuts = cuts, as.table = as.table), dots)
do.call(levelplot, dots)
} else { # multiple spplots: panel for each time step.
form = as.formula(paste(z, "~ time"))
sp = geometry(obj@sp)
df = data.frame(unstack(as.data.frame(obj), form))
x = addAttrToGeom(sp, df, match.ID=FALSE)
## OR:
## x = as(obj, "Spatial")
## x@data = data.frame(x@data) # cripples column names
scales = sp:::longlat.scales(obj@sp, scales = scales,
xlim = bbox(obj@sp)[1,], ylim = bbox(obj@sp)[2,])
if (animate > 0) {
names.attr = rep(names.attr, length = ncol(df))
i = 0
while (do.repeat || i < ncol(df)) {
timeStep = (i %% ncol(df)) + 1
print(spplot(x[,timeStep], main = names.attr[timeStep], at = at,
cuts = cuts, as.table = as.table, auto.key = auto.key,
key.space = key.space, scales = scales, ...))
Sys.sleep(animate)
i = i + 1
}
} else
spplot(x, names.attr = names.attr, as.table = as.table, at = at,
cuts = cuts, auto.key = auto.key, key.space = key.space,
scales = scales, ...)
}
}
#stplot.STIDF = function(obj, names.attr = index(obj@time), ...)
# stplot(as(obj, "STFDF"), names.attr = names.attr, ...)
panel.stpointsplot = function(x, y, col, sp.layout, ...) {
sp:::sp.panel.layout(sp.layout, panel.number())
panel.xyplot(x, y, col = col, ...)
}
stplot.STIDF = function(obj, names.attr = NULL, ...,
as.table = TRUE, by = c("time", "burst", "id"),
scales = list(draw=FALSE), xlab = NULL, ylab = NULL,
type = 'p', number = 6, overlap = 0, asp,
col = 1, panel = panel.stpointsplot, sp.layout = NULL,
xlim = bbox(obj@sp)[1,], ylim = bbox(obj@sp)[2,]
) {
f = paste(rev(coordnames(obj@sp)), collapse=" ~ ")
by = by[1]
f = paste(f, "|", by)
if (missing(asp))
asp = mapasp(obj@sp)
scales = sp:::longlat.scales(obj@sp, scales = scales, xlim, ylim)
obj = as.data.frame(obj)
if (is.numeric(number) && number > 1)
obj$time = equal.count(obj$time, number = number, overlap = overlap)
xyplot(as.formula(f), obj, asp = asp, type = type,
as.table = as.table, scales = scales, xlab = xlab, ylab = ylab,
panel = panel, sp.layout = sp.layout, ...)
}
panel.sttrajplot = function(x, y, col, sp.layout, ..., GRP, lwd) {
sp:::sp.panel.layout(sp.layout, panel.number())
if (length(GRP) == 1 && length(lwd) == 1 && length(col) == 1)
llines(x, y, lwd = lwd, col = col)
else {
lwd = rep(lwd, length.out = length(x)-1)
col = rep(col, length.out = length(x)-1)
if (length(x) > 1)
for (i in 1:(length(x)-1))
if (GRP[i] == GRP[i+1])
llines(x[i:(i+1)], y[i:(i+1)], lwd = lwd[i], col = col[i])
}
}
stplot.STTDF = function(obj, names.attr = NULL, ...,
as.table = TRUE, by = c("none", "burst", "id", "time"),
scales = list(draw=FALSE), xlab = NULL, ylab = NULL,
type = 'l', number = 6, overlap = 0, asp,
col = 1, lwd = 1, panel = panel.sttrajplot, sp.layout = NULL,
xlim = bbox(obj@sp)[1,], ylim = bbox(obj@sp)[2,]
) {
if (missing(asp))
asp = mapasp(obj@sp)
scales = sp:::longlat.scales(obj@sp, scales = scales, xlim, ylim)
GRP = rep(1:length(obj@traj), times = lapply(obj@traj, length))
obj = as(obj, "STIDF")
f = paste(rev(coordnames(obj@sp)), collapse=" ~ ")
by = by[1]
if (by != "none")
f = paste(f, "|", by)
obj = as.data.frame(obj)
if (is.numeric(number) && number > 1)
obj$time = equal.count(obj$time, number = number, overlap = overlap)
xyplot(as.formula(f), obj, asp = asp, type = type,
as.table = as.table, scales = scales, xlab = xlab, ylab = ylab,
panel = panel, sp.layout = sp.layout, col = col, lwd = lwd, ...,
GRP = GRP)
}
setMethod("stplot", signature("STTDF"), stplot.STTDF)
setMethod("stplot", signature("STFDF"), stplot.STFDF)
setMethod("stplot", signature("STSDF"), stplot.STIDF)
setMethod("stplot", signature("STIDF"), stplot.STIDF)
stackST = function(x, select, ...) {
nc = ncol(x@data)
df = stack(x@data)
g = as.data.frame(geometry(x))
gf = do.call(rbind, lapply(1:nc, function(x) g))
data.frame(gf, df)
}
stack.STFDF = stackST
stack.STSDF = stackST
stack.STIDF = stackST