Wavelet Quantile Correlation (WQC) is a powerful tool for examining scale-specific dependence between two time series at different points of the distribution (e.g., tails or median). By combining the maximal overlap discrete wavelet transform (MODWT) with quantile correlation measures, WQC uncovers how extreme and central co-movements vary across time scales. The wqc package implements WQC in three user-friendly functions:
Let \(X\) and \(Y\) be two random variables. For a quantile level \(\tau\in(0,1)\), define the influence function:
\[ \phi_\tau(w) = \tau - I(w < 0), \]
where \(I(\cdot)\) is the indicator function. The quantile covariance of \(Y\) and \(X\) at \(\tau\) is:
\[ \mathrm{qcov}_\tau(Y,X) = \mathrm{Cov}\bigl(\phi_\tau(Y - Q_{\tau,Y}),\,X - \mathbb{E}[X]\bigr), \]
with \(Q_{\tau,Y}\) the \(\tau\)th quantile of \(Y\). The Quantile Correlation (QC) is then:
\[ \mathrm{QC}_\tau(X,Y) = \frac{\mathrm{qcov}_\tau(Y,X)}{\sqrt{\mathrm{Var}(\phi_\tau(Y - Q_{\tau,Y}))\,\mathrm{Var}(X)}}. \]
To capture scale-dependent dynamics, each series is decomposed into \(J\) levels of detail coefficients via MODWT (Percival & Walden, 2000):
For each level \(j=1,\dots,J\) and quantile \(\tau\):
The function quantile_correlation_analysis() automates these computations, returning a data frame:
Level | Quantile | Estimated_QC | CI_Lower | CI_Upper |
---|---|---|---|---|
1 | 0.05 | 0.12 | 0.05 | 0.18 |
… | … | … | … | … |
\(J\) | 0.95 | -0.03 | -0.08 | 0.01 |
apply_quantile_correlation()
library(wqca)
set.seed(123)
# Reference series plus two targets
data <- data.frame(
x = rnorm(512),
y = 0.6 * rnorm(512) + 0.4 * rnorm(512),
z = rnorm(512)
)
quantiles <- c(0.1, 0.5, 0.9)
# Compute WQC up to 3 levels with 300 bootstrap sims
res_df <- apply_quantile_correlation(data, quantiles, J = 3, n_sim = 300)
# View top rows
head(res_df)
quantile_correlation_analysis()
plot_quantile_heatmap()
Once you have your correlation results from quantile_correlation_analysis() , you can plot them at a glance:
# compute a small example
set.seed(100)
df <- quantile_correlation_analysis(
x = rnorm(128), y = rnorm(128),
quantiles = c(0.1, 0.5, 0.9),
J = 4, n_sim = 50
)
plot_quantile_heatmap(df)
Kumar, A. S., & Padakandla, S. R. (2022). Testing the safe-haven properties of gold and bitcoin in the backdrop of COVID-19: A wavelet quantile correlation approach. Finance Research Letters, 47, 102707.
Percival, D. B., & Walden, A. T. (2000). Wavelet Methods for Time Series Analysis. Cambridge University Press.