changeset 0:64d45f959303

Uploaded
author jjohnson
date Mon, 11 Nov 2013 13:54:43 -0500
parents
children 1ff2fc8da328
files datatypes_conf.xml rsem.py rsem_calculate_expression.xml rsem_prepare_reference.xml tool-data/rsem_indices.loc.sample tool_data_table_conf.xml.sample tool_dependencies.xml
diffstat 7 files changed, 824 insertions(+), 0 deletions(-) [+]
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/datatypes_conf.xml	Mon Nov 11 13:54:43 2013 -0500
@@ -0,0 +1,10 @@
+<?xml version="1.0"?>
+<datatypes>
+    <datatype_files>
+        <datatype_file name="rsem.py"/>
+    </datatype_files>
+    <registration>
+        <datatype extension="rsem_ref" type="galaxy.datatypes.rsem:RsemReference" display_in_upload="True"/>
+    </registration>
+</datatypes>
+
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/rsem.py	Mon Nov 11 13:54:43 2013 -0500
@@ -0,0 +1,83 @@
+"""
+SnpEff datatypes
+"""
+import os,os.path,re,sys
+import galaxy.datatypes.data
+from galaxy.datatypes.images import Html
+from galaxy.datatypes.metadata import MetadataElement
+
+class RsemReference( Html ):
+    """Class describing an RSEM reference"""
+    MetadataElement( name='reference_name', default='galaxy_generated_bowtie_index', desc='RSEM Reference Name', readonly=True, visible=True, no_value=None )
+
+    file_ext = 'rsem_ref'
+    is_binary = True
+    composite_type = 'auto_primary_file'
+    allow_datatype_change = False
+
+    def generate_primary_file( self, dataset = None ):
+        """
+        This is called only at upload to write the html file
+        cannot rename the datasets here - they come with the default unfortunately
+        """
+        return '<html><head></head><body>AutoGenerated Primary File for RSEM Reference Composite Dataset</body></html>'
+
+    def regenerate_primary_file(self,dataset):
+        """
+        cannot do this until we are setting metadata
+        """
+        refname = dataset.metadata.reference_name
+        flist = os.listdir(dataset.extra_files_path)
+        rval = ['<html><head><title>RSEM Reference %s</title></head><p/>Comprises the following files:<p/><ul>' % (refname)]
+        for i,fname in enumerate(flist):
+            sfname = os.path.split(fname)[-1]
+            rval.append( '<li><a href="%s">%s</a>' % ( sfname, sfname ) )
+        rval.append( '</ul></html>' )
+        f = file(dataset.file_name,'w')
+        f.write("\n".join( rval ))
+        f.write('\n')
+        f.close()
+
+    def set_peek( self, dataset, is_multi_byte=False ):
+        if not dataset.dataset.purged:
+            dataset.peek  = "RSEM Reference (%s)" % ( dataset.metadata.reference_name )
+            dataset.blurb =  "RSEM Reference (%s)" % ( dataset.metadata.reference_name )
+        else:
+            dataset.peek = 'RSEM Reference (%s) does not exist' % ( dataset.metadata.reference_name )
+            dataset.blurb = 'RSEM Reference (%s) purged from disk' % ( dataset.metadata.reference_name )
+
+    def display_peek( self, dataset ):
+        try:
+            return dataset.peek
+        except:
+            return "RSEM Reference"
+
+    def set_meta( self, dataset, overwrite = True, **kwd ):
+        """
+        Expecting files:
+        extra_files_path/<reference_name>.grp
+        extra_files_path/<reference_name>.ti
+        extra_files_path/<reference_name>.seq
+        extra_files_path/<reference_name>.transcripts.fa
+        Optionally includes files:
+        extra_files_path/<reference_name>.chrlist
+        extra_files_path/<reference_name>.idx.fa
+        extra_files_path/<reference_name>.4.ebwt
+        extra_files_path/<reference_name>.3.ebwt
+        extra_files_path/<reference_name>.2.ebwt
+        extra_files_path/<reference_name>.1.ebwt
+        extra_files_path/<reference_name>.rev.2.ebwt
+        extra_files_path/<reference_name>.rev.1.ebwt
+        """
+        log.info( "RSEM reference set_meta %s %s" % (dataset,dataset.extra_files_path))
+        pat = '^(.*)\.grp$'
+        efp = dataset.extra_files_path
+        flist = os.listdir(efp)
+        for i,fname in enumerate(flist):
+          m = re.match(pat,fname)
+          if m: 
+            dataset.metadata.reference_name = m.groups()[0]
+            break
+        self.regenerate_primary_file(dataset)
+
+
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/rsem_calculate_expression.xml	Mon Nov 11 13:54:43 2013 -0500
@@ -0,0 +1,583 @@
+<tool id="rsem_calculate_expression" name="RSEM calculate expression" version="1.1.17">
+  <description>RNA-Seq by Expectation-Maximization</description>
+  <requirements>
+    <requirement type="package" version="1.1.17">rsem</requirement>
+    <requirement type="package" version="0.1.19">samtools</requirement>
+    <requirement type="package" version="1.0.0">bowtie</requirement>
+  </requirements>
+  <command interpreter="perl">
+    rsem-calculate-expression 
+    --calc-ci $useci.ci
+    --fragment-length-mean $fraglenmean
+    --fragment-length-min $fraglenmin
+    --fragment-length-sd $fraglensd
+    --fragment-length-max $fraglenmax
+    --bowtie-e $bowtie_e
+    --bowtie-m $bowtie_m
+
+   #if $input.format=="fastq"
+        ## IF FASTQ AND SINGLE END READS (DEFAULTS)
+	#if $input.fastqmatepair.matepair=="single" #rsem-wrapper-1.1.17.pl --bam_genome $bam_genome --bamtype $bamtype 
+	--seed-length $seedlength $input.fastq_select --estimate-rspd $rspd --forward-prob 
+	$fprob -p $cpus --bowtie-n $bowtie_mis --output-genome-bam --single_fastq $singlefastq 
+	--output $output --isoformfile $isoforms --bamfile $bam_res --log $log 
+	--sampling-for-bam $sampling_for_bam --reference ${index.fields.path}
+    	#end if
+        ## IF FASTQ AND PAIRED END READS (DEFAULTS)
+        #if $input.fastqmatepair.matepair=="paired" #rsem-wrapper-1.1.17.pl --bam_genome $bam_genome --bamtype $bamtype 
+	--paired-end --seed-length $seedlength --estimate-rspd $rspd $input.fastq_select --forward-prob $fprob -p $cpus 
+        --bowtie-n $bowtie_mis --output-genome-bam --fastq1 $fastq1 --fastq2 $fastq2 --output 
+        $output --isoformfile $isoforms --bamfile $bam_res --log $log --sampling-for-bam 
+        $sampling_for_bam --reference ${index.fields.path} 
+	#end if
+   #end if 
+   #if $input.format=="fasta"
+        ## IF FASTA AND SINGLE END READS (DEFAULTS)
+	#if $input.fastamatepair.matepair=="single" #rsem-wrapper-1.1.17.pl --bam_genome $bam_genome --bamtype $bamtype
+	--no-qualities --seed-length $seedlength --estimate-rspd $rspd --forward-prob $fprob -p $cpus --bowtie-n $bowtie_mis 
+	--output-genome-bam --single_fasta $single_fasta --output $output --isoformfile 
+	$isoforms --bamfile $bam_res --log $log --sampling-for-bam $sampling_for_bam --reference 
+	${index.fields.path}
+        #end if
+        ## IF FASTA AND PAIRED END READS (DEFAULTS)
+        #if $input.fastamatepair.matepair=="paired" #rsem-wrapper-1.1.17.pl --bam_genome $bam_genome --bamtype $bamtype
+	--no-qualities --paired-end --seed-length $seedlength --estimate-rspd $rspd --forward-prob $fprob -p $cpus 
+        --bowtie-n $bowtie_mis --output-genome-bam --fasta1 $fasta1 --fasta2 $fasta2 --output 
+        $output --isoformfile $isoforms --bamfile $bam_res --log $log --sampling-for-bam 
+        $sampling_for_bam --reference ${index.fields.path} 
+	#end if
+    #end if
+
+ </command>
+
+ <inputs>
+ <param name="sample" type="text" format="txt" label="Sample label" />
+ <conditional name="input">
+	<param name="format" type="select" label="Input file type">
+		<option value="fastq">FASTQ</option>
+		<option value="fasta">FASTA</option>
+	</param>
+ 	<when value="fastq">
+                   <param name="fastq_select" size="15" type="select" label="FASTQ type" >
+						<option value="--phred33-quals">phred33 qualities</option>
+						<option value="--solexa-quals">solexa qualities</option>
+						<option value="--phred64-quals">phred64 qualities</option>
+		 </param>
+
+	<conditional name="fastqmatepair">
+        	<when value="single">
+            	<param name="singlefastq" type="data" checked="yes" format="fastq" label="FASTQ file" />
+			</when>
+        	<when value="paired">
+             	<param name="fastq1" type="data" format="fastq" label="Read 1 fastq file" />
+                 <param name="fastq2" type="data" format="fastq" label="Read 2 fastq file" />
+ 			</when>
+    		<param name="matepair" type="select" label="Library type">
+			<option value="single">Single End Reads</option>
+			<option value="paired">Paired End Reads</option>
+		</param>
+ 	</conditional>
+	</when>
+ 	<when value="fasta">
+	<conditional name="fastamatepair">
+    	<param name="matepair" type="select" label="Library Type">
+			<option value="single">Single End Reads</option>
+			<option value="paired">Paired End Reads</option>
+		</param>
+    	<when value="single">
+    		<param name="single_fasta" type="data" checked="yes" format="fasta" label="fasta file" />
+		</when>
+    	<when value="paired">
+    		<param name="fasta1" type="data" format="fasta" label="Read 1 fasta file" />
+        	<param name="fasta2" type="data" format="fasta" label="Read 2 fasta file" />
+ 		</when>
+ 	</conditional>
+	</when>
+	<when>
+	<conditional name="fastamatepair">
+    	<param name="matepair" type="select" label="Library Type" >
+			<option value="single">Single End Reads</option>
+			<option value="paired">Paired End Reads</option>
+		</param>
+        <when value="single">
+        	<param name="singlefastq" type="data" checked="yes" format="fastq" label="FASTQ	file" />
+		</when>
+        <when value="paired">
+        	<param name="fastq1" type="data" format="fastq" label="Read 1 FASTQ file" />
+            <param name="fastq2" type="data" format="fastq" label="Read 2 FASTQ file" />
+ 		</when>
+ 	</conditional>
+	</when>
+	</conditional>
+    <param name="fprob" type="select" >
+    	<label>Is the library strand specific?</label>
+		<option value="0.5">No</option>
+		<option value="1">Yes, the reads (or first reads from paired-end libraries) are only in the forward orientation</option>
+		<option value="0">Yes, the reads (or first reads from paired-end libraries) are only in the reverse orientation</option>
+    </param>
+
+	<param name="index" type="select" label="Select RSEM reference" help="Select from a list of pre-indexed references. If you don't see anything consult the wrapper's documentation on how to create or download a reference">
+		<options from_data_table="rsem_indexes">
+			<filter type="sort_by" column="2" />
+				<validator type="no_options" message="No indexes are available" />
+		</options>
+	</param>
+	<param name="fraglenmean" size="4" type="text" value="-1" label="Fragment length mean (single-end data only)" help="The mean of the fragment length distribution, which is assumed to be a Gaussian. (Default: -1, which disables use of the fragment length distribution)" />
+	<param name="fraglensd" size="4" type="text" value="0" label="The standard deviation of the fragment length distribution (single-end data only)" help="Default 0, which assumes that all fragments are of the same length, given by the rounded value of fragment length mean. " />
+
+    <param name="bamtype" type="select" label="Create genome bam file" help="In addition to the transcript-coordinate-based BAM file output, also output a BAM file with the read alignments in genomic coordinates" >
+      <option value="no">no</option>
+      <option value="yes">yes</option>
+   </param>
+    <param name="sampling_for_bam" type="select" format="text" help="When RSEM generates a BAM file, instead of outputing all alignments a read has with their posterior probabilities, one alignment is sampled and outputed according to the posterior probabilities. If the sampling result is that the read comes from the noise transcript, nothing is outputed. (Default: off)">
+  		<label>Sample Bam File</label>
+			<option value="no">no</option>
+			<option value="yes">yes</option>
+    </param>
+    <param name="rspd" type="select" format="text" help="Set this option if you want to estimate the read start position distribution (RSPD) from data. Otherwise, RSEM will use a uniform RSPD.  (Default: off)">
+  		<label>Estimate and correct for a non-uniform read start position distribution (RSPD)</label>
+			<option value="no">no</option>
+			<option value="yes">yes</option>
+    </param>
+    
+<!-- <conditional name="fullpar">
+		<param name="fullpar" type="select" label="Full list of parameters" help="use 
+full list for linting all the parameters in RSEM">
+			<option value="default">Default</option>
+			<option value="fullset">Full Set</option>
+		</param>
+	<when value="fullset"> -->
+	 <!-- <param name="testing" size="4" type="text" value="" label="Advanced Parameters" /> 
+-->
+	<conditional name="useci">
+		<param name="ci" type="select" label="Calculate 95% Credibility Intervals">
+	   		<option value="no">no</option>
+	   		<option value="yes">yes</option>
+	   </param>
+       <when value="yes">
+	   	<param name="cimem" size="4" type="text" value="1024" label="Amount of memory in (MB) for computing CI" />
+       </when>
+    </conditional>
+	<param name="fraglenmin" size="4" type="text" value="1" label="Minimum read/insert length. Minimum read/insert length allowed. This is also the value for the bowtie -X option" />
+	<param name="fraglenmax" size="4" type="text" value="1000" label="Maximum read/insert length. Minimum read/insert length allowed. This is also the value for the bowtie -l option" />
+        <param name="bowtie_mis" size="2" type="text" value="2" label="Bowtie mismatches" help="Bowtie parameter max # of mismatches in the seed. (Range: 0-3, Default: 2) "/>
+	<param name="bowtie_e" size="4" type="text" value="99999999" label="Maximum sum of quality scores at mismatched positions in read alignments.  This is also the value for the Bowtie -e option" />
+	<param name="bowtie_m" size="4" type="text" value="200" label="Discard alignments for reads with number of alignments greater than" />
+        <param name="seedlength" size="2" type="text" value="25" label="Seed length used by the read aligner" help="Providing the correct value for this parameter is important for RSEM's accuracy if the data are single-end reads. RSEM uses this value for Bowtie's seed length parameter. The minimum value is 25. (Default:25)" />
+        <param name="cpus" size="2" type="integer" value="1" label="Number of threads to use" help="Number of threads to use. Both Bowtie and expression estimation will use this many threads.  (Default: 1)" />
+   <!-- </when> --> <!-- </conditional> -->
+  </inputs>
+  <stdio>
+    <exit_code range="1:"  level="fatal" description="Error Running RSEM" />
+  </stdio>
+  <outputs>
+    <data format="tabular" name="output" label="${sample}.gene_abundances"/>
+    <data format="tabular" name="isoforms" label="${sample}.isoform_abundances"/>
+    <data format="bam" name="bam_res" label="${sample}.transcript.bam"/>
+    <data format="bam" name="bam_genome" label="${sample}.genome.bam">
+    	<filter>bamtype == "yes"</filter>
+    </data>
+
+    <data format="txt" name="log" label="${sample}.rsem_log"/>
+  </outputs>
+  <help>
+  
+
+RSEM HOME PAGE - http://deweylab.biostat.wisc.edu/rsem/
+
+NAME
+    rsem-calculate-expression
+
+SYNOPSIS
+         rsem-calculate-expression [options] upstream_read_file(s) reference_name sample_name
+         rsem-calculate-expression [options] --paired-end upstream_read_file/s downstream_read_file/s reference_name sample_name
+         rsem-calculate-expression [options] --sam/--bam [--paired-end] input reference_name sample_name
+
+ARGUMENTS
+    upstream_read_files/s
+        Comma-separated list of files containing single-end reads or
+        upstream reads for paired-end data. By default, these files are
+        assumed to be in FASTQ format. If the --no-qualities option is
+        specified, then FASTA format is expected.
+
+    downstream_read_file/s
+        Comma-separated list of files containing downstream reads which are
+        paired with the upstream reads. By default, these files are assumed
+        to be in FASTQ format. If the --no-qualities option is specified,
+        then FASTA format is expected.
+
+    input
+        SAM/BAM formatted input file. If "-" is specified for the filename,
+        SAM/BAM input is instead assumed to come from standard input. RSEM
+        requires all alignments of the same read group together. For
+        paired-end reads, RSEM also requires the two mates of any alignment
+        be adjacent. See Description section for how to make input file obey
+        RSEM's requirements.
+
+    reference_name
+        The name of the reference used. The user must have run
+        'rsem-prepare-reference' with this reference_name before running
+        this program.
+
+    sample_name
+        The name of the sample analyzed. All output files are prefixed by
+        this name (e.g., sample_name.genes.results)
+
+OPTIONS
+
+    --paired-end
+        Input reads are paired-end reads. (Default: off)
+
+    --no-qualities
+        Input reads do not contain quality scores. (Default: off)
+
+    --strand-specific
+        The RNA-Seq protocol used to generate the reads is strand specific,
+        i.e., all (upstream) reads are derived from the forward strand. This
+        option is equivalent to --forward-prob=1.0. With this option set, if
+        RSEM runs the Bowtie aligner, the '--norc' Bowtie option will be
+        used, which disables alignment to the reverse strand of transcripts.
+        (Default: off)
+
+    --sam
+        Input file is in SAM format. (Default: off)
+
+    --bam
+        Input file is in BAM format. (Default: off)
+
+    --sam-header-info [file]
+        RSEM reads header information from input by default. If this option
+        is on, header information is read from the specified file. For the
+        format of the file, please see SAM official website. (Default: "")
+
+    -p/--num-threads [int]
+        Number of threads to use. Both Bowtie and expression estimation will
+        use this many threads. (Default: 1)
+
+    --no-bam-output
+        Do not output any BAM file. (Default: off)
+
+    --output-genome-bam
+        Generate a BAM file, 'sample_name.genome.bam', with alignments
+        mapped to genomic coordinates and annotated with their posterior
+        probabilities. In addition, RSEM will call samtools (included in
+        RSEM package) to sort and index the bam file.
+        'sample_name.genome.sorted.bam' and
+        'sample_name.genome.sorted.bam.bai' will be generated. (Default:
+        off)
+
+    --sampling-for-bam
+        When RSEM generates a BAM file, instead of outputing all alignments
+        a read has with their posterior probabilities, one alignment is
+        sampled and outputed according to the posterior probabilities. If
+        the sampling result is that the read comes from the "noise"
+        transcript, nothing is outputed. (Default: off)
+
+    --calc-ci
+        Calculate 95% credibility intervals and posterior mean estimates.
+        (Default: off)
+
+    --seed-length [int]
+        Seed length used by the read aligner. Providing the correct value is
+        important for RSEM. If RSEM runs Bowtie, it uses this value for
+        Bowtie's seed length parameter. Any read with its or at least one of
+        its mates' (for paired-end reads) length less than this value will
+        be ignored. If the references are not added poly(A) tails, the
+        minimum allowed value is 5, otherwise, the minimum allowed value is
+        25. Note that this script will only check if the value less or equal than
+        5 and give a warning message if the value less than 25 but greter or equal than
+        5. (Default: 25)
+
+    --tag [string]
+        The name of the optional field used in the SAM input for identifying
+        a read with too many valid alignments. The field should have the
+        format [tagName]:i:[value], where a [value] bigger than 0 indicates
+        a read with too many alignments. (Default: "")
+
+    --bowtie-path [path]
+        The path to the bowtie executables. (Default: the path to the bowtie
+        executables is assumed to be in the user's PATH environment
+        variable)
+
+    --bowtie-n [int]
+        (Bowtie parameter) max # of mismatches in the seed. (Range: 0-3,
+        Default: 2)
+
+    --bowtie-e [int]
+        (Bowtie parameter) max sum of mismatch quality scores across the
+        alignment. (Default: 99999999)
+
+    --bowtie-m [int]
+        (Bowtie parameter) suppress all alignments for a read if greater then [int]
+        valid alignments exist. (Default: 200)
+
+    --bowtie-chunkmbs [int]
+        (Bowtie parameter) memory allocated for best first alignment
+        calculation (Default: 0 - use bowtie's default)
+
+    --phred33-quals
+        Input quality scores are encoded as Phred+33. (Default: on)
+
+    --phred64-quals
+        Input quality scores are encoded as Phred+64 (default for GA
+        Pipeline ver. less than  1.3). (Default: off)
+
+    --solexa-quals
+        Input quality scores are solexa encoded (from GA Pipeline ver. less
+        than 1.3). (Default: off)
+
+    --forward-prob [double]
+        Probability of generating a read from the forward strand of a
+        transcript. Set to 1 for a strand-specific protocol where all
+        (upstream) reads are derived from the forward strand, 0 for a
+        strand-specific protocol where all (upstream) read are derived from
+        the reverse strand, or 0.5 for a non-strand-specific protocol.
+        (Default: 0.5)
+
+    --fragment-length-min [int]
+        Minimum read/insert length allowed. This is also the value for the
+        bowtie -I option. (Default: 1)
+
+    --fragment-length-max [int]
+        Maximum read/insert length allowed. This is also the value for the
+        bowtie -X option. (Default: 1000)
+
+    --fragment-length-mean [double]
+        (single-end data only) The mean of the fragment length distribution,
+        which is assumed to be a Gaussian. (Default: -1, which disables use
+        of the fragment length distribution)
+
+    --fragment-length-sd [double]
+        (single-end data only) The standard deviation of the fragment length
+        distribution, which is assumed to be a Gaussian. (Default: 0, which
+        assumes that all fragments are of the same length, given by the
+        rounded value of --fragment-length-mean)
+
+    --estimate-rspd
+        Set this option if you want to estimate the read start position
+        distribution (RSPD) from data. Otherwise, RSEM will use a uniform
+        RSPD. (Default: off)
+
+    --num-rspd-bins [int]
+        Number of bins in the RSPD. Only relevant when '--estimate-rspd' is
+        specified. Use of the default setting is recommended. (Default: 20)
+
+    --ci-memory [int]
+        Maximum size (in memory, MB) of the auxiliary buffer used for
+        computing credibility intervals (CI). Set it larger for a faster CI
+        calculation. However, leaving 2 GB memory free for other usage is
+        recommended. (Default: 1024)
+
+    --keep-intermediate-files
+        Keep temporary files generated by RSEM. RSEM creates a temporary
+        directory, 'sample_name.temp', into which it puts all intermediate
+        output files. If this directory already exists, RSEM overwrites all
+        files generated by previous RSEM runs inside of it. By default,
+        after RSEM finishes, the temporary directory is deleted. Set this
+        option to prevent the deletion of this directory and the
+        intermediate files inside of it. (Default: off)
+
+    --time
+        Output time consumed by each step of RSEM to 'sample_name.time'.
+        (Default: off)
+
+    -q/--quiet
+        Suppress the output of logging information. (Default: off)
+
+    -h/--help
+        Show help information.
+
+DESCRIPTION
+    In its default mode, this program aligns input reads against a reference
+    transcriptome with Bowtie and calculates expression values using the
+    alignments. RSEM assumes the data are single-end reads with quality
+    scores, unless the '--paired-end' or '--no-qualities' options are
+    specified. Users may use an alternative aligner by specifying one of the
+    --sam and --bam options, and providing an alignment file in the
+    specified format. However, users should make sure that they align
+    against the indices generated by 'rsem-prepare-reference' and the
+    alignment file satisfies the requirements mentioned in ARGUMENTS
+    section.
+
+    One simple way to make the alignment file satisfying RSEM's requirements
+    (assuming the aligner used put mates in a paired-end read adjacent) is
+    to use 'convert-sam-for-rsem' script. This script only accept SAM format
+    files as input. If a BAM format file is obtained, please use samtools to
+    convert it to a SAM file first. For example, if '/ref/mouse_125' is the
+    'reference_name' and the SAM file is named 'input.sam', you can run the
+    following command:
+
+      convert-sam-for-rsem /ref/mouse_125 input.sam -o input_for_rsem.sam
+
+    For details, please refer to 'convert-sam-for-rsem's documentation page.
+
+    The SAM/BAM format RSEM uses is v1.4. However, it is compatible with old
+    SAM/BAM format. However, RSEM cannot recognize 0x100 in the FLAG field.
+    In addition, RSEM requires SEQ and QUAL are not '*'.
+
+    The user must run 'rsem-prepare-reference' with the appropriate
+    reference before using this program.
+
+    For single-end data, it is strongly recommended that the user provide
+    the fragment length distribution parameters (--fragment-length-mean and
+    --fragment-length-sd). For paired-end data, RSEM will automatically
+    learn a fragment length distribution from the data.
+
+    Please note that some of the default values for the Bowtie parameters
+    are not the same as those defined for Bowtie itself.
+
+    The temporary directory and all intermediate files will be removed when
+    RSEM finishes unless '--keep-intermediate-files' is specified.
+
+    With the '--calc-ci' option, 95% credibility intervals and posterior
+    mean estimates will be calculated in addition to maximum likelihood
+    estimates.
+
+OUTPUT
+    sample_name.genes.results
+        File containing gene level expression estimates. The format of each
+        line in this file is:
+
+        gene_id expected_counts tau_value [pmc_value tau_pme_value
+        tau_ci_lower_bound tau_ci_upper_bound] transcript_id_list
+
+        Fields are separated by the tab character. Fields within "[]" are
+        only presented if '--calc-ci' is set. pme stands for posterior mean
+        estimation. pmc stands for posterior mean counts. ci_lower_bound(l)
+        means the lower bound of the credibility intervals,
+        ci_upper_bound(u) means the upper bound of the credibility
+        intervals. So the credibility interval is [l, u].
+        'transcript_id_list' is a space-separated list of transcript_ids
+        belonging to the gene. If no gene information is provided, this file
+        has the same content as 'sample_name.isoforms.results'.
+
+    sample_name.isoforms.results
+        File containing isoform level expression values. The format of each
+        line in this file is:
+
+        transcript_id expected_counts tau_value [pmc_value tau_pme_value
+        tau_ci_lower_bound tau_ci_upper_bound] gene_id
+
+        Fields are separated by the tab character. 'gene_id' is the gene_id
+        of the gene which this transcript belongs to. If no gene information
+        is provided, 'gene_id' and 'transcript_id' are the same.
+
+    sample_name.transcript.bam, sample_name.transcript.sorted.bam and
+    sample_name.transcript.sorted.bam.bai
+        Only generated when --no-bam-output is not specified.
+
+        'sample_name.transcript.bam' is a BAM-formatted file of read
+        alignments in transcript coordinates. The MAPQ field of each
+        alignment is set to min(100, floor(-10 * log10(1.0 - w) + 0.5)),
+        where w is the posterior probability of that alignment being the
+        true mapping of a read. In addition, RSEM pads a new tag ZW:f:value,
+        where value is a single precision floating number representing the
+        posterior probability.
+
+        'sample_name.transcript.sorted.bam' and
+        'sample_name.transcript.sorted.bam.bai' are the sorted BAM file and
+        indices generated by samtools (included in RSEM package).
+
+    sample_name.genome.bam, sample_name.genome.sorted.bam and
+    sample_name.genome.sorted.bam.bai
+        Only generated when --no-bam-output is not specified and
+        --output-genome-bam is specified.
+
+        'sample_name.genome.bam' is a BAM-formatted file of read alignments
+        in genomic coordinates. Alignments of reads that have identical
+        genomic coordinates (i.e., alignments to different isoforms that
+        share the same genomic region) are collapsed into one alignment. The
+        MAPQ field of each alignment is set to min(100, floor(-10 *
+        log10(1.0 - w) + 0.5)), where w is the posterior probability of that
+        alignment being the true mapping of a read. In addition, RSEM pads a
+        new tag ZW:f:value, where value is a single precision floating
+        number representing the posterior probability. If an alignment is
+        spliced, a XS:A:value tag is also added, where value is either '+'
+        or '-' indicating the strand of the transcript it aligns to.
+
+        'sample_name.genome.sorted.bam' and
+        'sample_name.genome.sorted.bam.bai' are the sorted BAM file and
+        indices generated by samtools (included in RSEM package).
+
+    sample_name.sam.gz
+        Only generated when the input files are raw reads instead of SAM/BAM
+        format files
+
+        It is the gzipped SAM output produced by bowtie aligner.
+
+    sample_name.time
+        Only generated when --time is specified.
+
+        It contains time (in seconds) consumed by aligning reads, estimating
+        expression levels and calculating credibility intervals.
+
+    sample_name.stat
+        This is a folder instead of a file. All model related statistics are
+        stored in this folder. Use 'rsem-plot-model' can generate plots
+        using this folder.
+
+EXAMPLES
+    Assume the path to the bowtie executables is in the user's PATH
+    environment variable. Reference files are under '/ref' with name
+    'mouse_125'.
+
+    1) '/data/mmliver.fq', single-end reads with quality scores. Quality
+    scores are encoded as for 'GA pipeline version >= 1.3'. We want to use 8
+    threads and generate a genome BAM file:
+
+     rsem-calculate-expression --phred64-quals \
+                               -p 8 \
+                               --output-genome-bam \
+                               /data/mmliver.fq \
+                               /ref/mouse_125 \
+                               mmliver_single_quals
+
+    2) '/data/mmliver_1.fq' and '/data/mmliver_2.fq', paired-end reads with
+    quality scores. Quality scores are in SANGER format. We want to use 8
+    threads and do not generate a genome BAM file:
+
+     rsem-calculate-expression -p 8 \
+                               --paired-end \
+                               /data/mmliver_1.fq \
+                               /data/mmliver_2.fq \
+                               /ref/mouse_125 \
+                               mmliver_paired_end_quals
+
+    3) '/data/mmliver.fa', single-end reads without quality scores. We want
+    to use 8 threads:
+
+     rsem-calculate-expression -p 8 \
+                               --no-qualities \
+                               /data/mmliver.fa \
+                               /ref/mouse_125 \
+                               mmliver_single_without_quals
+
+    4) Data are the same as 1). We want to take a fragment length
+    distribution into consideration. We set the fragment length mean to 150
+    and the standard deviation to 35. In addition to a BAM file, we also
+    want to generate credibility intervals. We allow RSEM to use 1GB of
+    memory for CI calculation:
+
+     rsem-calculate-expression --bowtie-path /sw/bowtie \
+                               --phred64-quals \
+                               --fragment-length-mean 150.0 \
+                               --fragment-length-sd 35.0 \
+                               -p 8 \
+                               --output-genome-bam \
+                               --calc-ci \
+                               --ci-memory 1024 \
+                               /data/mmliver.fq \
+                               /ref/mouse_125 \
+                               mmliver_single_quals
+
+    5) '/data/mmliver_paired_end_quals.bam', paired-end reads with quality
+    scores. We want to use 8 threads:
+
+     rsem-calculate-expression --paired-end \
+                               --bam \
+                               -p 8 \
+                               /data/mmliver_paired_end_quals.bam \
+                               /ref/mouse_125 \
+                               mmliver_paired_end_quals
+  </help> 
+</tool> 
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/rsem_prepare_reference.xml	Mon Nov 11 13:54:43 2013 -0500
@@ -0,0 +1,114 @@
+<tool id="rsem_prepare_reference" name="RSEM prepare reference" version="1.1.17">
+  <description></description>
+  <requirements>
+    <requirement type="package" version="1.1.17">rsem</requirement>
+    <requirement type="package" version="1.0.0">bowtie</requirement>
+  </requirements>
+  <command>
+    rsem-prepare-reference 
+    #if $polya.polya_use == 'add':
+      #if $polya.polya_length:
+        --polyA-length $polya.polya_length
+      #end if
+    #elif $polya.polya_use == 'subset':
+      --no-polyA-subset $polya.no_polya_subset
+      #if $polya.polya_length:
+        --polyA-length $polya.polya_length
+      #end if
+    #elif $polya.polya_use == 'none':
+      --no-polyA
+    #end if
+    $ntog
+    #if $transcript_to_gene_map:
+      --transcript-to-gene-map $transcript_to_gene_map
+    #end if
+    #if $reference.ref_type == 'transcripts':
+      $reference.reference_fasta_file
+    #else:
+      --gtf $reference.gtf
+      $reference.reference_fasta_file
+    #end if
+    $reference_name
+  </command>
+
+  <inputs>
+    <conditional name="reference">
+      <param name="ref_type" type="select" label="">
+        <option value="transcripts">transcript fasta</option>
+        <option value="genomic">reference genome and gtf</option>
+      </param>
+      <when value="transcripts">
+        <param name="reference_fasta_file" type="data" format="fasta" label="reference fasta file" 
+               help="The files should contain the sequences of transcripts."/>
+
+      </when>
+      <when value="genomic">
+        <param name="reference_fasta_file" type="data" format="fasta" label="reference fasta file" 
+               help="The files should contain either the sequences of an entire genome."/>
+        <param name="gtf" type="data" format="gtf" optional="true" label="gtf" 
+               help="extract transcript reference sequences using the gene annotations specified in this GTF" />
+      </when>
+    </conditional>
+    <param name="transcript_to_gene_map" type="data" format="tabular" optional="true" label="Map of gene ids to transcript (isoform) ids" >
+      <help>
+        Each line of should be of the form: gene_id transcript_id ( with the two fields separated by a tab character )
+        The map can be obtained from the UCSC table browser  
+          group: Genes and Gene Prediction Tracks 
+          table: knownIsoforms
+        Without a map:
+          If a reference genome and gtf is used, then RSEM uses the "gene_id" and "transcript_id" attributes in the GTF file. 
+          Otherwise, RSEM assumes that each sequence in the reference sequence files is a separate gene.
+      </help>
+    </param>
+    <param name="reference_name" type="text" value="" label="reference name">
+    </param>
+
+    <conditional name="polya">
+      <param name="polya_use" type="select" label="PolyA ">
+        <option value="add" selected="true">Add poly(A) tails to all transcripts</option>
+        <option value="subset">Exclude poly(A) tails from selected transcripts</option>
+        <option value="none">Do not add poly(A) tails to any transcripts</option>
+      </param>
+      <when value="add">
+        <param name="polya_length" type="integer" value="125" optional="true" label="The length of the poly(A) tails to be added. (Default: 125)">
+          <validator type="in_range" message="must be positive " min="1"/>
+        </param>
+      </when>
+      <when value="subset">
+        <param name="no_polya_subset" type="data" format="tabular" optional="true" label="List of transcript IDs (one per line) that should should not have polyA tails added."/> 
+        <param name="polya_length" type="integer" value="125" optional="true" label="The length of the poly(A) tails to be added. (Default: 125)">
+          <validator type="in_range" message="must be positive " min="1"/>
+        </param>
+      </when>
+      <when value="none"/>
+    </conditional>
+
+    <param name="ntog" type="boolean" truevalue="--no-ntog" falsevalue="" checked="false" label="Disable the conversion of 'N' characters to 'G' characters in the reference sequences" help="Bowite uses the automatic N to G conversion to to align against all positions in the reference."/>
+  </inputs>
+  <stdio>
+    <exit_code range="1:"  level="fatal" description="Error Running RSEM" />
+  </stdio>
+  <outputs>
+    <data format="rsem_ref" name="reference_file" label="RSEM ${reference_name} reference"/>
+  </outputs>
+  <help>
+  
+
+RSEM HOME PAGE - http://deweylab.biostat.wisc.edu/rsem/
+
+NAME
+    rsem-prepare-reference
+
+SYNOPSIS
+    rsem-prepare-reference [options] reference_fasta_file(s) reference_name
+
+DESCRIPTION
+    The rsem-prepare-reference program extracts/preprocesses the reference sequences and builds Bowtie indices using default parameters. 
+    This program is used in conjunction with the 'rsem-calculate-expression' program.
+
+INPUTS
+
+
+
+  </help> 
+</tool> 
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/tool-data/rsem_indices.loc.sample	Mon Nov 11 13:54:43 2013 -0500
@@ -0,0 +1,14 @@
+#This is a sample file distributed with Galaxy that enables tools
+#to use a directory of Bowtie indexed sequences data files. You will
+#need to create these data files and then create a bowtie_indices.loc
+#file similar to this one (store it in this directory) that points to
+#the directories in which those files are stored. The bowtie_indices.loc
+#file has this format (longer white space characters are TAB characters):
+#
+#<unique_build_id>   <dbkey>   <display_name>   <file_base_path>
+#
+#So, for example, if you had hg18 indexed stored in 
+#/depot/data2/galaxy/bowtie/hg18/, 
+#then the bowtie_indices.loc entry would look like this:
+#
+#hg18   hg18   hg18   /depot/data2/galaxy/bowtie/hg18/hg18
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/tool_data_table_conf.xml.sample	Mon Nov 11 13:54:43 2013 -0500
@@ -0,0 +1,8 @@
+<tables>
+    <!-- Locations of all rsem reference files under genome directory -->
+    <table name="rsem_indexes" comment_char="#">
+        <columns>value, dbkey, name, path</columns>
+        <file path="tool-data/rsem_indices.loc" />
+    </table>
+</tables>
+
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/tool_dependencies.xml	Mon Nov 11 13:54:43 2013 -0500
@@ -0,0 +1,12 @@
+<?xml version="1.0"?>
+<tool_dependency>
+    <package name="rsem" version="1.1.17">
+        <repository toolshed="http://testtoolshed.g2.bx.psu.edu" name="package_rsem_1_1_17" owner="jjohnson" changeset_revision="9fa1826ae6d4" />
+    </package>
+    <package name="samtools" version="0.1.19">
+        <repository changeset_revision="54195f1d4b0f" name="package_samtools_0_1_19" owner="iuc" toolshed="http://testtoolshed.g2.bx.psu.edu" />
+    </package>
+    <package name="bowtie" version="1.0.0">
+        <repository changeset_revision="e682af6a72cd" name="package_bowtie_1_0_0" owner="jjohnson" toolshed="http://testtoolshed.g2.bx.psu.edu" />
+    </package>
+</tool_dependency>