Aggregare e combinare dati intraday

Importare e gestire dati finanziari in R

Joshua Ulrich

Quantitative Analyst & quantmod Co-Author and Maintainer

Fusi orari!

1 Fonte: https://www.shutterstock.com/video/search/time-zone-clocks
Importare e gestire dati finanziari in R

Fusi orari!

  • Internamente, l'indice xts è secondi dal mezzanotte 1970-01-01 in UTC
  • merge() usa l'indice interno
  • Il risultato di merge() avrà il fuso orario del primo oggetto
Importare e gestire dati finanziari in R

Fusi orari!

datetime <- as.POSIXct("2017-01-18 10:00:00", tz = "UTC")
london <- xts(1, datetime, tzone = "Europe/London")
tokyo <- xts(1, datetime, tzone = "Asia/Tokyo")
merge(london, tokyo)
                    london tokyo
2017-01-18 10:00:00      1     1
merge(tokyo, london)
                    tokyo london
2017-01-18 19:00:00     1      1
Importare e gestire dati finanziari in R

Creare dati intraday regolari

head(dc_trades)
                    Price
2016-01-16 08:00:58 20.85
2016-01-16 08:01:56 20.85
2016-01-16 08:03:35 20.85
2016-01-16 08:07:44 20.84
2016-01-16 08:45:58 20.85
2016-01-16 08:46:49 20.85
Importare e gestire dati finanziari in R

Creare dati intraday regolari

datetimes <- seq(from = as.POSIXct("2016-01-16 08:00"),
                  to = as.POSIXct("2016-01-17 18:00"),
                  by = "1 min")
regular_xts <- xts(, order.by = datetimes)
merged_xts <- merge(dc_trades, regular_xts)
head(merged_xts)
                    Price
2016-01-16 08:00:00    NA
2016-01-16 08:00:58 20.85
2016-01-16 08:01:00    NA
2016-01-16 08:01:56 20.85
2016-01-16 08:02:00    NA
2016-01-16 08:03:00    NA
Importare e gestire dati finanziari in R

Sottinsieme alle ore di negoziazione

# Tutte le osservazioni devono essere NA
all(is.na(merged_xts["2016-01-16 19:00/2016-01-17 07:00"]))
TRUE
# Sottoinsiemi per ora del giorno in xts
merged_trade_day <- merged_xts["T08:00/T18:00"]
# Ora non ci sono osservazioni
nrow(merged_trade_day["2016-01-16 19:00/2016-01-17 07:00"])
0
Importare e gestire dati finanziari in R

Riempi i valori mancanti per giorno di trading

# split() dei dati in blocchi non sovrapposti
trade_day_list <- split(merged_trade_day, "days")
# lapply() di una funzione a ogni blocco (elemento della lista)
filled_trade_day_list <- lapply(trade_day_list, na.locf)
# Combina i blocchi con do.call() e rbind()
filled_trade_day <- do.call(rbind, filled_trade_day_list)
Importare e gestire dati finanziari in R

Aggrega dati intraday irregolari

  • Aggrega dati intraday densi con to.period()
    • period: nuova periodicità (es. secondi, ore, giorni, ecc.)
    • k: numero di periodi per nuova osservazione
Importare e gestire dati finanziari in R

Aggrega dati intraday irregolari (1)

head(dc_price)
                    DC.Price
2016-01-16 00:00:07 20.84224
2016-01-16 00:00:08 20.84225
2016-01-16 00:00:08 20.84225
2016-01-16 00:00:11 20.84225
2016-01-16 00:00:25 20.84224
2016-01-16 00:00:44 20.84224
Importare e gestire dati finanziari in R
xts_5min <- to.period(dc_price, period = "minutes", k = 5)
head(xts_5min, n = 4)
                    dc_price.Open  dc_price.High  dc_price.Low  dc_price.Close
2016-01-16 00:03:49      20.84224       20.84227      20.84140        20.84160
2016-01-16 00:09:50      20.84160       20.84160      20.84156        20.84156
2016-01-16 00:14:57      20.84156       20.84156      20.84154        20.84154
2016-01-16 00:19:23      20.84154       20.84154      20.83206        20.83211
xts_aligned <- align.time(xts_5min, n = 60 * 5)
head(xts_aligned, n = 4)
                    dc_price.Open  dc_price.High  dc_price.Low  dc_price.Close
2016-01-16 00:05:00      20.84224       20.84227      20.84140        20.84160
2016-01-16 00:05:00      20.84160       20.84160      20.84156        20.84156
2016-01-16 00:15:00      20.84156       20.84156      20.84154        20.84154
2016-01-16 00:20:00      20.84154       20.84154      20.83206        20.83211
Importare e gestire dati finanziari in R

Ayo berlatih!

Importare e gestire dati finanziari in R

Preparing Video For Download...