forked from tidyverts/fasster
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathREADME.Rmd
115 lines (85 loc) · 4.14 KB
/
README.Rmd
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
103
104
105
106
107
108
109
110
111
112
113
114
---
output:
md_document:
variant: markdown_github
---
<!-- README.md is generated from README.Rmd. Please edit that file -->
```{r, echo = FALSE, message=FALSE}
knitr::opts_chunk$set(
collapse = TRUE,
comment = "#>",
fig.path = "man/figure/"
)
library(fasster)
library(tidyverse)
library(lubridate)
library(tsibble)
library(forecast)
```
# fasster <img src="man/figure/logo.png" align="right" />
[![Travis-CI Build Status](https://travis-ci.org/mitchelloharawild/fasster.svg?branch=master)](https://travis-ci.org/mitchelloharawild/fasster)
<!-- [![CRAN_Status_Badge](http://www.r-pkg.org/badges/version/fasster)](https://cran.r-project.org/package=fasster) -->
<!-- [![Downloads](http://cranlogs.r-pkg.org/badges/fasster?color=brightgreen)](https://cran.r-project.org/package=fasster) -->
An implementation of the FASSTER (Forecasting with Additive Switching of Seasonality, Trend and Exogenous Regressors) model in R. This model is designed to capture patterns of multiple seasonality in a state space framework by using state switching. The *fasster* package prioritizes flexibility, computational speed and accuracy to provide convenient tools for modelling, predicting and understanding high frequency time-series.
## Installation
<!-- The **stable** version can be installed from CRAN: -->
<!-- ```{r, eval = FALSE} -->
<!-- install.packages("fasster") -->
<!-- ``` -->
The **development** version can be installed from GitHub using:
```{r, eval = FALSE}
# install.packages("devtools")
devtools::install_github("mitchelloharawild/fasster")
```
## Usage
### Model specification
*fasster* allows flexible model specification by allowing the user to specify the model structure with standard formula conventions.
```{r xreg}
fasster(fdeaths ~ mdeaths) %>% ggfitted
```
Commonly used state space components can be added using the following convenience functions:
* `poly(n)` to include an n-th order polynomial
* `seas(s)` to include a seasonal factor of frequency s
* `trig(s, q)` to include seasonal fourier terms of frequency s with q harmonics
* `arma(ar, ma)` to include an ARMA term (where ar and ma are vectors of coefficients)
* Exogenous regressors can be added by referring to their name
For example, to create a model with trend and monthly seasonality, you can use:
```{r component}
fit <- fasster(USAccDeaths ~ poly(1) + trig(12))
fit %>% ggfitted
```
The interface for creating a FASSTER model introduces a new formula construct, `%S%`, known as the switch operator. This allows modelling of more complex patterns such as multiple seasonality by modelling the components for each group seperately and switching between them.
```{r complex}
fit_switch <- as_tsibble(taylor) %>%
mutate(index = seq(ymd_h("2000-6-5 00"), by="30 mins", length.out=length(taylor)),
DayType = ifelse(wday(index) %in% 2:6, "Weekday", "Weekend")) %>%
fasster(taylor ~ DayType %S% (poly(1) + trig(48, 10)))
fit_switch %>%
ggfitted
```
### Decomposing
Fitted FASSTER models can be decomposed to provide a description of how the underlying states function. Decomposing a FASSTER model provides aggregates of its components such as trends and seasonalities.
These components can be plotted using the autoplot function on a fitted model:
```{r decompose}
fit %>% autoplot
```
```{r decompose-complex}
fit_switch %>% autoplot
```
The tools made available by *fasster* are designed to integrate seamlessly with the tidyverse of packages, enabling familiar data manipulation and visualisation capabilities.
### Forecasting
*fasster* conforms to the object structure from the *forecast* package, allowing common visualisation and analysis tools to be applied on FASSTER models.
```{r forecast}
library(forecast)
fit %>% accuracy
fit %>%
forecast(h=24) %>%
autoplot
```
Like other forecasting functions, if additional information is required (such as future state switching), it can be provided via the `newdata` argument.
```{r complex_fc}
fit_switch %>%
forecast(newdata = tibble(DateTime = seq(ymd_h("2000-8-28 00"), by="30 mins", length.out=48*7*2)) %>%
mutate(DayType = ifelse(wday(DateTime) %in% 2:6, "Weekday", "Weekend"))) %>%
autoplot(include = 48*7*4)
```