The hardware and bandwidth for this mirror is donated by dogado GmbH, the Webhosting and Full Service-Cloud Provider. Check out our Wordpress Tutorial.
If you wish to report a bug, or if you are interested in having us mirror your free-software or open-source project, please feel free to contact us at mirror[@]dogado.de.
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.
These binaries (installable software) and packages are in development.
They may not be fully stable and should be used with caution. We make no claims about them.
Health stats visible at Monitor.