Title: | Detrended Fluctuation and Detrended Cross-Correlation Analysis |
---|---|
Description: | A collection of functions to perform Detrended Fluctuation Analysis (DFA) and Detrended Cross-Correlation Analysis (DCCA). This package implements the results presented in Prass, T.S. and Pumi, G. (2019). "On the behavior of the DFA and DCCA in trend-stationary processes" <arXiv:1910.10589>. |
Authors: | Taiane Schaedler Prass [aut, cre] , Guilherme Pumi [aut] |
Maintainer: | Taiane Schaedler Prass <[email protected]> |
License: | GPL (>= 3) |
Version: | 0.1.1 |
Built: | 2024-12-28 06:23:44 UTC |
Source: | CRAN |
Calculates the autocovariance of the detrended variance.
covF2dfa(m = 3, nu = 0, h = 0, overlap = TRUE, G, Cumulants = NULL)
covF2dfa(m = 3, nu = 0, h = 0, overlap = TRUE, G, Cumulants = NULL)
m |
an integer or integer valued vector indicating the size of the window for the polinomial fit. |
nu |
a non-negative integer denoting the degree of the polinomial fit applied on the integrated series. |
h |
an integer or integer valued vector indicating the lags for which the autocovariance function is to be calculated. |
overlap |
logical: if true (the default), overlapping boxes are used for calculations. Otherwise, non-overlapping boxes are applied. |
G |
the autocovariance matrix for the original time series. The dimension of |
Cumulants |
The matrix containing the joint cumulants for lags. Dimension must be |
A matrix with the autocovariance of lag , for each value of
provided. This matrix is obtained from expressions (21) for
and (22) for
in Prass and Pumi (2019).
Taiane Schaedler Prass
Prass, T.S. and Pumi, G. (2019). On the behavior of the DFA and DCCA in trend-stationary processes <arXiv:1910.10589>.
## Not run: ms = seq(3,100,1) hs = seq(0,50,1) overlap = TRUE nu = 0 m_max = (max(ms)+1)*(max(hs)+1) - max(ms)*max(hs)*as.integer(overlap) theta = c(c(1,(20:1)/10), rep(0, m_max - 20)) Gamma1 = diag(m_max+1) Gamma2 = matrix(0, ncol = m_max+1, nrow = m_max+1) Gamma12 = matrix(0, ncol = m_max+1, nrow = m_max+1) for(t in 1:(m_max+1)){ for(h in 0:(m_max+1-t)){ Gamma2[t,t+h] = sum(theta[1:(length(theta)-h)]*theta[(1+h):length(theta)]) Gamma2[t+h,t] = Gamma2[t,t+h] Gamma12[t,t+h] = theta[h+1] } } covdfa1 = covF2dfa(m = ms, nu = 0, h = hs, overlap = TRUE, G = Gamma1, Cumulants = NULL) covdfa2 = covF2dfa(m = ms, nu = 0, h = hs, overlap = TRUE, G = Gamma2, Cumulants = NULL) cr = rainbow(100) plot(ms, covdfa1[,1], type = "l", ylim = c(0,20), xlab = "m", ylab = expression(gamma[DFA](h)), col = cr[1]) for(i in 2:ncol(covdfa1)){ points(ms, covdfa1[,i], type = "l", col = cr[i]) } lattice::wireframe(covdfa1, drape = TRUE, col.regions = rev(rainbow(150))[50:150], zlab = expression(gamma[DFA]), xlab = "m", ylab = "h") ## End(Not run)
## Not run: ms = seq(3,100,1) hs = seq(0,50,1) overlap = TRUE nu = 0 m_max = (max(ms)+1)*(max(hs)+1) - max(ms)*max(hs)*as.integer(overlap) theta = c(c(1,(20:1)/10), rep(0, m_max - 20)) Gamma1 = diag(m_max+1) Gamma2 = matrix(0, ncol = m_max+1, nrow = m_max+1) Gamma12 = matrix(0, ncol = m_max+1, nrow = m_max+1) for(t in 1:(m_max+1)){ for(h in 0:(m_max+1-t)){ Gamma2[t,t+h] = sum(theta[1:(length(theta)-h)]*theta[(1+h):length(theta)]) Gamma2[t+h,t] = Gamma2[t,t+h] Gamma12[t,t+h] = theta[h+1] } } covdfa1 = covF2dfa(m = ms, nu = 0, h = hs, overlap = TRUE, G = Gamma1, Cumulants = NULL) covdfa2 = covF2dfa(m = ms, nu = 0, h = hs, overlap = TRUE, G = Gamma2, Cumulants = NULL) cr = rainbow(100) plot(ms, covdfa1[,1], type = "l", ylim = c(0,20), xlab = "m", ylab = expression(gamma[DFA](h)), col = cr[1]) for(i in 2:ncol(covdfa1)){ points(ms, covdfa1[,i], type = "l", col = cr[i]) } lattice::wireframe(covdfa1, drape = TRUE, col.regions = rev(rainbow(150))[50:150], zlab = expression(gamma[DFA]), xlab = "m", ylab = "h") ## End(Not run)
Calculates the autocovariance of the detrended cross-covariance.
covFdcca(m = 3, nu = 0, h = 0, overlap = TRUE, G1, G2, G12, Cumulants = NULL)
covFdcca(m = 3, nu = 0, h = 0, overlap = TRUE, G1, G2, G12, Cumulants = NULL)
m |
an integer or integer valued vector indicating the size of the window for the polinomial fit. |
nu |
a non-negative integer denoting the degree of the polinomial fit applied on the integrated series. |
h |
an integer or integer valued vector indicating the lags for which the autocovariance function is to be calculated. Negative values are not allowed. |
overlap |
logical: if true (the default), overlapping boxes are used for calculations. Otherwise, non-overlapping boxes are applied. |
G1 , G2
|
the autocovariance matrices for the original time series. The dimension of |
G12 |
the cross-covariance matrix for the original time series. The dimension of |
Cumulants |
The matrix of cumulants. If not provided, it is assumed that the cumulants are all zero. |
A matrix of dimension by
with the autocovariance of lag
(rows), for each value of
(columns) provided. This matrix is obtained from expressions (24) for
and (25) for
in Prass and Pumi (2019).
Taiane Schaedler Prass
Prass, T.S. and Pumi, G. (2019). On the behavior of the DFA and DCCA in trend-stationary processes <arXiv:1910.10589>.
## Not run: ms = seq(3,100,1) hs = seq(0,50,1) overlap = TRUE nu = 0 m_max = (max(ms)+1)*(max(hs)+1) - max(ms)*max(hs)*as.integer(overlap) theta = c(c(1,(20:1)/10), rep(0, m_max - 20)) Gamma1 = diag(m_max+1) Gamma2 = matrix(0, ncol = m_max+1, nrow = m_max+1) Gamma12 = matrix(0, ncol = m_max+1, nrow = m_max+1) for(t in 1:(m_max+1)){ for(h in 0:(m_max+1-t)){ Gamma2[t,t+h] = sum(theta[1:(length(theta)-h)]*theta[(1+h):length(theta)]) Gamma2[t+h,t] = Gamma2[t,t+h] Gamma12[t,t+h] = theta[h+1] } } covdcca = covFdcca(m = ms, nu = 0, h = hs, G1 = Gamma1, G2 = Gamma2, G12 = Gamma12) ## End(Not run)
## Not run: ms = seq(3,100,1) hs = seq(0,50,1) overlap = TRUE nu = 0 m_max = (max(ms)+1)*(max(hs)+1) - max(ms)*max(hs)*as.integer(overlap) theta = c(c(1,(20:1)/10), rep(0, m_max - 20)) Gamma1 = diag(m_max+1) Gamma2 = matrix(0, ncol = m_max+1, nrow = m_max+1) Gamma12 = matrix(0, ncol = m_max+1, nrow = m_max+1) for(t in 1:(m_max+1)){ for(h in 0:(m_max+1-t)){ Gamma2[t,t+h] = sum(theta[1:(length(theta)-h)]*theta[(1+h):length(theta)]) Gamma2[t+h,t] = Gamma2[t,t+h] Gamma12[t,t+h] = theta[h+1] } } covdcca = covFdcca(m = ms, nu = 0, h = hs, G1 = Gamma1, G2 = Gamma2, G12 = Gamma12) ## End(Not run)
Calculates the expected value of the detrended variance.
EF2dfa(m = 3, nu = 0, G, K = NULL)
EF2dfa(m = 3, nu = 0, G, K = NULL)
m |
an integer or integer valued vector indicating the size of the window for the polinomial fit. |
nu |
a non-negative integer denoting the degree of the polinomial fit applied on the integrated series. |
G |
the autocovariance matrix for the original time series. The dimension of |
K |
optional: the matrix |
A vector of size containing the expected values of the detrended variance corresponding to the values of
provided. This is expression (20) in Prass and Pumi (2019).
Taiane Schaedler Prass
Prass, T.S. and Pumi, G. (2019). On the behavior of the DFA and DCCA in trend-stationary processes <arXiv:1910.10589>.
m = 3 K = Km(m = m, nu = 0) G = diag(m+1) EF2dfa(G = G, K = K) # same as EF2dfa(m = 3, nu = 0, G = G) # An AR(1) example phi = 0.4 n = 500 burn.in = 50 eps = rnorm(n + burn.in) z.temp = numeric(n + burn.in) z.temp[1] = eps[1] for(i in 2:(n + burn.in)){ z.temp[i] = phi*z.temp[i-1] + eps[i] } z = z.temp[(burn.in + 1):(n + burn.in)] F2.dfa = F2dfa(z, m = 3:100, nu = 0, overlap = TRUE) plot(3:100, F2.dfa, type="o", xlab = "m")
m = 3 K = Km(m = m, nu = 0) G = diag(m+1) EF2dfa(G = G, K = K) # same as EF2dfa(m = 3, nu = 0, G = G) # An AR(1) example phi = 0.4 n = 500 burn.in = 50 eps = rnorm(n + burn.in) z.temp = numeric(n + burn.in) z.temp[1] = eps[1] for(i in 2:(n + burn.in)){ z.temp[i] = phi*z.temp[i-1] + eps[i] } z = z.temp[(burn.in + 1):(n + burn.in)] F2.dfa = F2dfa(z, m = 3:100, nu = 0, overlap = TRUE) plot(3:100, F2.dfa, type="o", xlab = "m")
Calculates the expected value of the detrended cross-covariance given a cross-covariance matrix.
EFdcca(m = 3, nu = 0, G, K = NULL)
EFdcca(m = 3, nu = 0, G, K = NULL)
m |
an integer or integer valued vector indicating the size of the window for the polinomial fit. |
nu |
a non-negative integer denoting the degree of the polinomial fit applied on the integrated series. |
G |
the cross-covariance matrix for the original time series. The dimension of |
K |
optional: the matrix |
a size vector containing the expected values of the detrended cross-covariance corresponding to the values of
provided. This is expression (23) in Prass and Pumi (2019).
Taiane Schaedler Prass
Prass, T.S. and Pumi, G. (2019). On the behavior of the DFA and DCCA in trend-stationary processes <arXiv:1910.10589>.
m = 3 K = Km(m = m, nu = 0) G = diag(m+1) EFdcca(G = G, K = K) # same as EFdcca(m = 3, nu = 0, G = G)
m = 3 K = Km(m = m, nu = 0) G = diag(m+1) EFdcca(G = G, K = K) # same as EFdcca(m = 3, nu = 0, G = G)
Calculates the detrended variance based on a given time series.
F2dfa(y, m = 3, nu = 0, overlap = TRUE)
F2dfa(y, m = 3, nu = 0, overlap = TRUE)
y |
vector corresponding to the time series data. |
m |
an integer or integer valued vector indicating the size (or sizes) of the window for the polinomial fit. |
nu |
a non-negative integer denoting the degree of the polinomial fit applied on the integrated series. |
overlap |
logical: if true (the default), uses overlapping windows. Otherwise, non-overlapping boxes are applied. |
A vector of size containing the detrended variance considering windows of size
, for each
supplied.
Taiane Schaedler Prass
Prass, T.S. and Pumi, G. (2019). On the behavior of the DFA and DCCA in trend-stationary processes <arXiv:1910.10589>.
# Simple usage y = rnorm(100) F2.dfa = F2dfa(y, m = 3, nu = 0, overlap = TRUE) F2.dfa vF2.dfa = F2dfa(y, m = 3:5, nu = 0, overlap = TRUE) vF2.dfa ################################################### # AR(1) example showing how the DFA varies with phi phi = (1:8)/10 n = 300 z = matrix(nrow = n, ncol = length(phi)) for(i in 1:length(phi)){ z[,i] = arima.sim(model = list(ar = phi[i]), n) } ms = 3:50 F2.dfa = matrix(ncol = length(phi), nrow = length(ms)) for(j in 1:length(phi)){ F2.dfa[,j] = F2dfa(z[,j], m = ms , nu = 0, overlap = TRUE) } cr = rainbow(length(phi)) plot(ms, F2.dfa[,1], type = "o", xlab = "m", col = cr[1], ylim = c(0,max(F2.dfa)), ylab = "F2.dfa") for(j in 2:length(phi)){ points(ms, F2.dfa[,j], type = "o", col = cr[j]) } legend("topleft", lty = 1, legend = phi, col = cr, bty = "n", title = expression(phi), pch=1) ############################################################################## # An MA(2) example showcasing why overlapping windows are usually advantageous n = 300 ms = 3:50 theta = c(0.4,0.5) # Calculating the expected value of the DFA in this scenario m_max = max(ms) vtheta = c(c(1,theta, rep(0, m_max - length(theta)))) G = matrix(0, ncol = m_max+1, nrow = m_max+1) for(t in 1:(m_max+1)){ for(h in 0:(m_max+1-t)){ G[t,t+h] = sum(vtheta[1:(length(vtheta)-h)]*vtheta[(1+h):length(vtheta)]) G[t+h,t] = G[t,t+h] } } EF2.dfa = EF2dfa(m = ms, nu = 0, G = G) z = arima.sim(model = list(ma = theta), n) ms = 3:50 OF2.dfa = F2dfa(z, m = ms, nu = 0, overlap = TRUE) NOF2.dfa = F2dfa(z, m = ms, nu = 0, overlap = FALSE) plot(ms, OF2.dfa, type = "o", xlab = "m", col = "blue", ylim = c(0,max(OF2.dfa,NOF2.dfa,EF2.dfa)), ylab = "F2.dfa") points(ms, NOF2.dfa, type = "o", col = "darkgreen") points(ms, EF2.dfa, type = "o", col = "red") legend("bottomright", legend = c("overlapping","non-overlapping","expected"), col = c("blue", "darkgreen","red"), lty= 1, bty = "n", pch=1)
# Simple usage y = rnorm(100) F2.dfa = F2dfa(y, m = 3, nu = 0, overlap = TRUE) F2.dfa vF2.dfa = F2dfa(y, m = 3:5, nu = 0, overlap = TRUE) vF2.dfa ################################################### # AR(1) example showing how the DFA varies with phi phi = (1:8)/10 n = 300 z = matrix(nrow = n, ncol = length(phi)) for(i in 1:length(phi)){ z[,i] = arima.sim(model = list(ar = phi[i]), n) } ms = 3:50 F2.dfa = matrix(ncol = length(phi), nrow = length(ms)) for(j in 1:length(phi)){ F2.dfa[,j] = F2dfa(z[,j], m = ms , nu = 0, overlap = TRUE) } cr = rainbow(length(phi)) plot(ms, F2.dfa[,1], type = "o", xlab = "m", col = cr[1], ylim = c(0,max(F2.dfa)), ylab = "F2.dfa") for(j in 2:length(phi)){ points(ms, F2.dfa[,j], type = "o", col = cr[j]) } legend("topleft", lty = 1, legend = phi, col = cr, bty = "n", title = expression(phi), pch=1) ############################################################################## # An MA(2) example showcasing why overlapping windows are usually advantageous n = 300 ms = 3:50 theta = c(0.4,0.5) # Calculating the expected value of the DFA in this scenario m_max = max(ms) vtheta = c(c(1,theta, rep(0, m_max - length(theta)))) G = matrix(0, ncol = m_max+1, nrow = m_max+1) for(t in 1:(m_max+1)){ for(h in 0:(m_max+1-t)){ G[t,t+h] = sum(vtheta[1:(length(vtheta)-h)]*vtheta[(1+h):length(vtheta)]) G[t+h,t] = G[t,t+h] } } EF2.dfa = EF2dfa(m = ms, nu = 0, G = G) z = arima.sim(model = list(ma = theta), n) ms = 3:50 OF2.dfa = F2dfa(z, m = ms, nu = 0, overlap = TRUE) NOF2.dfa = F2dfa(z, m = ms, nu = 0, overlap = FALSE) plot(ms, OF2.dfa, type = "o", xlab = "m", col = "blue", ylim = c(0,max(OF2.dfa,NOF2.dfa,EF2.dfa)), ylab = "F2.dfa") points(ms, NOF2.dfa, type = "o", col = "darkgreen") points(ms, EF2.dfa, type = "o", col = "red") legend("bottomright", legend = c("overlapping","non-overlapping","expected"), col = c("blue", "darkgreen","red"), lty= 1, bty = "n", pch=1)
Calculates the detrended cross-covariance between two time series and
.
Fdcca(y1, y2, m = 3, nu = 0, overlap = TRUE)
Fdcca(y1, y2, m = 3, nu = 0, overlap = TRUE)
y1 , y2
|
vectors corresponding to the time series data. If |
m |
an integer or integer valued vector indicating the size (or sizes) of the window for the polinomial fit. |
nu |
a non-negative integer denoting the degree of the polinomial fit applied on the integrated series. |
overlap |
logical: if true (the default), uses overlapping windows. Otherwise, non-overlapping boxes are applied. |
A vector of size containing the detrended cross-covariance considering windows of size
, for each
supplied.
Taiane Schaedler Prass
Prass, T.S. and Pumi, G. (2019). On the behavior of the DFA and DCCA in trend-stationary processes <arXiv:1910.10589>.
# Simple usage y1 = rnorm(100) y2 = rnorm(100) F.dcca = Fdcca(y1, y2, m = 3, nu = 0, overlap = TRUE) F.dcca # A simple example where y1 and y2 are independent. ms = 3:50 F.dcca1 = Fdcca(y1, y2, m = ms, nu = 0, overlap = TRUE) F.dcca2 = Fdcca(y1, y2, m = ms, nu = 0, overlap = FALSE) plot(ms, F.dcca1, type = "o", xlab = "m", col = "blue", ylim = c(min(F.dcca1,F.dcca2),max(F.dcca1,F.dcca2)), ylab = expression(F[DCCA])) points(ms, F.dcca2, type = "o", col = "red") legend("bottomright", legend = c("overlapping","non-overlapping"), col = c("blue", "red"), lty= 1, bty = "n", pch=1) # A more elaborated example where y1 and y2 display cross-correlation for non-null lags. # This example also showcases why overlapping windows are usually advantageous. # The data generating process is the following: # y1 is i.i.d. Gaussian while y2 is an MA(2) generated from y1. n = 500 ms = 3:50 theta = c(0.4,0.5) # Calculating the expected value of the DCCA in this scenario m_max = max(ms) vtheta = c(1,theta, rep(0, m_max - length(theta))) G12 = matrix(0, ncol = m_max+1, nrow = m_max+1) for(t in 1:(m_max+1)){ for(h in 0:(m_max+1-t)){ G12[t,t+h] = vtheta[h+1] } } EF.dcca = EFdcca(m = ms, nu = 0, G = G12) # generating the series and calculating the DCCA burn.in = 100 eps = rnorm(burn.in) y1 = rnorm(n) y2 = arima.sim(model = list(ma = theta), n, n.start = burn.in, innov = y1, start.innov = eps) ms = 3:50 OF.dcca = Fdcca(y1, y2, m = ms, nu = 0, overlap = TRUE) NOF.dcca = Fdcca(y1, y2, m = ms, nu = 0, overlap = FALSE) plot(ms, OF.dcca, type = "o", xlab = "m", col = "blue", ylim = c(min(NOF.dcca,OF.dcca,EF.dcca),max(NOF.dcca,OF.dcca,EF.dcca)), ylab = expression(F[DCCA])) points(ms, NOF.dcca, type = "o", col = "darkgreen") points(ms, EF.dcca, type = "o", col = "red") legend("bottomright", legend = c("overlapping","non-overlapping","expected"), col = c("blue", "darkgreen","red"), lty= 1, bty = "n", pch=1)
# Simple usage y1 = rnorm(100) y2 = rnorm(100) F.dcca = Fdcca(y1, y2, m = 3, nu = 0, overlap = TRUE) F.dcca # A simple example where y1 and y2 are independent. ms = 3:50 F.dcca1 = Fdcca(y1, y2, m = ms, nu = 0, overlap = TRUE) F.dcca2 = Fdcca(y1, y2, m = ms, nu = 0, overlap = FALSE) plot(ms, F.dcca1, type = "o", xlab = "m", col = "blue", ylim = c(min(F.dcca1,F.dcca2),max(F.dcca1,F.dcca2)), ylab = expression(F[DCCA])) points(ms, F.dcca2, type = "o", col = "red") legend("bottomright", legend = c("overlapping","non-overlapping"), col = c("blue", "red"), lty= 1, bty = "n", pch=1) # A more elaborated example where y1 and y2 display cross-correlation for non-null lags. # This example also showcases why overlapping windows are usually advantageous. # The data generating process is the following: # y1 is i.i.d. Gaussian while y2 is an MA(2) generated from y1. n = 500 ms = 3:50 theta = c(0.4,0.5) # Calculating the expected value of the DCCA in this scenario m_max = max(ms) vtheta = c(1,theta, rep(0, m_max - length(theta))) G12 = matrix(0, ncol = m_max+1, nrow = m_max+1) for(t in 1:(m_max+1)){ for(h in 0:(m_max+1-t)){ G12[t,t+h] = vtheta[h+1] } } EF.dcca = EFdcca(m = ms, nu = 0, G = G12) # generating the series and calculating the DCCA burn.in = 100 eps = rnorm(burn.in) y1 = rnorm(n) y2 = arima.sim(model = list(ma = theta), n, n.start = burn.in, innov = y1, start.innov = eps) ms = 3:50 OF.dcca = Fdcca(y1, y2, m = ms, nu = 0, overlap = TRUE) NOF.dcca = Fdcca(y1, y2, m = ms, nu = 0, overlap = FALSE) plot(ms, OF.dcca, type = "o", xlab = "m", col = "blue", ylim = c(min(NOF.dcca,OF.dcca,EF.dcca),max(NOF.dcca,OF.dcca,EF.dcca)), ylab = expression(F[DCCA])) points(ms, NOF.dcca, type = "o", col = "darkgreen") points(ms, EF.dcca, type = "o", col = "red") legend("bottomright", legend = c("overlapping","non-overlapping","expected"), col = c("blue", "darkgreen","red"), lty= 1, bty = "n", pch=1)
Creates a by
lower triangular matrix with all non-zero entries equal to one.
Jn(n = 2)
Jn(n = 2)
n |
number of rows and columns in the J matrix. |
an by
lower triangular matrix with all non-zero entries equal to one. This is an auxiliary function.
J = Jn(n = 3) J
J = Jn(n = 3) J
This is an auxiliary function and requires some context to be used adequadely. It computes equation (19) in Prass and Pumi (2019), returning a square matrix defined by
where:
is an
by
lower triangular matrix with all non-zero entries equal to one, with
if overlap = TRUE and
, otherwise;
corresponds to the first
rows and columns of
;
corresponds to the last
rows of
;
, where
is the
by
projection matrix into the subspace generated by degree
polynomials.
Kkronm(m = 3, nu = 0, h = 0, overlap = TRUE, K = NULL)
Kkronm(m = 3, nu = 0, h = 0, overlap = TRUE, K = NULL)
m |
a positive integer indicating the size of the window for the polinomial fit. |
nu |
a non-negative integer denoting the degree of the polinomial fit applied on the integrated series. |
h |
an integer indicating the lag. |
overlap |
logical: if true (the default), overlapping boxes are used for calculations. Otherwise, non-overlapping boxes are applied. |
K |
optional: the matrix defined by |
an by
matrix, where
if overlap = TRUE and
, otherwise. This matrix corresponds to equation (19) in Prass and Pumi (2019).
Taiane Schaedler Prass
Prass, T.S. and Pumi, G. (2019). On the behavior of the DFA and DCCA in trend-stationary processes <arXiv:1910.10589>.
Jn
which creates the matrix ,
Qm
which creates and
Km
which creates .
m = 3 h = 1 J = Jn(n = m+1+h) Q = Qm(m = m, nu = 0) # using K K = Km(J = J[1:(m+1),1:(m+1)], Q = Q) Kkron0 = Kkronm(K = K, h = h) # using m and nu Kkron = Kkronm(m = m, nu = 0, h = h) # using kronecker product from R K = Km(J = J[1:(m+1),1:(m+1)], Q = Q) Kh = rbind(matrix(0, nrow = h, ncol = m+1+h), cbind(matrix(0, nrow = m+1, ncol = h), K)) KkronR = K %x% Kh # using the definition K* = (Jm %x% J)'(Q %x% Q)(Jm %x% J) J_m = J[1:(m+1),1:(m+1)] J_h = J[(h+1):(m+1+h),1:(m+1+h)] KkronD = t(J_m %x% J_h)%*%(Q %x% Q)%*%(J_m %x% J_h) # comparing the results sum(abs(Kkron0 - Kkron)) sum(abs(Kkron0 - KkronR)) sum(abs(Kkron0 - KkronD)) # difference due to rounding error ## Not run: # Function Kkronm is computationaly faster than a pure implementation in R: m = 100 h = 1 J = Jn(n = m+1) Q = Qm(m = m, nu = 0) # using Kkronm t1 = proc.time() Kkron = Kkronm(m = m, nu = 0, h = 1) t2 = proc.time() # elapsed time: t2-t1 # Pure R implementation: K = Km(J = J, Q = Q) Kh = rbind(matrix(0, nrow = h, ncol = m+1+h), cbind(matrix(0, nrow = m+1, ncol = h), K)) t3 = proc.time() KkronR = K %x% Kh t4 = proc.time() # elapsed time t4-t3 ## End(Not run)
m = 3 h = 1 J = Jn(n = m+1+h) Q = Qm(m = m, nu = 0) # using K K = Km(J = J[1:(m+1),1:(m+1)], Q = Q) Kkron0 = Kkronm(K = K, h = h) # using m and nu Kkron = Kkronm(m = m, nu = 0, h = h) # using kronecker product from R K = Km(J = J[1:(m+1),1:(m+1)], Q = Q) Kh = rbind(matrix(0, nrow = h, ncol = m+1+h), cbind(matrix(0, nrow = m+1, ncol = h), K)) KkronR = K %x% Kh # using the definition K* = (Jm %x% J)'(Q %x% Q)(Jm %x% J) J_m = J[1:(m+1),1:(m+1)] J_h = J[(h+1):(m+1+h),1:(m+1+h)] KkronD = t(J_m %x% J_h)%*%(Q %x% Q)%*%(J_m %x% J_h) # comparing the results sum(abs(Kkron0 - Kkron)) sum(abs(Kkron0 - KkronR)) sum(abs(Kkron0 - KkronD)) # difference due to rounding error ## Not run: # Function Kkronm is computationaly faster than a pure implementation in R: m = 100 h = 1 J = Jn(n = m+1) Q = Qm(m = m, nu = 0) # using Kkronm t1 = proc.time() Kkron = Kkronm(m = m, nu = 0, h = 1) t2 = proc.time() # elapsed time: t2-t1 # Pure R implementation: K = Km(J = J, Q = Q) Kh = rbind(matrix(0, nrow = h, ncol = m+1+h), cbind(matrix(0, nrow = m+1, ncol = h), K)) t3 = proc.time() KkronR = K %x% Kh t4 = proc.time() # elapsed time t4-t3 ## End(Not run)
This is an auxiliary function which computes expression (18) in Prass and Pumi (2019). It creates an by
matrix defined by
where
is a
by
lower triangular matrix with all non-zero entries equal to one and
is a
by
given by
where
is the projection matrix into the subspace generated by degree
polynomials and
is the
by
identity matrix.
Km(m = 3, nu = 0, J = NULL, Q = NULL)
Km(m = 3, nu = 0, J = NULL, Q = NULL)
m |
a positive integer greater or equal than |
nu |
a non-negative integer denoting the degree of the polinomial fit applied on the integrated series. |
J , Q
|
optional: the matrices such that |
an by
matrix corresponding to expression (18) in Prass and Pumi (2019).
Taiane Schaedler Prass
Prass, T.S. and Pumi, G. (2019). On the behavior of the DFA and DCCA in trend-stationary processes <arXiv:1910.10589>.
Jn
which creates the matrix ,
Qm
which creates and
Pm
which creates .
K = Km(m = 3, nu = 0) K # same as m = 3 J = Jn(n = m+1) Q = Qm(m = m, nu = 0) K = Km(J = J, Q = Q) K
K = Km(m = 3, nu = 0) K # same as m = 3 J = Jn(n = m+1) Q = Qm(m = m, nu = 0) K = Km(J = J, Q = Q) K
Creates the by
projection matrix defined by
where
is the design matrix associated to a polynomial regression of degree nu + 1.
Pm(m = 2, nu = 0)
Pm(m = 2, nu = 0)
nu |
the degree of the polinomial fit. |
m |
a positive integer satisfying |
To perform matrix inversion, the code makes use of the routine DGETRI in LAPACK, which applies an LU decomposition approach to obtain the inverse matrix. See the LAPACK documentation available at http://www.netlib.org/lapack.
an by
matrix.
Taiane Schaedler Prass
P = Pm(m = 5, nu = 0) P n = 10 t = 1:n D = cbind(rep(1,n),t,t^2) # Calculating in R PR = D%*%solve(t(D)%*%D)%*%t(D) # Using the provided function P = Pm(m = n-1, nu = 1) # Difference: sum(abs(P-PR))
P = Pm(m = 5, nu = 0) P n = 10 t = 1:n D = cbind(rep(1,n),t,t^2) # Calculating in R PR = D%*%solve(t(D)%*%D)%*%t(D) # Using the provided function P = Pm(m = n-1, nu = 1) # Difference: sum(abs(P-PR))
Creates the by
projection matrix defined by
where
is the the
by
identity matrix and
is the
by
projection matrix into the space generated by polynomials of degree
.
Qm(m = 2, nu = 0, P = NULL)
Qm(m = 2, nu = 0, P = NULL)
nu |
the degree of the polinomial fit. |
m |
a positive integer satisfying |
P |
optional: the projection matrix such that |
an by
matrix.
Pm
which generates the projection matrix .
Q = Qm(m = 3, nu = 0) Q # same as P = Pm(m = 3, nu = 0) Q = Qm(P = P) Q
Q = Qm(m = 3, nu = 0) Q # same as P = Pm(m = 3, nu = 0) Q = Qm(P = P) Q
Calculates the detrended cross-correlation coefficient for two time series and
.
rhodcca(y1, y2, m = 3, nu = 0, overlap = TRUE)
rhodcca(y1, y2, m = 3, nu = 0, overlap = TRUE)
y1 , y2
|
vectors corresponding to the time series data. If |
m |
an integer value or a vector of integer values indicating the size of the window for the polinomial fit. |
nu |
the degree of the polynomial fit |
overlap |
logical: if true (the default), uses overlapping windows. Otherwise, non-overlapping boxes are applied. |
A list containing the following elements, calculated considering windows of size , for each
supplied:
F2dfa1 , F2dfa2
|
The detrended variances for |
Fdcca |
The detrended cross-covariance. |
rhodcca |
The detrended cross-correlation coefficient. |
The time series and
must have the same sample size.
Taiane Schaedler Prass
Prass, T.S. and Pumi, G. (2019). On the behavior of the DFA and DCCA in trend-stationary processes <arXiv:1910.10589>.
F2dfa
which calculated the DFA and Fdcca
which calculated the DCCA of two given time series.
y1 = rnorm(100) y2 = rnorm(100) rho.dccam1 = rhodcca(y1, y2, m = 3, nu = 0, overlap = TRUE) rho.dccam1 rho.dccam2 = rhodcca(y1, y2, m = c(3,6,8), nu = 0, overlap = TRUE) rho.dccam2
y1 = rnorm(100) y2 = rnorm(100) rho.dccam1 = rhodcca(y1, y2, m = 3, nu = 0, overlap = TRUE) rho.dccam1 rho.dccam2 = rhodcca(y1, y2, m = c(3,6,8), nu = 0, overlap = TRUE) rho.dccam2
Calculates the theoretical counterpart of the cross-correlation coefficient. This is expression (11) in Prass and Pumi (2019). For trend-stationary processes under mild assumptions, this is equivalent to the limit of the detrended cross correlation coefficient calculated with window of size as
tends to infinity (see theorem 3.2 in Prass and Pumi, 2019).
rhoE(m = 3, nu = 0, G1, G2, G12, K = NULL)
rhoE(m = 3, nu = 0, G1, G2, G12, K = NULL)
m |
an integer or integer valued vector indicating the size (or sizes) of the window for the polinomial fit. |
nu |
a non-negative integer denoting the degree of the polinomial fit applied on the integrated series. |
G1 , G2
|
the autocovariance matrices for the original time series. Both are |
G12 |
the cross-covariance matrix for the original time series. The dimension of |
K |
optional: the matrix |
The optional argument is an
by
matrix defined by
, where
is a
by
lower triangular matrix with all non-zero entries equal to one and
is a
by
given by
where
is the projection matrix into the subspace generated by degree
polynomials and
is the
by
identity matrix.
is equivalent to expression (18) in Prass and Pumi (2019).
If this matrix is provided and
is an integer, then
are ignored.
A list containing the following elements, calculated considering windows of size , for each
supplied:
EF2dfa1 , EF2dfa2
|
the expected values of the detrended variances. |
EFdcca |
the expected value of the detrended cross-covariance. |
rhoE |
the vector with the theoretical counterpart of the cross-correlation coefficient. |
Taiane Schaedler Prass
Prass, T.S. and Pumi, G. (2019). On the behavior of the DFA and DCCA in trend-stationary processes <arXiv:1910.10589>.
Km
which creates the matrix ,
Jn
which creates the matrix ,
Qm
which creates and
Pm
which creates .
m = 3 K = Km(m = m, nu = 0) G1 = G2 = diag(m+1) G12 = matrix(0,ncol = m+1, nrow = m+1) rhoE(G1 = G1, G2 = G2, G12 = G12, K = K) # same as rhoE(m = 3, nu = 0, G1 = G1, G2 = G2, G12 = G12)
m = 3 K = Km(m = m, nu = 0) G1 = G2 = diag(m+1) G12 = matrix(0,ncol = m+1, nrow = m+1) rhoE(G1 = G1, G2 = G2, G12 = G12, K = K) # same as rhoE(m = 3, nu = 0, G1 = G1, G2 = G2, G12 = G12)