Examples
Examples.Rmd
library(fChange)
#>
#> Attaching package: 'fChange'
#> The following objects are masked from 'package:stats':
#>
#> acf, pacf, qqplot, sd, var
Electricity
This section examines the hourly Spanish electricity spot price from
2014. This data is loaded into ${\tt
fChange}$, and can be retrieved by calling
electricity
. The goal is to detect any changes in the
data.
This data may be viewed using the following:
plot(electricity,
val_axis_title = '',res_axis_title = '',FD_axis_title = '',
plot_title = '')
This data seems to exhibit some trends over time (perhaps due to season). We wish to model these trends first, and then search the data for any remaining changes. We will use principal component analysis to convert it to finite dimensions, fit a model, and return this to functional data. In , and are pre-built functions that can be used to project the data, e.g.
epca <- pca_examination(X = electricity,TVE = 0.99)
set.seed(654321)
res1 <- fchange(X = epca$residuals,
statistic='Tn',
critical = 'simulation',method = 'characteristic',
type = 'segmentation')
The previous approach is similar to the next, except without smoothing incorporated. In the next, we show the details more precisely. We use binary segmentation to investigate the residuals in this case.
set.seed(123456)
elec_mod <- projection_model(electricity,TVE=0.95,model='ets', check.cp=TRUE)
plot(elec_mod$errors,changes = elec_mod$changes)
S&P 500
This section is focused on an application in finance, specifically the S&P500 index. includes this data as , which is pre-loaded. The aim is to detect changes in the stock prices.
The data is collected at minutely resolution. We convert it into the overnight cumulative intraday returns below, and plot it.
compute_ocidr <- function(dat){
dat_cidr <- dat
dat_cidr[,1] <- 100*(log(dat[,1]) - log(dat[1,1]))
# Obs
for(j in 2:ncol(dat_cidr)){
dat_cidr[,j] <- 100 *
( log(dat[,j]) - log(dat[nrow(dat_cidr),j-1]) )
}
dat_cidr
}
SPYUS_ocidr <- compute_ocidr(SPYUS500)
plot_ocidr <- plot(dfts(SPYUS_ocidr),
val_axis_title = '',res_axis_title = '',FD_axis_title = '',
plot_title = '')
The changes can be detected using binary segmentation as follows.
set.seed(25641)
spy_min_changes <- fchange(dfts(SPYUS_ocidr), type='segmentation',
statistic='Tn',
critical='simulation',
method = 'characteristic')
plot_ocidr <- plot(dfts(SPYUS_ocidr),changes = spy_min_changes[[1]],
val_axis_title = '',res_axis_title = '',FD_axis_title = '',
plot_title = '',type = 'fast')