I have two or more lists of genes that I want to compare. If I compare strings directly, I could run into trouble if there is slight variation (e.g., SLC6A4 vs. SLC6A9). I could also look at functional annotation, but that still doesn’t give me a nice visualization of “how close are these two sets?.” What I basically want is a nice snapshot of where the genes are in relation to one another.
This is a job for… Cytogenetic Mapping!
A cytogenetic map historically means chromosomes stained under a microscope. Let’s be real. Most of us don’t work with microscopes, and thus a cytogenetic map is simply a mapping of something (genes, SNP’s, etc) to chromosomes. I would like to create these maps with d3 (to allow for interactive graphics), however a rule of thumb when you are a noob at anything is to start simple. So today we will do the following:
- Start with gene lists
- Look up chromosome id and position
- Create a static cytogenetic map with an easy-to-use software solution
An important note! We will be mapping the **starting position of genes, since we are working with full genes and not SNPs. This means that the genes may take up more real estate on the chromosomes than the map indicates.
Writing a Script in R
R can do my laundry for me, so it sure as heck can do this simple task:
library('biomaRt')
# Set our output and present working directory setwd('/home/vanessa/Documents/Work/GENE_EXPRESSION/neurosynth/results/sigresults/')
# Prepare biomart to look up chromosome information from gene # What marts are available?
listMarts()
# Get ensemble object
ens = useMart('ensembl')
# What databases are there?
listDatasets(ens)
# Get the human database
human = useMart('ensembl', dataset = 'hsapiens_gene_ensembl')
# What attributes can I get?
listAttributes(human)
# Each file has a single line of genes, separated by tab
genelists = list.files('visualization/genelis',pattern='*txt')
for (g in genelists){
# The name of the file will be our phenotype label
geneset = gsub('.txt','',g)
genes = strsplit(readLines(paste("visualization/genelist/",g,sep='')),sep='\t')
# This is the command to look up the chromosome name and position
chr = getBM(attributes= c('hgnc_symbol','chromosome_name', 'start_position'), filters='hgnc_symbol',values=genes,mart=human)
# Get rid of the weird ones
idx = grep('PATCH|LRG|HSCHR|HG&',chr$chr)
if (length(idx) != 0){
chr = chr[-idx,]
}
# Add label column
chr = cbind(chr,rep(geneset,nrow(chr)))
colnames(chr) = c('annotation','chr','pos','phenotype')
# Write single disorder to output file
write.table(chr,file=paste('visualization/geneChromosomeTable',geneset,'.txt',sep=''),row.names=FALSE,sep='\t',quote=FALSE)
}
</pre>
## Creating the Map
You can combine different gene lists from the output files if you want more than one phenotype in your map. It’s then simply a matter of [using this tool to show you map](http://visualization.ritchielab.psu.edu/phenograms/plot). It’s so easy! [![phenogramDisorderSubset](http://vsoch.com/blog/wp-content/uploads/2014/07/phenogramDisorderSubset-1024x682.png)](http://vsoch.com/blog/wp-content/uploads/2014/07/phenogramDisorderSubset.png)
## When is this a good idea?
I’m not great at visualization, but I want to be. The first question I’ve been asking myself is “What do I want to show?” I think it’s easy to get sucked into wanting to make some crazy cool network without actually thinking about what you are trying to communicate to your viewer. Don’t do that! Once you know what you want to show, the second question is “Does this strategy achieve that?” We already know we want to show physical proximity for different gene sets, if we can justify that closeness == relatedness. With this in mind, when will the static cytogenetic map be a good visualization strategy? It will be good when…
- **you have a small number of genes or SNPs**: too many things to plot means a visually overwhelming graphic that just isn’t that meaningful
- **you have more phenotypes: **The strength of this visual is to show the relationship between multiple phenotypes
- **chromosome position is meaningful: **if physical closeness isn’t useful or related to what you are trying to show, this is pretty useless
## How can I do better?
This is a good start, but I’d really like this interactive. I’ll start by incorporating these static plots into a d3 visualization, and ultimately (hopefully) have these maps be integrated into the d3 as well. As always, start simple, and grow from that! :)
Suggested Citation:
Sochat, Vanessa. "Create Cytogenetic Maps from Gene Lists." @vsoch (blog), 13 Jul 2014, https://vsoch.github.io/2014/create-cytogenetic-maps-from-gene-lists/ (accessed 22 Dec 24).