GeneSpring GX 11, or how to make the simple – undocumentable..
Posted by The Blog Swan in My Work, science, tags: bugfix, genespring, help, microarrayI divide my time about equally between GeneSpring GX 11 from Agilent and BioConductor (free, from awesome people) for microarray analysis. The latter for all the neat tools that GeneSpring doesn’t have, the former because sometimes it is nice to lead a researcher visually through their data, without having to type into a green on black terminal window.
GeneSpring GX 11 is the third iteration after Agilent bought up Silicon Genetics, then decided to throw the unwieldy, quirky, but very functional GeneSpring product in the trash and start again with something built on Strand Life Sciences AVADIS platform. We’ve been through versions 9, 10 and now we’re on 11. There’s been plenty of bugs on the way, the most serious (to me) being the one where GeneSpring 10 managed to miscall the quality flags on Illumina data in 50% of the cases. Not good, but at least fixed.
Many people have been griping on mailing lists about functionality missing in the new GeneSpring that existed in the old version. I always think it’s a matter of familiarity with the software really. I hadn’t really come across anything I couldn’t do in GeneSpring 11 that I could do in GeneSpring 7. That was until yesterday.
I sat down with a customer yesterday to look at some microbial Nimblegen data. GeneSpring doesn’t really deal with Nimblegen data very well, you are left with the choice of not analysing it in GeneSpring, or accepting there’s going to be a bit of fudging and some extra annotation steps in order to make the data useable as a ‘Custom technology’. The customer, quite reasonably, asked if we could get the biological genome information (effectively gene annotations that are independent of the chip technology you’re using) loaded into GeneSpring. And thus started a morning of fun and games.
GeneSpring 11 has a very handy import feature for biological genomes under Annotations>Create Biological Genome. That is providing you want to choose one of their predefined organisms to download the information from NCBI. There is *NO* route in the software to add another organism to this list, or do anything than use one of their check box limited organisms. This is not a bug apparently, because in a separate part of the software (dealing with Pathways for an organism) you can pull this information directly from NCBI using the Taxon ID of the organism you’re interested in. So why can’t you use it to download a biological genome? Who knows…
One of the things I really liked about the old GeneSpring was the fact that it came with a manual a foot thick. It told you how to do every single operation in the UI, it didn’t tell you anything about the order in which to apply them, but you could generally rely on it for an answer. There was no such answer to this issue in the GeneSpring manual..
It transpires that if you really want to do this, the following, slightly insane process needs to take place:
1) Take this snippet of XMLishness:
<hexff version="1.0">
<object type="cube.plugin" version="1.0" handle="0">
<key>type</key>
<string>plugin.product.TaxID</string>
<key>id</key>
<string>TaxID</string>
<key>data</key>
<!-- taxID.xml for various organisms {{{ -->
<dict>
<key>Homo sapiens</key><string>9606</string>
<key>Mus musculus</key><string>10090</string>
<key>Rattus norvegicus</key><string>10116</string>
<key>Anopheles gambiae</key><string>7165</string>
<key>Arabidopsis thaliana</key><string>3702</string>
<key>Bacillus subtilis</key><string>1423</string>
<key>Bos taurus</key><string>9913</string>
<key>Caenorhabditis elegans</key><string>6239</string>
<key>Canis lupus familiaris</key><string>9615</string>
<key>Citrus sinensis</key><string>2711</string>
<key>Danio rerio</key><string>7955</string>
<key>Drosophila melanogaster</key><string>7227</string>
<key>Equus caballus</key><string>9796</string>
<key>Escherichia coli</key><string>562</string>
<key>Felis catus</key><string>9685</string>
<key>Gallus gallus</key><string>9031</string>
<key>Glycine max</key><string>3847</string>
<key>Gossypium hirsutum</key><string>3635</string>
<key>Hordeum vulgare</key><string>4513</string>
<key>Macaca mulatta</key><string>9544</string>
<key>Magnaporthe grisea</key><string>148305</string>
<key>Medicago sativa</key><string>3879</string>
<key>Medicago truncatula</key><string>3880</string>
<key>Nicotiana tabacum</key><string>4097</string>
<key>Oryctolagus cuniculus</key><string>9986</string>
<key>Oryza sativa</key><string>4530</string>
<key>Ovis aries</key><string>9940</string>
<key>Pan troglodytes</key><string>9598</string>
<key>Plasmodium falciparum</key><string>5833</string>
<key>Pongo abelii</key><string>9601</string>
<key>Poplar mosaic virus</key><string>12166</string>
<key>Populus sp.</key><string>3697</string>
<key>Pseudomonas aeruginosa</key><string>287</string>
<key>Saccharomyces cerevisiae</key><string>4932</string>
<key>Saccharum officinarum</key><string>4547</string>
<key>Salmo salar</key><string>8030</string>
<key>Schizosaccharomyces pombe</key><string>4896</string>
<key>Staphylococcus aureus</key><string>1280</string>
<key>Sus scrofa</key><string>9823</string>
<key>Takifugu rubripes</key><string>31033</string>
<key>Lycopersicon esculentum</key><string>4081</string>
<key>Triticum aestivum</key><string>4565</string>
<key>Vitis vinifera</key><string>29760</string>
<key>Xenopus laevis</key><string>8355</string>
<key>Xenopus tropicalis</key><string>8364</string>
<key>Zea mays </key><string>4577</string>
</dict>
<!-- }}} -->
</object>
</hexff>
2) Add an entry
<key>Your organism name</key><string>NCBI Taxon ID</string>
after the Zea mays line
3) In your GeneSpring directory under this tree:
GeneSpring GX11\bin\packages\marray\project\2.1
Create a folder called ‘plugins’ and save the edited XML above as a file called TaxID.plg
4) Restart GeneSpring and proceed to update your newly added Biological genome, which now appears in the list!
Actually, I have to say, I’m not sure I ever want to see that in a manual of a piece of software as expensive as GeneSpring… And besides this still doesn’t work for me as advertised because GeneSpring, whilst aware of what an HTTP proxy might conceivably be, has no concept of what an FTP proxy might be – which is problematic when you need to connect to ftp.ncbi.nlm.nih.gov. Brilliant!
Entries (RSS)