Skip to content

Scripts required to calculate tetramer frequencies and create input files for ESOM. See: Dick, G.J., A. Andersson, B.J. Baker, S.S. Simmons, B.C. Thomas, A.P. Yelton, and J.F. Banfield (2009). Community-wide analysis of microbial genome sequence signatures. Genome Biology, 10: R85

Notifications You must be signed in to change notification settings

tetramerFreqs/Binning

Repository files navigation

DOI

Binning

Scripts required to calculate tetramer frequencies and create input files for ESOM.
See: Dick, G.J., A. Andersson, B.J. Baker, S.S. Simmons, B.C. Thomas, A.P. Yelton, and J.F. Banfield (2009). Community-wide analysis of microbial genome sequence signatures. Genome Biology, 10: R85
Open Access: http://genomebiology.com/2009/10/8/R85

How to ESOM?

These instructions are for ESOM-based for binning: see http://databionic-esom.sourceforge.net/ for software download and manual.

  1. Generate input files.

  • Although not necessary but we recommend adding some reference genomes based on your 16s/OTU analysis as 'controls'. The idea is that, if the ESOM worked, your reference genome should form a bin itself. You may do this by downloading genomes in fasta format from any public database, preferably a complete single sequence genome.

  • Use the esomWrapper.pl script to create the relevant input files for ESOM. In order to run this script, you'll need to have all your sequence(in fasta format) files with the same extension in the same folder. For example: perl esomWrapper.pl -path fasta_folder -ext fa
    For more help and examples, type:
    perl esomWrapper.pl -h

  • The script will use the fasta file to produce three tab-delimited files that ESOM requires:

  • Learn file = a table of tetranucleotide frequencies (.lrn)

  • Names file = a list of the names of each contig (.names)

  • Class file = a list of the class of each contig, which can be used to color data points, etc. ( .cls)

NOTE:class number: The esom mapping requires that you define your sequences as classes. We generally define all the sequences that belong to your query (meatgenome for example) as 0 and all the others 1, 2 and so on. think of these as your predefined bins, each sequence that has the same class number will be assigned the same color in the map.

  • These files are generated using Anders Anderssons perl script tetramer_freqs _esom.pl which needs to be in the same folder as the esomWrapper.pl. To see how to use the tetramer_freqs _esom.pl independent of the wrapper, type: perl tetramer_freqs _esom.pl -h
  1. Run ESOM:

  • On you termial, run w/ following command from anywhere (X11 must be enabled):
    ./esomana
  • Load .lrn, .names, and .cls files (File > load .lrn etc.)
  • Normalize the data(optional, but recommended): under data tab, see Z-transform, RobustZT, or To[0,1] as described in the users manual. I find that this RobustZT makes the map look cleaner.
  1. Train the data:

###Using the GUI

  • Tools > Training:
  • Parameters: use default parameters with the following exceptions. Note this is what seems work best for AMD datasets but the complete parameter space has not been fully optimized. David Soergel (Brenner Lab) is working on this:
  • Training algorithm: K-batch
  • Number of rows/columns in map: I use ~5-6 times more neurons than there are data points. E.g. for 12000 data points (window, NOT contigs) I use 200 rows x 328 columns (~65600 neurons).
  • Start value for radius = 50 (increase/decrease for smaller/larger maps).
  • I've never seen a benefit to training for more than 20 epochs for the AMD data.
  • Hit 'START' -- training will take 10 minutes to many hours depending on the size of the data set and parameters used.

###From the terminal

  • At this point, you may also choose to add additional data (like coverage) to your contigs. You may do so using the addInfo2lrn.pl script OR by simply using the flag -info in esomTrain.pl.
  • esomTrain.pl script maybe used to train the data without launching the GUI. This script will add the additional information to the lrn file (using -info), normalize it and train the ESOM. Type perl esomTrain.pl -h in your terminal to see the help document for this script.
  • To view the results of the training, simply launch ESOM by following the instructions in Step 5: Loading a previous project to load the relevant files.
  • Resume analysis from Step 4: Analyzing the output
  1. Analyzing the output:

  • Best viewed (see VIEW tab) with UMatrix background, tiled display. Use Zoom, Color, Bestmatch size to get desired view. Also viewing without data points drawn (uncheck "Draw bestmatches") helps to see the underlying data structure.
  • Use CLASSES tab to rename and recolor classes.
  • To select a region of the map, go to DATA tab then draw a shape with mouse (holding left click), close it with right click. Data points will be selected and displayed in DATA tab.
  • To assign data points to bins, use the CLASS tab and using your pointer draw a boundary around the region of interest (e.g. using the data structure as a guide -- see also "contours" box in VIEW tab which might help to delineate bins). This will assign each data point to a class (bin). The new .cls file can be saved (File > Save .cls) for further analysis.
  1. Loading a previous project:

  • On you termial, run w/ following command from anywhere (X11 must be enabled): ./esomana
  • File > load .wts

Questions?

  • Gregory J. Dick,
    gdick [AT] umich [DOT] edu,
    Assistant Professor, Michigan Geomicrobiology Lab,
    University of Michigan
  • Sunit Jain,
    sunitj [AT] umich [DOT] edu,
    Bioinformatics Specialist, Michigan Geomicrobiology Lab,
    University of Michigan.

About

Scripts required to calculate tetramer frequencies and create input files for ESOM. See: Dick, G.J., A. Andersson, B.J. Baker, S.S. Simmons, B.C. Thomas, A.P. Yelton, and J.F. Banfield (2009). Community-wide analysis of microbial genome sequence signatures. Genome Biology, 10: R85

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages