This vignette1 explains how to prepare or simulate data in {fHMM} for estimation.
library(fHMM)
Empirical data must be provided as a comma-separated values (CSV) file and its path must be specified in set_controls()
, see the vignette on specifying the controls for details.2 The {fHMM} package comes with two datasets of the Deutscher Aktienindex and the VW stock for demonstration purpose that can be accessed as follows:
system.file("extdata", "dax.csv", package = "fHMM")
#> [1] "C:/Users/loelschlaeger/AppData/Local/Temp/RtmpiSMuNu/Rinst4d81c6a7447/fHMM/extdata/dax.csv"
system.file("extdata", "vw.csv", package = "fHMM")
#> [1] "C:/Users/loelschlaeger/AppData/Local/Temp/RtmpiSMuNu/Rinst4d81c6a7447/fHMM/extdata/vw.csv"
The prepare_data()
function prepares the data based on the data
controls specifications and returns an fHMM_data
object that can be passed to the fit_model()
function for model fitting.
<- list(
controls states = 3,
sdds = "t",
data = list(file = system.file("extdata", "dax.csv", package = "fHMM"),
date_column = "Date",
data_column = "Close",
logreturns = TRUE)
)<- set_controls(controls)
controls <- prepare_data(controls)
data summary(data)
#> Summary of fHMM empirical data
#> * number of observations: 8778
#> * data source: dax.csv
#> * date column: Date
#> * log returns: TRUE
Daily stock prices listed on https://finance.yahoo.com can be downloaded directly via
download_data(symbol, from, to, file)
where
symbol
is the stock’s symbol that has to match the official symbol on https://finance.yahoo.com,3
from
and to
define the time interval (in format "YYYY-MM-DD"
),
file
is the name of the file where the .csv-file is saved. Per default, it is saved in the current working directory under the name <symbol>.csv
.
For example, the call
download_data(symbol = "^GDAXI", from = "2000-01-01", to = Sys.Date())
#> Download successful.
#> * symbol: ^GDAXI
#> * from: 2000-01-03
#> * to: 2022-07-07
#> * path: C:\Users\loelschlaeger\AppData\Local\Temp\RtmpiSMuNu\Rbuild4d85fe434fa\fHMM\vignettes\^GDAXI.csv
downloads the 21st century daily data of the DAX into the current working directory.
Historical events can be highlighted by specifying a named list events
with elements dates
(a vector of dates) and labels
(a vector of labels for the events) and passing it to the plot method, for example:
<- fHMM:::fHMM_events(
events list(
dates = c("2001-09-11","2008-09-15","2020-01-27"),
labels = c("9/11 terrorist attack","Bankruptcy of Lehman Brothers","First COVID-19 case in Germany")
)
)print(events)
#> dates labels
#> 1 2001-09-11 9/11 terrorist attack
#> 2 2008-09-15 Bankruptcy of Lehman Brothers
#> 3 2020-01-27 First COVID-19 case in Germany
plot(data, events = events)
If the data
parameter in the model’s controls
is unspecified, the model is fitted to simulated data from the model specification. This can be useful for testing the functionality or conducting simulation experiments. True model parameters can be specified by defining an fHMM_parameters
-object via the fHMM_parameters()
function and passing it to prepare_data()
.
This vignette was build using R 4.1.0 with the {fHMM} 1.0.3 package.↩︎
The download_data()
function explained below provides a convenient tool for downloading stock data from https://finance.yahoo.com/ in csv-format.↩︎
For example, "^GDAXI"
is the symbol of the DAX and "^GSPC"
the one of the S&P 500.↩︎