#' @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")
}
}
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.