Learn R Programming

⚠️There's a newer version (1.1.5) of this package.Take me there.

tsibble

The tsibble package provides a data infrastructure for tidy temporal data with wrangling tools. Adapting the tidy data principles, tsibble is a data- and model-oriented object. In tsibble:

  1. Index is a variable with inherent ordering from past to present.
  2. Key is a set of variables that define observational units over time.
  3. Each observation should be uniquely identified by index and key.
  4. Each observational unit should be measured at a common interval, if regularly spaced.

Installation

You could install the stable version on CRAN:

install.packages("tsibble")

You could install the development version from Github using

# install.packages("remotes")
remotes::install_github("tidyverts/tsibble")

Get started

Coerce to a tsibble with as_tsibble()

To coerce a data frame to tsibble, we need to declare key and index. For example, in the weather data from the package nycflights13, the time_hour containing the date-times should be declared as index, and the origin as key. Other columns can be considered as measured variables.

library(dplyr)
library(tsibble)
weather <- nycflights13::weather %>% 
  select(origin, time_hour, temp, humid, precip)
weather_tsbl <- as_tsibble(weather, key = origin, index = time_hour)
weather_tsbl
#> # A tsibble: 26,115 x 5 [1h] <America/New_York>
#> # Key:       origin [3]
#>   origin time_hour            temp humid precip
#>   <chr>  <dttm>              <dbl> <dbl>  <dbl>
#> 1 EWR    2013-01-01 01:00:00  39.0  59.4      0
#> 2 EWR    2013-01-01 02:00:00  39.0  61.6      0
#> 3 EWR    2013-01-01 03:00:00  39.0  64.4      0
#> 4 EWR    2013-01-01 04:00:00  39.9  62.2      0
#> 5 EWR    2013-01-01 05:00:00  39.0  64.4      0
#> # … with 2.611e+04 more rows

The key can be comprised of empty, one, or more variables. See package?tsibble and vignette("intro-tsibble") for details.

The interval is computed from index based on the representation, ranging from year to nanosecond, from numerics to ordered factors. The table below shows how tsibble interprets the common time formats.

IntervalClass
Annualinteger/double
Quarterlyyearquarter
Monthlyyearmonth
Weeklyyearweek
DailyDate/difftime
SubdailyPOSIXt/difftime/hms

fill_gaps() to turn implicit missing values into explicit missing values

Often there are implicit missing cases in time series. If the observations are made at regular time interval, we could turn these implicit missingness to be explicit simply using fill_gaps(), filling gaps in precipitation (precip) with 0 in the meanwhile. It is quite common to replaces NAs with its previous observation for each origin in time series analysis, which is easily done using fill() from tidyr.

full_weather <- weather_tsbl %>%
  fill_gaps(precip = 0) %>% 
  group_by_key() %>% 
  tidyr::fill(temp, humid, .direction = "down")
full_weather
#> # A tsibble: 26,190 x 5 [1h] <America/New_York>
#> # Key:       origin [3]
#> # Groups:    origin [3]
#>   origin time_hour            temp humid precip
#>   <chr>  <dttm>              <dbl> <dbl>  <dbl>
#> 1 EWR    2013-01-01 01:00:00  39.0  59.4      0
#> 2 EWR    2013-01-01 02:00:00  39.0  61.6      0
#> 3 EWR    2013-01-01 03:00:00  39.0  64.4      0
#> 4 EWR    2013-01-01 04:00:00  39.9  62.2      0
#> 5 EWR    2013-01-01 05:00:00  39.0  64.4      0
#> # … with 2.618e+04 more rows

fill_gaps() also handles filling in time gaps by values or functions, and respects time zones for date-times. Wanna a quick overview of implicit missing values? Check out vignette("implicit-na").

index_by() + summarise() to aggregate over calendar periods

index_by() is the counterpart of group_by() in temporal context, but it groups the index only. In conjunction with index_by(), summarise() and its scoped variants aggregate interested variables over calendar periods. index_by() goes hand in hand with the index functions including as.Date(), yearweek(), yearmonth(), and yearquarter(), as well as other friends from lubridate. For example, it would be of interest in computing average temperature and total precipitation per month, by applying yearmonth() to the index variable (referred to as .).

full_weather %>%
  group_by_key() %>%
  index_by(year_month = ~ yearmonth(.)) %>% # monthly aggregates
  summarise(
    avg_temp = mean(temp, na.rm = TRUE),
    ttl_precip = sum(precip, na.rm = TRUE)
  )
#> # A tsibble: 36 x 4 [1M]
#> # Key:       origin [3]
#>   origin year_month avg_temp ttl_precip
#>   <chr>       <mth>    <dbl>      <dbl>
#> 1 EWR      2013 Jan     35.6       3.53
#> 2 EWR      2013 Feb     34.2       3.83
#> 3 EWR      2013 Mar     40.1       3   
#> 4 EWR      2013 Apr     53.0       1.47
#> 5 EWR      2013 May     63.3       5.44
#> # … with 31 more rows

