Nothing
#'Flexible logoplot wrapper
#'
#' @description Plots a logoplot of the CDR3 aminoacid region
#' @param cdr3.vector A character vector of aa sequences. This is to increase flexibility of this function. Such a sequence vector may be retrieved from the VDJ_analyse function output on a clonotype level or from the VDJ_GEX_matrix function output on a per cell level. Additionally, any length of sequence may be used (e.g. HCDR3 only or H and LCDR3 pasted together)
#' @param length_cdr3 Integer or character. Defaults to "auto". Sets the length of the CDR3 regions that are selected to be plotted. If set to auto, the most frequently appearing length in the vector will be used
#' @param seq_type passed to ggseqlogo. Can be set to "aa", "dna", "rna" or "other"
#' @param namespace passed to ggseqlogo. Default "auto".
#' @param font passed to ggseqlogo. Default "roboto_medium".
#' @param method passed to ggseqlogo. Default "bits".
#' @return Returns the logo plot.
#' @export
#' @examples
#' VDJ_logoplot_vector(
#' cdr3.vector = Platypus::small_vgm[[1]]$VDJ_cdr3s_aa
#' ,length_cdr3 = "auto",seq_type = "auto")
#'
VDJ_logoplot_vector <- function(cdr3.vector,
length_cdr3,
seq_type,
namespace,
font,
method) {
if(missing(length_cdr3)) length_cdr3 <- "auto"
if(missing(seq_type)) seq_type <- "auto"
if(missing(namespace)) namespace <- NULL
if(missing(font)) font <- 'roboto_medium'
if(missing(method)) method <- 'bits'
cdr3.vector <- as.character(cdr3.vector)
cdr3.vector[is.na(cdr3.vector)] <- ""
if("" %in% cdr3.vector){
cdr3.vector <- cdr3.vector[-c(which(cdr3.vector == ""))]}
if(length_cdr3 == "auto"){
length_cdr3 <- as.numeric(names(which.max(table(nchar(cdr3.vector)))))
} else if (length_cdr3 < min(nchar(cdr3.vector))) {
length_cdr3 <- min(nchar(cdr3.vector))
} else if (length_cdr3 > max(nchar(cdr3.vector))) {
length_cdr3 <- max(nchar(cdr3.vector))
}
if(!as.character(length_cdr3) %in% names(table(nchar(cdr3.vector)))){
message("No CDR3s of chosen length present. Setting length_cdr3 to mode of length of input sequences")
length_cdr3 <- as.numeric(names(which.max(table(nchar(cdr3.vector)))))
}
message(paste0("Returning logoplot based on ", length(cdr3.vector[which(nchar(cdr3.vector)==length_cdr3)]), " sequences of a total ", length(cdr3.vector), " input sequences"))
return(ggseqlogo::ggseqlogo(cdr3.vector[which(nchar(cdr3.vector)==length_cdr3)], method=method, seq_type= seq_type, namespace=namespace, font= font))
}
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.