R/STATIS.R

STATIS <- function (Ktab, nf=3, tol=1e-07) {
    
    nlig <- nrow(Ktab[[1]]) 
    ntab <- length(Ktab)
    result <- sep <- list()
    
    sep <- lapply(Ktab, function(wk) { wk <- as.matrix(wk)
    wk <- t(wk) * sqrt(1/ncol(wk))
    wk <- t(wk) %*% wk
    wk })
    
    sep <- matrix(unlist(sep), nlig * nlig, ntab)
    
    RV <- t(sep) %*% sep
    ak <- sqrt(diag(RV))
    RV <- sweep(RV, 1, ak, "/")
    RV <- sweep(RV, 2, ak, "/")
    
    eig1 <- eigen(RV, symmetric=TRUE)
    
    if (any(eig1$vectors[, 1] < 0)) {
        eig1$vectors[, 1] <- -eig1$vectors[, 1]
    }
    
    tabw <- eig1$vectors[, 1]
    
    sep <- t(t(sep)/ak)
    Cro <- rowSums(sweep(sep, 2, tabw, "*"))
    Cro <- matrix(unlist(Cro), nlig, nlig)
    eig1 <- eigen(Cro, symmetric=TRUE)
    result$Cro <- Cro
    rm(Cro)
    eig <- eig1$values
    rank <- sum((eig/eig[1]) > tol)
    
    if (nf <= 0) { nf <- 2 }
    
    if (nf > rank) { nf <- rank }
    
    wref <- eig1$vectors[, seq_len(nf)]
    rm(eig1)
    w <- data.frame(t(t(wref) * sqrt(eig[seq_len(nf)])))
    names(w) <- paste("C", seq_len(nf), sep="")
    result$Cli <- w
    
    return(result)
}
GonzalezIgnacio/missRows documentation built on Jan. 16, 2020, 4:11 a.m.