- Open Access
mSpecs: a software tool for the administration and editing of mass spectral libraries in the field of metabolomics
BMC Bioinformaticsvolume 10, Article number: 229 (2009)
Metabolome analysis with GC/MS has meanwhile been established as one of the "omics" techniques. Compound identification is done by comparison of the MS data with compound libraries. Mass spectral libraries in the field of metabolomics ought to connect the relevant mass traces of the metabolites to other relevant data, e.g. formulas, chemical structures, identification numbers to other databases etc. Since existing solutions are either commercial and therefore only available for certain instruments or not capable of storing such information, there is need to provide a software tool for the management of such data.
Here we present mSpecs, an open source software tool to manage mass spectral data in the field of metabolomics. It provides editing of mass spectra and virtually any associated information, automatic calculation of formulas and masses and is extensible by scripts. The graphical user interface is capable of common techniques such as copy/paste, undo/redo and drag and drop. It owns import and export filters for the major public file formats in order to provide compatibility to commercial instruments.
mSpecs is a versatile tool for the management and editing of mass spectral libraries in the field of metabolomics. Beyond that it provides capabilities for the automatic management of libraries though its scripting functionality. mSpecs can be used on all major platforms and is licensed under the GNU General Public License and available at http://mspecs.tu-bs.de.
Metabolomics, the comprehensive analysis of metabolites present in a biological sample [1, 2], is technically one of the most challenging fields in systems biology. While genetics has to handle the four digit code chemistry of the nucleic acids and proteomics the 20 letter code of amino acids [1, 3], there are several thousands of metabolites with diverse organochemical properties known .
For the identification and quantification of metabolites a number of techniques have been available . Besides nuclear magnetic resonance [5, 6] and optical spectroscopies, e.g. Raman- and Fourier transform infra-red spectroscopy , a major part of the methods rely on chromatographic separation, either by gas chromatography, liquid chromatography or capillary electrophoresis, followed by a mass spectroscopic characterization of the substances . During gas chromatography coupled to mass spectroscopy (GC/MS ) the boiling points of the compounds are usually decreased by derivatization prior to measurement in order to provide a higher yield in detection [4, 9].
The detection of metabolites is typically accomplished by the comparison of obtained mass spectra and their retention time or retention index value with standards pooled in a library [9, 10]. While this information may be sufficient for the identification, in many cases there is a need to add additional data to a library entry. One common task is e.g. to draw data attained from experiments onto metabolic pathway maps, and there are several tools to handle such maps, e.g. VANTED  and Cytoscape . However, for the automatic mapping of the data it is necessary to connect a standard in a library to a metabolite on the pathway map, e.g. by utilizing its KEGG compound number .
For the maintaining of libraries there are several tools available, from which NIST MS Search  and AMDIS  are the most common ones. However, the possibilities to edit and manage mass spectra as well as associated information are limited. None of the programs is capable of handling more than two libraries at the same time, performing complex sort and filter options and automated operation via scriptable commands. Furthermore the data fields lack important areas such as multiple reference ions for quantification, KEGG compound numbers, InChI codes  or systems biology data like associated reactions, enzymes or genes. Therefore we present mSpecs, an open source based software for the manual and automated management of libraries used in chromatography/mass spectroscopy approaches.
mSpecs is released under the GNU General Public License  and was programmed using C++ and the Qt4-framework . It can be compiled on all major platforms including Windows, Linux and MacOS X. An installer package for Windows platforms as well as documentation and source code is provided on the website of the project.
mSpecs provides an easy-to-use graphical user interface (see figure 1). The workspace is divided into three pages (or tabs), on which data can be entered. The entries of the library are listed in a separate table on the left side, which can be undocked from the main window and moved to an arbitrary screen location. The given data fields cover all areas of interest, including viewing the spectrum in visual and tabular form, information such as retention time and Kováts retention index , identification numbers, e.g. from KEGG , ChemSpider  or HMDB  other chemical data like SMILES-codes , monoisotopic masses  and the author's name or the date of measurement. A complete overview can be found in table 1. Since in the field of GC/MS it is often necessary to maintain the information of two chemical entities, the metabolite and its derivative, data fields for both substances are provided.
Capabilities of the user interface
Each of the data fields can be activated or deactivated using the built-in settings dialog and the user interface will dynamically fit to the available space. This way, the scientist is able to adapt the interface to his needs without losing data in the hidden fields.
There is no limit to the number of open files and the user is able to copy and paste or drag and drop entries between the libraries. Any user input can generally be undone by the program's undo/redo functionalities. In order to navigate through the list of entries, there are multiple sort and filter options available (see table 1). The maximum number of simultaneously maintained entries depends only on the size of the main memory of the computer. Assuming one gigabyte of free memory and an average size of an entry from four to 40 kilobytes, there are 25,000 to 250,000 entries that can be maintained simultaneously. Bearing in mind that the NIST MS library , one of the largest mass spectral libraries available, contains about 191,000 spectra, this should be enough for most of the tasks.
Much of the data is entered in simple text boxes. However, certain information cannot be stored in simple text strings, so that a special treatment is applied. An example is the graphical representation of the structures of metabolite and derivative. Structures can be imported in MDL mol file  or CML  version 1 or 2 format and can be displayed. Furthermore structures can be exported in MDL mol file, CML version 1 and 2, scalable vector graphics  and several image formats such as jpeg.
It is possible to compute the molecular formula from the structure, the molecular weight of the component or the monoisotopic mass of the derivative based on the formula and furthermore the Kováts retention index  starting from the retention time and a reference list of alkanes. Moreover certain fields like the identification numbers or the fields in the systems biology area (see table 1) provide a link to corresponding information on the internet.
Loading and saving of libraries
mSpecs provides various import and export options. In Addition to its own binary format, which is optimized for fast disk operations while maintaining small size, mSpecs is able to load and save the AMDIS/NIST mass spectral format , which is also supported by the Xcalibur software package from Thermo Scientific . As a second file format JCAMP-DX  is supported, which again can be used together with the ChemStation software by Agilent Technologies .
A major part of the data fields can be exported into a tab-delimited text file, which then can be viewed in spreadsheet software. An export into the portable document format (pdf)  as well as printing is also possible. Furthermore mSpecs provides an implementation of the extensible markup language (xml) , which serves as an interexchange format for prospective developments.
Automation using scripts
This is a demo script to illustrate the automated operation of mSpecs.
// process every entry in the active library.
for (var i = 0; i < library.length; ++i)
// get structure of the actual component.
var molecule = library.at(i).moleculeComponent;
// calculate chemical formula from the structure.
var formula = tools.calculateFormulaFromStructure(molecule);
// store formula in the corresponding data field.
library.at(i).formula = formula;
Our primary goal is to provide further interoperability with other tools like MetaQuant  or Bioclypse  in order to make mSpecs usable for a larger community. The data fields, the user interface and the scripting functionalities will be extended on the basis of user feedback. More vendor-specific file formats will be supported depending on available implementation details. We are currently working on a suite to view and analyze data obtained from GC/MS or LC/MS-experiments similar to AMDIS , but with more possibilities such as handling high-resolution mass spectroscopic data. mSpecs will be part of this suite as a library maintaining tool.
Discussion and conclusion
mSpecs is a versatile tool for the management and editing of mass spectral libraries in the field of metabolomics. Beyond that it provides capabilities for the automatic management of libraries though its scripting functionality. mSpecs can be used on all major platforms and is licensed under the GNU General Public License and available at http://mspecs.tu-bs.de
Availability and requirements
Project name: mSpecs;
Project home page: http://mspecs.tu-bs.de;
Operating system(s): platform independent;
Programming language: C++; Other requirements: Qt 4.4 (or higher);
License: GNU GPL
gas chromatography – mass spectrometry
liquid chromatography – mass spectrometry.
Fiehn O: Metabolomics – the link between genotypes and phenotypes. Plant Molecular Biology 2002, 48: 155–171. 10.1023/A:1013713905833
Weckwerth W: Metabolomics in systems biology. Annual Review of Plant Biology 2003, 54: 669–689. 10.1146/annurev.arplant.54.031902.135014
Glassbrook N, Beecher C, Ryals J: Metabolic profiling on the right path. Nature Biotechnology 2000, 18: 1142–1143. 10.1038/81116
Kopka J, Fernie A, Weckwerth W, Gibon Y, Stitt M: Metabolite profiling in plant biology: platforms and destinations. Genome Biology 2004, 5: s109. 10.1186/gb-2004-5-6-109
Kell DB: Metabolomics and systems biology: making sense of the soup. Current Opinion in Microbiology 2004, 7: 296–307. 10.1016/j.mib.2004.04.012
Krishnan P, Kruger NJ, Ratcliffe RG: Metabolite fingerprinting and profiling in plants using NMR. Journal of Experimental Botany 2005, 56: 255–265. 10.1093/jxb/eri010
Dunn WB, Bailey NJ, Johnson HE: Measuring the metabolome: current analytical technologies. The Analyst 2005, 130: 606–625. 10.1039/b418288j
Strelkov S, von Elstermann M, Schomburg D: Comprehensive analysis of metabolites in Corynebacterium glutamicum by gas chromatography/mass spectrometry. Biological Chemistry 2004, 385: 853–861. 10.1515/BC.2004.111
Halket JM, Waterman D, Przyborowska AM, Raj PKP, Fraser PD, Bramley PM: Chemical derivatization and mass spectral libraries in metabolic profiling by GC/MS and LC/MS/MS. Journal of Experimental Botany 2005, 56: 219–243. 10.1093/jxb/eri069
Kováts E: Gas-chromatographische Charakteriserung organischer Verbindungen.Teil 1: Retentionsindices aliphatischer Halogenide, Alkohole, Aldehyde und Ketone. Helvetica Chimica Acta 1958, 41: 1915–1932. 10.1002/hlca.19580410703
Junker BH, Klukas C, Schreiber F: VANTED: a system for advanced data analysis and visualization in the context of biological networks. BMC Bioinformatics 2006, 7: s109. 10.1186/1471-2105-7-109
Shannon P, Markiel A, Ozier O, Baliga NS, Wang JT, Ramage D, Amin N, Schwikowski B, Ideker T: Cytoscape: a software environment for integrated models of biomolecular interaction networks. Genome Research 2003, 13: 2498–2504. 10.1101/gr.1239303
Ogata H, Goto S, Sato K, Fujibuchi W, Bono H, Kanehisa M: KEGG: Kyoto Encyclopedia of Genes and Genomes. Nucleic Acids Research 1999, 27: 29–34. 10.1093/nar/27.1.29
National Institute of Standards and Technology: NIST Standard Reference Database 1A.[http://www.nist.gov/data/nist1a.htm]
Stein SE, Mallard G: AMDIS.[http://chemdata.nist.gov/mass-spc/amdis/]
Heller S, Stein S, Tchekhovskoi D: InChI: Open access/open source and the IUPAC international chemical identifier. Abstracts of the Papers of the American Chemical Society 2005, 230: U1025-U1026.
GNU Operating System: GNU General Public License.[http://www.gnu.org/licenses/gpl.html]
Nokia: Qt – A cross-platform application and UI framework.[http://www.qtsoftware.com/]
Wishart DS, Tzur D, Knox C, Eisner R, Guo AC, Young N, Cheng D, Jewell K, Arndt D, Sawhney S, Fung C, Nikolai L, Lewis M, Coutouly M, Forsythe I, Tang P, Shrivastava S, Jeroncic K, Stothard P, Amegbey G, Block D, Hau DD, Wagner J, Miniaci J, Clements M, Gebremedhin M, Guo N, Zhang Y, Duggan GE, Macinnis GD, Weljie AM, Dowlatabadi R, Bamforth F, Clive D, Greiner R, Li L, Marrie T, Sykes BD, Vogel HJ, Querengesser L: HMDB: the Human Metabolome Database. Nucleic Acids Research 2007, 35: D521-D526. 10.1093/nar/gkl923
Weininger D: SMILES, a chemical language and information system. 1. Introduction to methodology and encoding rules. Journal of Chemical Information and Computer Sciences 1988, 28: 31–36.
Yergey J, Heller D, Hansen G, Cotter RJ, Fenselau C: Isotopic Distributions in Mass Spectra of Large Molecules. Analytical Chemistry 1983, 55: 353–356. 10.1021/ac00253a037
Dalby A, Nourse JG, Hounshell DW, Gushurst AK, Grier DL, Leland BA, Laufer J: Description of several chemical structure file formats used by computer programs developed at Molecular Design Limited. Journal of Chemical Information and Computer Sciences 1992, 32: 244–255.
Murray-Rust P, Rzepa HS, Whitaker BJ: The World-Wide Web as a chemical information tool. Chemical Society Reviews 1997, 26: 1–10. 10.1039/cs9972600001
World Wide Web Consortium: Scalable vector graphics.[http://www.w3.org/Graphics/SVG/]
Thermo Sceintific: Xcalibur.[http://www.thermo.com/com/cda/product/detail/0,1055,1000001009250,00.html]
Lampen P, Hillig H, Davies AN, Linscheid M: JCAMP-DX for Mass Spectrometry. Applied Spectroscopy 1994, 48: 1545–1552.
Agilent Technologies: Chemstation.[http://www.chem.agilent.com/scripts/pds.asp?lpage=282]
Adobe: Adobe PDF Technology Center.[http://www.adobe.com/devnet/pdf/pdf_reference.html]
World Wide Web Consortium: Extensible Markup Language (XML).[http://www.w3.org/XML/]
ECMA International: Standard ECMA-262.[http://www.ecma-international.org/publications/standards/Ecma-262.htm]
Bunk B, Kucklick M, Jonas R, Münch R, Schobert M, Jahn D, Hiller K: MetaQuant: a tool for the automatic quantification of GC/MS-based metabolome data. Bioinformatics 2006, 22: 2962–2965. 10.1093/bioinformatics/btl526
Spjuth O, Helmus T, Willighagen EL, Kuhn S, Eklund M, Wagener J, Murray-Rust P, Steinbeck C, Wikberg JES: Bioclipse: an open source workbench for chemo- and bioinformatics. BMC Bioinformatics 2007, 8: s59. 10.1186/1471-2105-8-59
Stein SE: An Integrated Method for Spectrum Extraction and Compound Identification from Gas Chromatography/Mass Spectrometry Data. Journal of the American Society of Mass Spectrometry 1999, 10: 770–781. 10.1016/S1044-0305(99)00047-1
This work was funded by the German Federal Ministry of Education and Research (BMBF) for the National Genome Research Network (NGFN2-EP, 15 Grant No. 0313398A) and by ENFIN, a Network of Excellence funded by the European Commission within the FP6 programs, under the thematic area "Life sciences, genomics and biotechnology for health", contract number LSHGCT-2005-518254.P.
BT carried out the major part of the program design and did the major part of the programming. SH participated in the design and testing of the program. DS consulted and supervised the project. All authors read and approved the final manuscript.
Authors’ original submitted files for images
Below are the links to the authors’ original submitted files for images.