Nothing
sig_compare <- function(sig1, sig2, metric = c("cosine", "jsd"),
threshold=0.9) {
metric <- match.arg(metric)
sig1_names <- colnames(sig1)
sig2_names <- colnames(sig2)
if (nrow(sig1) != nrow(sig2)) {
stop("Signatures must have the same number of motifs.")
}
if(!is.null(rownames(sig1)) && !is.null(rownames(sig2)) &&
!all(rownames(sig1) == rownames(sig2))) {
warning("The names of the motifs in signature matrix one do not equal the ",
"names of the motifs in signature matrix two.")
}
if(metric == "jsd") {
matches <- .jsd(sig1, sig2)
metric_name <- "1_minus_jsd"
} else {
matches <- .cosine(sig1, sig2)
metric_name <- "cosine"
}
comparison <- NULL
for (row in seq_len(nrow(matches))) {
line <- which(matches[row, ] > threshold)
if (length(line) > 0) {
for (match in line) {
comparison <- rbind(comparison, c(matches[row, match], row, match,
sig1_names[row], sig2_names[match]))
}
}
}
if (is.null(comparison)) {
stop("No matches found, try lowering threshold.")
}
comparison <- data.frame(comparison, stringsAsFactors = FALSE)
colnames(comparison) <- c(metric_name, "x_sig_index", "y_sig_index",
"x_sig_name", "y_sig_name")
comparison[[metric_name]] <- as.numeric(comparison[[metric_name]])
comparison$x_sig_index <- as.numeric(comparison$x_sig_index)
comparison$y_sig_index <- as.numeric(comparison$y_sig_index)
comparison <- comparison[order(comparison[[metric_name]], decreasing = TRUE),]
return(comparison)
}
#' Compare two result files to find similar signatures
#'
#' @param result A \code{\linkS4class{musica_result}} object.
#' @param other_result A second \code{\linkS4class{musica_result}} object.
#' @param threshold threshold for similarity
#' @param metric One of \code{"cosine"} for cosine similarity or \code{"jsd"}
#' for 1 minus the Jensen-Shannon Divergence. Default \code{"cosine"}.
#' @param result_name title for plot of first result signatures
#' @param other_result_name title for plot of second result signatures
#' @return Returns the comparisons
#' @examples
#' data(res)
#' compare_results(res, res, threshold = 0.8)
#' @export
compare_results <- function(result, other_result, threshold = 0.9,
metric = "cosine", result_name =
deparse(substitute(result)), other_result_name =
deparse(substitute(other_result))) {
signatures <- signatures(result)
comparison <- sig_compare(sig1 = signatures, sig2 = signatures(other_result),
threshold = threshold, metric = metric)
result_subset <- methods::new("musica_result",
signatures =
signatures(result)[, comparison$x_sig_index,
drop = FALSE], exposures =
matrix(), type = "NMF",
musica = musica(result),
tables = table_name(result))
other_subset <- methods::new("musica_result",
signatures =
signatures(
other_result)[, comparison$y_sig_index,
drop = FALSE],
exposures = matrix(), type = "NMF",
musica = musica(other_result),
tables = table_name(other_result))
.plot_compare_result_signatures(result_subset, other_subset,
res1_name = result_name,
res2_name = other_result_name)
return(comparison)
}
#' Compare a result object to COSMIC V3 Signatures; Select exome or genome for
#' SBS and only genome for DBS or Indel classes
#'
#' @param result A \code{\linkS4class{musica_result}} object.
#' @param variant_class Compare to SBS, DBS, or Indel
#' @param sample_type exome (SBS only) or genome
#' @param threshold threshold for similarity
#' @param metric One of \code{"cosine"} for cosine similarity or \code{"jsd"}
#' for 1 minus the Jensen-Shannon Divergence. Default \code{"cosine"}.
#' @param result_name title for plot user result signatures
#' @return Returns the comparisons
#' @examples
#' data(res)
#' compare_cosmic_v3(res, "SBS", "genome", threshold = 0.8)
#' @export
compare_cosmic_v3 <- function(result, variant_class, sample_type,
metric = "cosine", threshold = 0.9,
result_name = deparse(substitute(result))) {
if (sample_type == "exome") {
if (variant_class %in% c("snv", "SNV", "SNV96", "SBS", "SBS96")) {
cosmic_res <- cosmic_v3_sbs_sigs_exome
} else {
stop(paste("Only SBS class is available for whole-exome, please choose",
" `genome` for DBS or Indel", sep = ""))
}
} else if (sample_type == "genome") {
if (variant_class %in% c("snv", "SNV", "SNV96", "SBS", "SBS96")) {
cosmic_res <- cosmic_v3_sbs_sigs
} else if (variant_class %in% c("DBS", "dbs", "doublet")) {
cosmic_res <- cosmic_v3_dbs_sigs
} else if (variant_class %in% c("INDEL", "Indel", "indel", "ind", "IND",
"ID")) {
cosmic_res <- cosmic_v3_indel_sigs
} else {
stop("Only SBS, DBS, and Indel classes are supported")
}
} else {
stop("Sample type must be exome or genome")
}
signatures <- signatures(result)
comparison <- sig_compare(sig1 = signatures, sig2 = signatures(cosmic_res),
threshold = threshold, metric = metric)
result_subset <- methods::new(
"musica_result", signatures = signatures(result)[, comparison$x_sig_index,
drop = FALSE],
exposures = matrix(), type = "NMF", tables = table_name(result),
musica = musica(result))
other_subset <- methods::new("musica_result", signatures =
signatures(cosmic_res)[,
comparison$y_sig_index,
drop = FALSE],
exposures = matrix(), type = "NMF",
tables = table_name(cosmic_res),
musica = musica(cosmic_res))
.plot_compare_result_signatures(result_subset, other_subset,
res1_name = result_name,
res2_name = "COSMIC Signatures (V3)")
return(comparison)
}
#' Compare a result object to COSMIC V2 SBS Signatures (combination whole-exome
#' and whole-genome)
#'
#' @param result A \code{\linkS4class{musica_result}} object.
#' @param threshold threshold for similarity
#' @param metric One of \code{"cosine"} for cosine similarity or \code{"jsd"}
#' for 1 minus the Jensen-Shannon Divergence. Default \code{"cosine"}.
#' @param result_name title for plot user result signatures
#' @return Returns the comparisons
#' @examples
#' data(res)
#' compare_cosmic_v2(res, threshold = 0.7)
#' @export
compare_cosmic_v2 <- function(result, threshold = 0.9, metric = "cosine",
result_name = deparse(substitute(result))) {
signatures <- signatures(result)
comparison <- sig_compare(sig1 = signatures,
sig2 = signatures(cosmic_v2_sigs),
threshold = threshold, metric = metric)
result_subset <- methods::new("musica_result",
signatures =
signatures(result)[, comparison$x_sig_index,
drop = FALSE], exposures =
matrix(), type = get_result_type(result),
musica = musica(result),
tables = table_name(result))
other_subset <- methods::new("musica_result",
signatures =
signatures(
cosmic_v2_sigs)[, comparison$y_sig_index,
drop = FALSE],
exposures = matrix(), type = "NMF",
musica = musica(cosmic_v2_sigs),
tables = table_name(cosmic_v2_sigs))
.plot_compare_result_signatures(result_subset, other_subset,
res1_name = result_name,
res2_name = "COSMIC Signatures (V2)")
return(comparison)
}
#' Input a cancer subtype to return a list of related COSMIC signatures
#'
#' @param tumor_type Cancer subtype to view related signatures
#' @return Returns signatures related to a partial string match
#' @examples cosmic_v2_subtype_map ("lung")
#' @export
cosmic_v2_subtype_map <- function(tumor_type) {
subtypes <- c("adrenocortical carcinoma", "all", "aml", "bladder", "breast",
"cervix", "chondrosarcoma", "cll", "colorectum", "glioblastoma",
"glioma low grade", "head and neck", "kidney chromophobe",
"kidney clear cell", "kidney papillary", "liver", "lung adeno",
"lung small cell", "lung squamous", "lymphoma b-cell",
"lymphoma hodgkin", "medulloblastoma", "melanoma", "myeloma",
"nasopharyngeal carcinoma", "neuroblastoma", "oesophagus",
"oral gingivo-buccal squamous", "osteosarcoma", "ovary",
"pancreas", "paraganglioma", "pilocytic astrocytoma", "prostate",
"stomach", "thyroid", "urothelial carcinoma", "uterine carcinoma"
, "uterine carcinosarcoma", "uveal melanoma")
present_sig <- list(
c(1, 2, 4, 5, 6, 13, 18), c(1, 2, 5, 13), c(1, 5), c(1, 2, 5, 10, 13),
c(1, 2, 3, 5, 6, 8, 10, 13, 17, 18, 20, 26, 30), c(1, 2, 5, 6, 10, 13, 26),
c(1, 5), c(1, 2, 5, 9, 13), c(1, 5, 6, 10), c(1, 5, 11), c(1, 5, 6, 14),
c(1, 2, 4, 5, 7, 13), c(1, 5, 6), c(1, 5, 6, 27), c(1, 2, 5, 13),
c(1, 4, 5, 6, 12, 16, 17, 22, 23, 24), c(1, 2, 4, 5, 6, 13, 17),
c(1, 4, 5, 15), c(1, 2, 4, 5, 13), c(1, 2, 5, 9, 13, 17), c(1, 5, 25),
c(1, 5, 8), c(1, 5, 7, 11, 17), c(1, 2, 5, 13), c(1, 2, 5, 6, 13),
c(1, 5, 18), c(1, 2, 4, 5, 6, 13, 17), c(1, 2, 5, 7, 13, 29),
c(1, 2, 5, 6, 13, 30), c(1, 5), c(1, 2, 3, 5, 6, 13), c(1, 5), c(1, 5, 19),
c(1, 5, 6), c(1, 2, 5, 13, 15, 17, 18, 20, 21, 26, 28), c(1, 2, 5, 13),
c(1, 2, 5, 13, 22), c(1, 2, 5, 6, 10, 13, 14, 26), c(1, 2, 5, 6, 10, 13),
c(1, 5, 6)
)
partial <- grep(tumor_type, subtypes)
for (i in seq_len(length(partial))) {
print(subtypes[partial[i]])
print(present_sig[[partial[i]]])
}
}
.plot_compare_result_signatures <- function(res1, res2,
res1_name = "", res2_name = "") {
res1_plot <- plot_signatures(res1, legend = TRUE) +
ggplot2::ggtitle(res1_name)
legend <- cowplot::get_legend(res1_plot)
res1_plot <- res1_plot + theme(legend.position = "none")
res2_plot <- plot_signatures(res2, legend = FALSE) +
ggplot2::ggtitle(res2_name)
layout <- matrix(seq(2), ncol = 2, nrow = 9, byrow = TRUE)
layout <- rbind(layout, c(3,3))
g <- gridExtra::grid.arrange(res1_plot, res2_plot, legend,
layout_matrix = layout, ncol = 3,
widths = c(0.45, 0.45, 0.1))
return(g)
}
Any scripts or data that you put into this service are public.
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.