While collapsing rows (like summarise()), group_by() and index_by() will take care of updating the key and index respectively. This index_by() + summarise() combo can help with regularising a tsibble of irregular time space too.

Rolling with functional programming: slide(), tile(), stretch()

Temporal data often involves moving window calculations. Several functions in tsibble allow for different variations of moving windows using purrr-like syntax:

  • slide()/slide2()/pslide(): sliding window with overlapping observations.
  • tile()/tile2()/ptile(): tiling window without overlapping observations.
  • stretch()/stretch2()/pstretch(): fixing an initial window and expanding to include more observations.

For example, a moving average of window size 3 is carried out on hourly temperatures for each group (origin).

full_weather %>% 
  group_by_key() %>% 
  mutate(temp_ma = slide_dbl(temp, ~ mean(., na.rm = TRUE), .size = 3))
#> # A tsibble: 26,190 x 6 [1h] <America/New_York>
#> # Key:       origin [3]
#> # Groups:    origin [3]
#>   origin time_hour            temp humid precip temp_ma
#>   <chr>  <dttm>              <dbl> <dbl>  <dbl>   <dbl>
#> 1 EWR    2013-01-01 01:00:00  39.0  59.4      0    NA  
#> 2 EWR    2013-01-01 02:00:00  39.0  61.6      0    NA  
#> 3 EWR    2013-01-01 03:00:00  39.0  64.4      0    39.0
#> 4 EWR    2013-01-01 04:00:00  39.9  62.2      0    39.3
#> 5 EWR    2013-01-01 05:00:00  39.0  64.4      0    39.3
#> # … with 2.618e+04 more rows

Looking for rolling in parallel? Their multiprocessing equivalents are prefixed with future_. More examples can be found at vignette("window").


Please note that this project is released with a Contributor Code of Conduct. By participating in this project you agree to abide by its terms.

Copy Link

Version

Install

install.packages('tsibble')

Monthly Downloads

32,840

Version

0.8.6

License

GPL-3

Maintainer

Last Published

January 31st, 2020

Functions in tsibble (0.8.6)

is_duplicated

Test duplicated observations determined by key and index variables
as.tsibble

Deprecated functions
as.ts.tbl_ts

Coerce a tsibble to a time series
build_tsibble

Low-level constructor for a tsibble object
difference

Lagged differences
build_tsibble_meta

Low-level & high-performance constructor for a tsibble object
as_tsibble

Coerce to a tsibble object
as_tibble.tbl_ts

Coerce to a tibble or data frame
count_gaps

Count implicit gaps
fill_gaps

Turn implicit missing values into explicit missing values
guess_frequency

Guess a time frequency from other index objects
group_by_key

Group by key variables
future_stretch()

Stretching window in parallel
has_gaps

Does a tsibble have implicit gaps in time?
holiday_aus

Australian national and state-based public holiday
index_by

Group by time index and collapse with summarise()
index

Return index variable from a tsibble
new_tsibble

Create a subclass of a tsibble
measures

Return measured variables
new_interval

Create a time interval
new_data

New tsibble data and append new observations to a tsibble
index_valid

Add custom index support for a tsibble
future_slide()

Sliding window in parallel
filter_index

A shorthand for filtering time index for a tsibble
interval_pull

Pull time interval from a vector
is_tsibble

If the object is a tsibble
key_data

Keyed data
future_tile()

Tiling window in parallel
key

Return key variables
slide

Sliding window calculation
interval

Meta-information of a tsibble
slide_tsibble

Perform sliding windows on a tsibble by row
slider

Splits the input to a list according to the rolling window size.
scan_gaps

Scan a tsibble for implicit missing observations
slide2

Sliding window calculation over multiple inputs simultaneously
pedestrian

Pedestrian counts in the city of Melbourne
partial_slider

Partially splits the input to a list according to the rolling window size.
yearweek

Represent year-week (ISO) starting on Monday, year-month or year-quarter objects
key_drop_default

Default value for .drop argument for key
reexports

Objects exported from other packages
stretch_tsibble

Perform stretching windows on a tsibble by row
tile

Tiling window calculation
units_since

Time units since Unix Epoch
stretch2

Stretching window calculation over multiple simultaneously
unnest_tsibble

Unnest a data frame consisting of tsibbles to a tsibble
stretcher

Split the input to a list according to the stretching window size.
tiler

Splits the input to a list according to the tiling window size.
tsibble-tidyverse

Tidyverse methods for tsibble
tile_tsibble

Perform tiling windows on a tsibble by row
tourism

Australian domestic overnight trips
stretch

Stretching window calculation
time_in

If time falls in the ranges using compact expressions
tsibble-package

tsibble: tidy temporal data frames and tools
tsibble

Create a tsibble object
time_unit

Extract time unit from a vector
update_tsibble

Update key and index for a tsibble
tile2

Tiling window calculation over multiple inputs simultaneously