R/expression_plot.R

Defines functions expression_plot

Documented in expression_plot

#' @title Expression Plot
#' @description Displays the level of expression of a gene in each cell on the 2D projected data.
#'
#' @details This function displays the expression level of a gene of interest on
#' a 2D projection.
#' @details
#' `name` can be any character that corresponds to a row name
#' of `data`.
#' @details
#' `tsne` corresponds to the 2D coordinates for each cell. Although
#' t-SNE maps are widely used to display cells on a 2D projection, the user
#' can provide any table with two columns and a number of rows equal to the
#' number of columns of *data* (i.e. the two first components of a PCA).
#' @details
#' `colors` must be "default", "rainbow" or "heat" exclusively. "rainbow" and
#' "heat" are the color palettes provided in R.
#'
#' @param data a data frame of n rows (genes) and m columns (cells) of read or UMI counts (note : rownames(data)=genes)
#' @param name the identifier of the gene of interest
#' @param tsne a table of n rows and 2 columns with 2D projection coordinates for each cell
#' @param colors "default" returns the default colorpanel, also accepts "rainbow" or "heat"
#'
#' @return The function returns a R plot.
#' @export
#' @importFrom gplots colorpanel
#'
#' @examples
#' data <- matrix(runif(5,0,1),ncol=5)
#' data[2] <- data[5] <- 0
#' rownames(data) <- "gene 1"
#' tsne <- matrix(runif(10,0,1),ncol=2)
#' expression_plot(data,"gene 1",tsne)
#'
expression_plot <- function(data,name,tsne,colors=c("default","rainbow","heat")){
  options(warn=-1)
  colors <- match.arg(colors)
  opar <- par()
  if (is.element(name,rownames(data))==TRUE){
    a <- as.numeric(data[name,])
    a <- a*100/max(a)
    a <- log(5*a+1)
    if (sum(is.na(a))==0){
      if (sum(as.numeric(data[name,]))==0){
        print("No expression")
      }
      if (sum(as.numeric(data[name,]))!=0){
        a <- a+1
        if (colors=="default"){
          cr <- colorpanel(max(a),"lightblue","gray90","#CC0033")
        }
        if (colors=="rainbow"){
          cr <- rainbow(max(a))
        }
        if (colors=="heat"){
          cr <- heat.colors(max(a))
        }
        par(mar=c(5.1, 4.1, 4.1, 8))
        plot(x=tsne[,1],y=tsne[,2],type="n",main=list(name,cex=3, col="black", font=3),xlab="t-SNE1",ylab="t-SNE2")
        bx <- par("usr")
        abline(h=0)
        abline(v=0)
        if (sum(a==1)!=0){
          if (sum(a==1)==1){
            symbols(x=tsne[a==1,1],y=tsne[a==1,2],circles=rep(1,1),inches=0.05,bg=cr[a[a==1]],fg="gray20",add=TRUE)
          } else {
            symbols(x=tsne[a==1,1],y=tsne[a==1,2],circles=rep(1,nrow(tsne[a==1,])),inches=0.05,bg=cr[a[a==1]],fg="gray20",add=TRUE)
          }
        }
        symbols(x=tsne[a!=1,1],y=tsne[a!=1,2],circles=rep(1,nrow(tsne[a!=1,])),inches=0.05,bg=cr[a[a!=1]],fg="gray20",add=TRUE)
        n <- length(cr)
        Y <- bx[3]
        mY <- (bx[4] + bx[3])/2
        dX <- bx[2] - bx[1]
        dY <- bx[4] - bx[3]
        dy <- dY /length(cr)
        dx <- 0.1*dX
        x0 <- bx[2]+dx*0.8
        for (i in seq_len(n)){
          polygon(c(x0,x0+dx,x0+dx,x0), c(Y+(i-1)*dy,Y+(i-1)*dy,Y+i*dy,Y+i*dy), col=cr[i], border=cr[i],xpd=NA)
        }
        mtext("Expression level", side=4,at=mY,xpd=NA,line=+5,cex=1.6)
        mtext("-", side=4,at=Y,xpd=NA,line=+5,cex=1.6,adj=1)
        mtext("+", side=4,at=bx[4],xpd=NA,line=+5,cex=1.6)
        par(opar)
      } else {print("NA not supported")}
    }
  } else {
    print("Change name")
  }
}
SCA-IRCM/SingleCellSignalR documentation built on Dec. 11, 2022, 2:30 p.m.