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 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102
|
library(sftime)
set.seed(13531)
##### checks on tc ####
## popular POSIXct
#tc <- st_tc(as.POSIXct("2020-09-01 08:00:00")-0:3*3600*24)
#tc
#tc[1]
#order(tc)
#sort(tc)[1]
#
## custom interval class
## utility functions
#as.character.interval <- function(x) {
# paste0("[", x[1], ", ", x[2], "]")
#}
#
#print.interval<- function(x) {
# cat("Interval:", as.character(x))
#}
#
#'[.intervals' <- function(x, i) {
# sx <- unclass(x)[i]
# class(sx) <- "intervals"
# sx
#}
#
## time interval definition
#i1 <- c(5.3,12)
#class(i1) <- "interval"
#i2 <- c(3.1,6)
#class(i2) <- "interval"
#i3 <- c(1.4,2.9)
#class(i3) <- "interval"
#i4 <- c(1,2)
#class(i4) <- "interval"
#
#intrvls <- list(i1, i2, i3, i4)
#class(intrvls) <- "intervals"
#
## provide dedicated generic to xtfrm for class intervals
#xtfrm.intervals <- function(is) sapply(is, xtfrm)
#
## different sort definitions:
## - sort by centre
#xtfrm.interval <- function(i) mean(i)
#
#tc <- st_tc(intrvls)
#tc
#tc[1]
#order(tc)
#sort(tc)[1]
#
## - sort by end
#xtfrm.interval <- function(i) i[2]
#tc <- st_tc(intrvls)
#tc
#tc[1]
#order(tc)
#sort(tc)[1]
#
## - sort by start
#xtfrm.interval <- function(i) i[1]
#
#tc <- st_tc(intrvls)
#tc
#tc[1]
#order(tc)
#sort(tc)[1]
#
#### sftime construction ####
library(sf)
coords <- matrix(runif(100), ncol = 2)
g = st_sfc(lapply(1:50, function(i) st_point(coords[i,]) ))
sft <- st_sftime(a = 1:50, g, time = as.POSIXct("2020-09-01 00:00:00")+0:49*3600*6)
# coercion
library(spacetime)
example(STI)
sft <- st_as_sftime(stidf)
sft
plot(sft, pch=12)
## custom interval scenario
#intrvls <- lapply(1:12, function(i) {
# iv <- runif(1)+c(0,runif(1))
# class(iv) <- "interval"
# iv
#})
#
#class(intrvls) <- "intervals"
#intrvls <- intrvls[order(intrvls)]
#
#tc_intrvls <- st_tc(intrvls)
#sft_intrvls <- sft
## sft_intrvls$time <- tc_intrvls # does not work yet because class attribute order is changed, as discussed in https://github.com/r-spatial/sf/issues/1852
#
## plot(sft_intrvls, number=4, pch=12)
|