The tsibble package provides a data class of tbl_ts
to represent tidy
temporal data. A tsibble consists of a time index, key, and other measured
variables in a data-centric format, which is built on top of the tibble.
Index
An extensive range of indices are supported by tsibble:
native time classes in R (such as
Date
,POSIXct
, anddifftime
)tsibble's new additions (such as yearweek, yearmonth, and yearquarter).
other commonly-used classes:
ordered
,hms::hms
,lubridate::period
, andnanotime::nanotime
.
For a tbl_ts
of regular interval, a choice of index representation has to
be made. For example, a monthly data should correspond to time index created
by yearmonth, instead of Date
or POSIXct
. Because months in a year
ensures the regularity, 12 months every year. However, if using Date
, a
month containing days ranges from 28 to 31 days, which results in irregular
time space. This is also applicable to year-week and year-quarter.
Tsibble supports arbitrary index classes, as long as they can be ordered from
past to future. To support a custom class, you need to define index_valid()
for the class and calculate the interval through interval_pull()
.
Key
Key variable(s) together with the index uniquely identifies each record:
Empty: an implicit variable.
NULL
resulting in a univariate time series.A single variable: For example,
data(pedestrian)
usesSensor
as the key.Multiple variables: For example, Declare
key = c(Region, State, Purpose)
fordata(tourism)
. Key can be created in conjunction with tidy selectors likestarts_with()
.
Interval
The interval function returns the interval associated with the tsibble.
Regular: the value and its time unit including "nanosecond", "microsecond", "millisecond", "second", "minute", "hour", "day", "week", "month", "quarter", "year". An unrecognisable time interval is labelled as "unit".
Irregular:
as_tsibble(regular = FALSE)
gives the irregular tsibble. It is marked with!
.Unknown: Not determined (
?
), if it's an empty tsibble, or one entry for each key variable.
An interval is obtained based on the corresponding index representation:
integerish numerics between 1582 and 2499: "year" (
Y
). Note the year of 1582 saw the beginning of the Gregorian Calendar switch.yearquarter
: "quarter" (Q
)yearmonth
: "month" (M
)yearweek
: "week" (W
)Date
: "day" (D
)difftime
: "week" (W
), "day" (D), "hour" (h
), "minute" (m
), "second" (s
)POSIXt
/hms
: "hour" (h
), "minute" (m
), "second" (s
), "millisecond" (us
), "microsecond" (ms
)period
: "year" (Y
), "month" (M
), "day" (D
), "hour" (h
), "minute" (m
), "second" (s
), "millisecond" (us
), "microsecond" (ms
)nanotime
: "nanosecond" (ns
)other numerics &
ordered
(ordered factor): "unit" When the interval cannot be obtained due to the mismatched index format, an error is issued.
The interval is invariant to subsetting, such as filter()
, slice()
, and [.tbl_ts
.
However, if the result is an empty tsibble, the interval is always unknown.
When joining a tsibble with other data sources and aggregating to different
time scales, the interval gets re-calculated.
Time zone
Time zone corresponding to index will be displayed if index is POSIXct
.
?
means that the obtained time zone is a zero-length character "".
Print options
The tsibble package fully utilises the print
method from the tibble. Please
refer to tibble::tibble-package to change display options.
Author
Maintainer: Earo Wang earo.wang@gmail.com (ORCID)
Authors:
Other contributors:
Tyler Smith [contributor]
Wil Davis william.davis@worthingtonindustries.com [contributor]
Examples
# create a tsibble w/o a key ----
tsibble(
date = as.Date("2017-01-01") + 0:9,
value = rnorm(10)
)
#> Using `date` as index variable.
#> # A tsibble: 10 x 2 [1D]
#> date value
#> <date> <dbl>
#> 1 2017-01-01 -0.0613
#> 2 2017-01-02 0.0956
#> 3 2017-01-03 -0.543
#> 4 2017-01-04 0.498
#> 5 2017-01-05 -0.0419
#> 6 2017-01-06 0.496
#> 7 2017-01-07 0.901
#> 8 2017-01-08 1.62
#> 9 2017-01-09 0.379
#> 10 2017-01-10 -0.169
# create a tsibble with one key ----
tsibble(
qtr = rep(yearquarter("2010-01") + 0:9, 3),
group = rep(c("x", "y", "z"), each = 10),
value = rnorm(30),
key = group
)
#> Using `qtr` as index variable.
#> # A tsibble: 30 x 3 [1Q]
#> # Key: group [3]
#> qtr group value
#> <qtr> <chr> <dbl>
#> 1 2010 Q1 x -0.542
#> 2 2010 Q2 x -1.45
#> 3 2010 Q3 x 0.180
#> 4 2010 Q4 x 0.498
#> 5 2011 Q1 x -1.29
#> 6 2011 Q2 x 0.755
#> 7 2011 Q3 x -0.267
#> 8 2011 Q4 x 0.642
#> 9 2012 Q1 x -0.417
#> 10 2012 Q2 x -1.22
#> # ℹ 20 more rows