#' labelTransfer
#'
#' Label transfer between a test partition and a training set of partitions.
#'
#' @param training.cytometry List of partitions, where each partition is a dataframe where the last column contains the labels of the partition.
#' @param test.cytometry Test data, a dataframe without labels.
#' @param test.partition Labels of a partition of the test data.
#' @param equal.weights If True, weights assigned to every cluster in a partion are uniform (1/number of clusters) when calculating the similarity distance. If False, weights assigned to clusters are the proportions of points in every cluster compared to the total amount of points in the partition.
#'
#' @return A fuzzy relabeling consistent of a transportation plan.
#'
#' @examples
#' \donttest{
#' data.example <- data.frame(v1 = c(rnorm(50, 2, 1), rnorm(50, -2, 1)),
#' v2 = c(rnorm(50, 2, 1), rnorm(50, -2, 1)), id = c(rep(0, 50), rep(1, 50)))
#' test.labels <- c(rep('a', 50), rep('b', 50))
#' labelTransfer(data.example, data.example[, 1:2], test.labels)
#' }
#' @importFrom stats rnorm
#' @export
#'
labelTransfer <- function(training.cytometry, test.cytometry, test.partition, equal.weights = FALSE) {
dim.cyto <- dim(test.cytometry)[2]
training.partition <- training.cytometry[, dim(training.cytometry)[2]]
training.cells <- names(table(training.partition))
M <- length(training.cells)
test.cells <- names(table(test.partition))
N <- length(test.cells)
cost.matrix <- array(dim = c(M, N))
t0 <- Sys.time()
j <- 0
for (cell in training.cells) {
j <- j + 1
n_1 <- sum(training.partition == cell)
jj <- 0
for (k_m in test.cells) {
jj <- jj + 1
n_2 <- sum(test.partition == k_m)
if (n_1 <= 10000) {
if (n_2 <= 10000) {
cost <- sum(Rfast::dista(training.cytometry[training.partition == cell, 1:dim.cyto], test.cytometry[test.partition ==
k_m, 1:dim.cyto]))/(n_1 * n_2)
} else {
cost <- sum(Rfast::dista(training.cytometry[training.partition == cell, 1:dim.cyto], test.cytometry[sample(which(test.partition ==
k_m), 10000), 1:dim.cyto]))/(n_1 * 10000)
}
} else {
if (n_2 <= 10000) {
cost <- sum(Rfast::dista(training.cytometry[sample(which(training.partition == cell), 10000), 1:dim.cyto], test.cytometry[test.partition ==
k_m, 1:dim.cyto]))/(n_2 * 10000)
} else {
cost <- sum(Rfast::dista(training.cytometry[sample(which(training.partition == cell), 10000), 1:dim.cyto], test.cytometry[sample(which(test.partition ==
k_m), 10000), 1:dim.cyto]))/(10000 * 10000)
}
}
cost.matrix[j, jj] <- cost
}
}
if (equal.weights) {
A <- rep(1/M, M)
B <- rep(1/N, N)
names(A) <- training.cells
names(B) <- test.cells
} else {
A <- table(training.partition)/sum(table(training.partition))
B <- table(test.partition)/sum(table(test.partition))
}
optimal.transp.from.A.to.B <- transport::transport(a = A, b = B, costm = cost.matrix)
optimal.transp.from.A.to.B$to <- names(B)[optimal.transp.from.A.to.B$to]
optimal.transp.from.A.to.B$from <- names(A)[optimal.transp.from.A.to.B$from]
return(optimal.transp.from.A.to.B)
}
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.