The R package mixedCCA
implements sparse canonical
correlation analysis for data of mixed types: continuous, binary or
zero-inflated (truncated continuous). The corresponding reference is
The faster version of latent correlation computation part is now
fully available and implemented to the R package mixedCCA
.
The corresponding reference is available on arXiv:
Yoon G., Müller C.L. and Gaynanova I., “Fast computation of latent correlations” JCGS.
Attention: Due to deprecation of R package
chebpol
(https://cran.r-project.org/package=chebpol), the fast
version is temporarily unavailable. We are working on a fix.
devtools::install_github("irinagain/mixedCCA")
library(mixedCCA)
### Simple example
# Data setting
<- 100; p1 <- 15; p2 <- 10 # sample size and dimensions for two datasets.
n <- 0.9 # true canonical correlation
maxcancor
# Correlation structure within each data set
set.seed(0)
<- sample(1:p1, size = p1);
perm1 <- autocor(p1, 0.7)[perm1, perm1]
Sigma1 <- sample(1:3, size = p2, replace = TRUE);
blockind <- blockcor(blockind, 0.7)
Sigma2 <- rbinom(p1+p2, 1, 0.5)
mu
# true variable indices for each dataset
<- c(rep(1, 3), rep(0, p1-3))
trueidx1 <- c(rep(1, 2), rep(0, p2-2))
trueidx2
# Data generation
<- GenerateData(n=n, trueidx1 = trueidx1, trueidx2 = trueidx2, maxcancor = maxcancor,
simdata Sigma1 = Sigma1, Sigma2 = Sigma2,
copula1 = "exp", copula2 = "cube",
muZ = mu,
type1 = "trunc", type2 = "trunc",
c1 = rep(1, p1), c2 = rep(0, p2)
)<- simdata$X1
X1 <- simdata$X2
X2
# Sparse semiparametric CCA with BIC1 criterion
<- mixedCCA(X1, X2, type1 = "trunc", type2 = "trunc", BICtype = 1)
mixedCCAresult $KendallR # estimated latent correlation matrix
mixedCCAresult$w1 # estimated canonical vector for X1
mixedCCAresult$w2 # estimated canonical vector for X2
mixedCCAresult$cancor # estimated canonical correlation
mixedCCAresult
# Separate estimation of latent correlation matrix
estimateR(X1, type = "trunc")$R # For X1 only
estimateR_mixed(X1, X2, type1 = "trunc", type2 = "trunc")$R12 # For X = (X1, X2)