Ridgetorus
PCA on the torus using density ridges. Software companion for "Toroidal PCA via density ridges"
Install / Use
/learn @egarpor/RidgetorusREADME
ridgetorus
<!-- # ```{r, badges, echo = FALSE, results = 'asis'} --> <!-- # cat( --> <!-- # badger::badge_license(license = "GPLv3", color = "blue", --> <!-- # url = "https://www.gnu.org/licenses/gpl-3.0"), --> <!-- # badger::badge_github_actions(action = "R-CMD-check"), --> <!-- # badger::badge_github_actions(action = "test-coverage"), --> <!-- # badger::badge_codecov(ref = NULL), --> <!-- # badger::badge_cran_release(color = "green"), --> <!-- # badger::badge_cran_download(pkg = NULL, type = "grand-total"), --> <!-- # badger::badge_cran_download(pkg = NULL, type = "last-month") --> <!-- # ) --> <!-- # ``` --> <!-- <img src="" alt="ridgetorus hexlogo" align="right" width="200" style="padding: 0 15px; float: right;"/> -->Overview
Implementation of principal component analysis on the two-dimensional torus $\mathbb{T}^2=[-\pi,\pi)^2$ via density ridges. Software companion for the paper “Toroidal PCA via density ridges” (García-Portugués and Prieto-Tirado, 2023).
Installation
Get the latest version from GitHub:
# Install the package
library(devtools)
install_github("egarpor/ridgetorus")
# Load package
library(ridgetorus)
Usage
The main functionality of ridgetorus is the function ridge_pca(),
which can be employed to do dimension reduction via the bivariate sine
von Mises (Singh et al., 2002) and the bivariate wrapped Cauchy (Kato
and Pewsey, 2015) models, as the following examples show.
Bivariate sine von Mises
# 1. Simulate data from r_bvm()
data <- r_bvm(n = 1000, mu = c(1, 2), kappa = c(5, 2, 1.5))
# 2. Do ridge_pca()
rpca <- ridge_pca(x = data, type = "bvm")
# 3. Plot simulated data with ridge fit using show_ridge_pca()
show_ridge_pca(rpca, col_data = "red")
<img src="README/README-bvm-1.png" style="display: block; margin: auto;" />
# 4. Plot pairs plots of original data and scores with torus_pairs()
torus_pairs(data, col_data = "red", bwd = "EMI")
<img src="README/README-bvm-2.png" style="display: block; margin: auto;" />
torus_pairs(rpca$scores, col_data = "red", bwd = "EMI", scales = rpca$scales)
<img src="README/README-bvm-3.png" style="display: block; margin: auto;" />
Bivariate wrapped Cauchy
# 1. Simulate data from r_bwc()
data <- r_bwc(n = 1000, mu = c(-1, 2), xi = c(0.3, 0.6, 0.25))
# 2. Do ridge_pca()
rpca <- ridge_pca(x = data, type = "bwc")
# 3. Plot simulated data with ridge fit using show_ridge_pca()
show_ridge_pca(rpca, col_data = "red")
<img src="README/README-bwc-1.png" style="display: block; margin: auto;" />
# 4. Plot pairs plots of original data and scores with torus_pairs()
torus_pairs(rpca$scores, col_data = "red", bwd = "EMI", scales = rpca$scales)
<img src="README/README-bwc-2.png" style="display: block; margin: auto;" />
Data application in oceanography
The data applications in García-Portugués and Prieto-Tirado (2023) can be reproduced through the script data-application.R. The code snippet below illustrates the toroidal PCA analysis onto currents of four zones at Santa Barbara strait. Zone A and B are on the northern coast of Santa Barbara Channel while zone C and D, are at the top and bottom ends of the interisland channel.
# Load data
data("santabarbara")
# Example with zone A-B with automatic comparison between bvm and bwc
rpca_AB <- ridge_pca(x = santabarbara[c("A", "B")], type = "auto")
show_ridge_pca(fit = rpca_AB, col_data = "black", n_max = 1e3)
<img src="README/README-santabarbara-1.png" style="display: block; margin: auto;" />
torus_pairs(santabarbara[c("A", "B")], col_data = "black")
<img src="README/README-santabarbara-2.png" style="display: block; margin: auto;" />
torus_pairs(rpca_AB$scores, col_data = "black", scales = rpca_AB$scales)
<img src="README/README-santabarbara-3.png" style="display: block; margin: auto;" />
rpca_AB$type
#> [1] "bwc"
rpca_AB$var_exp
#> [1] 0.7450665 1.0000000
# Example with zone C-D with automatic comparison between bvm and bwc
rpca_CD <- ridge_pca(x = santabarbara[c("C", "D")], type = "auto")
show_ridge_pca(fit = rpca_CD, col_data = "black", n_max = 1e3)
<img src="README/README-santabarbara-4.png" style="display: block; margin: auto;" />
torus_pairs(santabarbara[c("C", "D")], col_data = "black")
<img src="README/README-santabarbara-5.png" style="display: block; margin: auto;" />
torus_pairs(rpca_CD$scores, col_data = "black", scales = rpca_CD$scales)
<img src="README/README-santabarbara-6.png" style="display: block; margin: auto;" />
rpca_CD$type
#> [1] "bvm"
rpca_CD$var_exp
#> [1] 0.7934003 1.0000000
It can be seen how the bivariate von Mises and the bivariate wrapped Cauchy are the most adequate fits for zones C–D and A–B, respectively. Toroidal PCA explains around 75% of the total variance in both cases, motivating its use for dimension reduction. The scores also transform the data distribution, reducing noise and allowing to check for groups or outliers, if any.
References
García-Portugués, E. and Prieto-Tirado, A. (2023). Toroidal PCA via density ridges. Statistics and Computing, 33(5):107. doi:10.1007/s11222-023-10273-9.
Kato, S. and Pewsey, A. (2015). A Möbius transformation-induced distribution on the torus. Biometrika, 102(2):359–370. doi:10.1093/biomet/asv003.
Singh, H., Hnizdo, V., and Demchuk, E. (2002). Probabilistic model for two dependent circular variables. Biometrika, 89(3):719–723. doi:10.1093/biomet/89.3.719.
Related Skills
node-connect
337.7kDiagnose OpenClaw node connection and pairing failures for Android, iOS, and macOS companion apps
frontend-design
83.3kCreate distinctive, production-grade frontend interfaces with high design quality. Use this skill when the user asks to build web components, pages, or applications. Generates creative, polished code that avoids generic AI aesthetics.
openai-whisper-api
337.7kTranscribe audio via OpenAI Audio Transcriptions API (Whisper).
commit-push-pr
83.3kCommit, push, and open a PR
