changeset 0:c170448acc8a draft

planemo upload for repository https://github.com/galaxyproject/tools-devteam/tree/master/tools/velvet commit 5a4e0ca9992af3a6e5ed2b533f04bb82ce761e0b
author devteam
date Mon, 09 Nov 2015 12:02:53 -0500
parents
children c397035f715d
files macros.xml tool_dependencies.xml velvetg.xml velvetg_wrapper.py velveth.xml velveth_wrapper.py
diffstat 6 files changed, 587 insertions(+), 0 deletions(-) [+]
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/macros.xml	Mon Nov 09 12:02:53 2015 -0500
@@ -0,0 +1,27 @@
+<?xml version="1.0"?>
+<macros>
+  <xml name="requirements">
+      <requirements>
+          <requirement type="package" version="1.2.10">velvet</requirement>
+      </requirements>
+  </xml>
+  <token name="@WRAPPER_VERSION@">1.2.10</token>
+  <xml name="stdio">
+    <stdio>
+      <!-- Anything other than zero is an error -->
+      <exit_code range="1:"/>
+      <exit_code range=":-1"/>
+      <!-- In case the return code has not been set propery check stderr too -->
+      <regex match="Error:"/>
+      <regex match="Exception:"/>
+    </stdio>
+  </xml>
+  <xml name="citation">
+      <citations>
+          <citation type="doi">
+              10.1101/gr.074492.107
+          </citation>
+      </citations>
+  </xml>
+</macros>
+
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/tool_dependencies.xml	Mon Nov 09 12:02:53 2015 -0500
@@ -0,0 +1,6 @@
+<?xml version="1.0"?>
+<tool_dependency>
+    <package name="velvet" version="1.2.10">
+      <repository changeset_revision="d9e36a5fd0ea" name="package_velvet_1_2_10" owner="devteam" toolshed="https://testtoolshed.g2.bx.psu.edu" />
+    </package>
+</tool_dependency>
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/velvetg.xml	Mon Nov 09 12:02:53 2015 -0500
@@ -0,0 +1,307 @@
+<tool id="velvetg" name="velvetg" version="@WRAPPER_VERSION@.0">
+  <description>Velvet sequence assembler for very short reads</description>
+  <version_command>velvetg 2&gt;&amp;1 | grep "Version" | sed -e 's/Version //'</version_command>
+  <macros>
+    <import>macros.xml</import>
+  </macros>
+  <expand macro="requirements"/>
+  <expand macro="stdio"/>
+  <command interpreter="python">
+    velvetg_wrapper.py
+           '$input.extra_files_path'
+           #if $generate_amos.afg  == "yes":
+               -amos_file $generate_amos.afg
+           #end if
+           #if $unused_reads.generate_unused  == "yes":
+               -unused_reads $unused_reads.generate_unused
+           #end if
+           $read_trkg
+           #if $coverage.cutoff == "auto":
+               -cov_cutoff auto
+           #elif $coverage.cutoff == "value":
+               -cov_cutoff $coverage.cov_cutoff
+           #end if
+           #if $expected.coverage == "auto":
+               -exp_cov auto
+           #elif $expected.coverage == "value":
+               -exp_cov $expected.exp_cov
+           #end if
+           #if $contig_lgth.use_contig_lgth == "yes":
+               -min_contig_lgth $contig_lgth.min_contig_lgth
+           #end if
+           #if $reads.paired == "yes":
+               #if int($reads.ins_length) > 0:
+                   -ins_length $reads.ins_length
+               #end if
+               #if $reads.options.advanced == "yes":
+                   #if int($reads.options.ins_length_sd) > 0:
+                       -ins_length_sd $reads.options.ins_length_sd
+                   #end if
+                   #if int($reads.options.ins_length2) > 0:
+                       -ins_length2 $reads.options.ins_length2
+                   #end if
+                   #if int($reads.options.ins_length2_sd) > 0:
+                       -ins_length2_sd $reads.options.ins_length2_sd
+                   #end if
+                   #if int($reads.options.ins_length_long) > 0:
+                       -ins_length_long $reads.options.ins_length_long
+                   #end if
+                   #if int($reads.options.ins_length_long_sd) > 0:
+                       -ins_length_long_sd $reads.options.ins_length_long_sd
+                   #end if
+                   #if int($reads.options.max_branch_length) > 0:
+                       -max_branch_length $reads.options.max_branch_length
+                   #end if
+                   #if int($reads.options.max_divergence) > 0:
+                       -max_divergence $reads.options.max_divergence
+                   #end if
+                   #if int($reads.options.max_gap_count) > 0:
+                       -max_gap_count $reads.options.max_gap_count
+                   #end if
+                   #if int($reads.options.min_pair_count) > 0:
+                       -min_pair_count $reads.options.min_pair_count
+                   #end if
+                   #if int($reads.options.max_coverage) > 0:
+                       -max_coverage $reads.options.max_coverage
+                   #end if
+                   #if int($reads.options.long_mult_cutoff) > 0:
+                       -long_mult_cutoff $reads.options.long_mult_cutoff
+                   #end if
+                   $reads.options.scaffolding
+               #end if
+           #end if
+  </command>
+  <inputs>
+    <param name="input" type="data" format="velvet" label="Velvet Dataset" help="Prepared by velveth."/>
+    <conditional name="generate_amos">
+      <param name="afg" type="select" label="Generate a AMOS.afg file">
+        <option value="no">No</option>
+        <option value="yes">Yes</option>
+      </param>
+      <when value="no"/>
+      <when value="yes"/>
+    </conditional>
+
+    <conditional name="unused_reads">
+      <param name="generate_unused" type="select" label="Generate a UnusedReads fasta file">
+        <option value="no">No</option>
+        <option value="yes">Yes</option>
+      </param>
+      <when value="no"/>
+      <when value="yes"/>
+    </conditional>
+
+    <conditional name="last_graph">
+      <param name="generate_graph" type="select" label="Generate velvet LastGraph file">
+        <option value="no">No</option>
+        <option value="yes">Yes</option>
+      </param>
+      <when value="no"/>
+      <when value="yes"/>
+    </conditional>
+
+    <param name="read_trkg" type="boolean" checked="false" truevalue="-read_trkg yes" falsevalue="-read_trkg no" label="Tracking of short read positions in assembly" help="Generates Graph2 dataset" />
+
+    <conditional name="coverage">
+      <param name="cutoff" type="select" label="Coverage cutoff" help="">
+        <option value="none">None</option>
+        <option value="auto">Automatically Determined</option>
+        <option value="value">Specify Cutoff Value</option>
+      </param>
+      <when value="none"/>
+      <when value="auto"/>
+      <when value="value">
+        <param name="cov_cutoff" value="10.0" label="Remove nodes with coverage below" type="float" />
+      </when>
+    </conditional>
+
+    <conditional name="expected">
+      <param name="coverage" type="select" label="Expected Coverage of Unique Regions" help="">
+        <option value="none">None</option>
+        <option value="auto">Automatically Determined</option>
+        <option value="value">Specify Expected Value</option>
+      </param>
+      <when value="none"/>
+      <when value="auto"/>
+      <when value="value">
+        <param name="exp_cov" value="10.0" label="Remove nodes with coverage below" type="float" />
+      </when>
+    </conditional>
+
+    <conditional name="contig_lgth">
+      <param name="use_contig_lgth" type="select" label=" Set minimum contig length" help="minimum contig length exported to contigs.fa file (default: hash length * 2).">
+        <option value="no">No</option>
+        <option value="yes">Yes</option>
+      </param>
+      <when value="no"/>
+      <when value="yes">
+        <param name="min_contig_lgth" value="42" label="minimum contig length" type="integer" help="minimum contig length exported to contigs.fa file (default: hash length * 2)"/>
+      </when>
+    </conditional>
+
+    <conditional name="reads">
+      <param name="paired" type="select" label="Using Paired Reads">
+        <option value="no">No</option>
+        <option value="yes" selected="${input.metadata.paired_end_reads}">Yes</option>
+      </param>
+      <when value="no"/>
+      <when value="yes">
+        <param name="ins_length" value="-1" label="Insert Length in Paired-End Read dataset (ignored when -1)" type="integer" help="Expected distance between two paired end reads"/>
+        <conditional name="options">
+          <param name="advanced" type="select" label="Velvet Advanced Options">
+            <option value="no">Use Defaults</option>
+            <option value="yes">Set Advanced Option Values</option>
+          </param>
+          <when value="no"/>
+          <when value="yes">
+            <param name="ins_length_sd" value="-1" label="Estimate of Standard Deviation of Paired-End Read dataset(ignored when -1)" type="integer" help="Estimate of standard deviation of Paired-End Read dataset (default: 10% of corresponding length)"/>
+            <param name="ins_length2" value="-1" label="Insert Length in 2nd Paired-End Short Read dataset (ignored when -1)" type="integer" help="Expected distance between two paired end reads in the second short-read dataset"/>
+            <param name="ins_length2_sd" value="-1" label="Estimate of Standard Deviation of 2nd Paired-End Read dataset (ignored when -1)" type="integer" help="Estimate of standard deviation of 2nd Paired-End Read dataset (default: 10% of corresponding length)"/>
+            <param name="ins_length_long" value="-1" label="Insert Length in Long Paired-End Read dataset (ignored when -1)" type="integer" help="Expected distance between two long paired-end reads"/>
+            <param name="ins_length_long_sd" value="-1" label="Estimate of Standard Deviation of 2nd Paired-End Read dataset (ignored when -1)" type="integer" help="Estimate of standard deviation of Long Paired-End Read dataset (default: 10% of corresponding length)"/>
+            <param name="max_branch_length" value="-1" label="Maximum branch length (ignored when -1)" type="integer" help="maximum length in base pair of bubble (default: 100)"/>
+            <param name="max_divergence" value="-1." label="Maximum max_divergence (between .0 and 1., ignored when -1.)" type="float" help="maximum divergence rate between two branches in a bubble (default: .2)"/>
+            <param name="max_gap_count" value="-1" label="Maximum gap count (ignored when -1)" type="integer" help="maximum number of gaps allowed in the alignment of the two branches of a bubble (default: 3)"/>
+            <param name="min_pair_count" value="-1" label="Minimum read-pair count (ignored when -1)" type="integer" help="minimum number of paired end connections to justify the scaffolding of two long contigs (default: 10)"/>
+            <param name="max_coverage" value="-1." label="Maximum coverage exclusion(ignored when -1.)" type="float" help="Exclude data that has coverage more than this maximum coverage value"/>
+            <param name="long_mult_cutoff" value="-1" label="Minimum number of long reads required to merge contigs (ignored when -1)" type="integer" help="minimum number of long reads required to merge contigs (default: 2)"/>
+            <param name="scaffolding" type="boolean" checked="true" truevalue="-scaffolding yes" falsevalue="-scaffolding no" label="Use Scaffolding" help="Scaffold contigs that it cannot quite be connected (This results in sequences of Ns in the contigs)"/>
+
+          </when>
+        </conditional>
+      </when>
+    </conditional>
+  </inputs>
+  <outputs>
+    <data format="txt" name="Graph2" label="${tool.name} on ${on_string}: Graph2" from_work_dir="Graph2">
+      <filter>read_trkg is True</filter>
+    </data>
+    <data format="txt" name="LastGraph" label="${tool.name} on ${on_string}: LastGraph" from_work_dir="LastGraph">
+      <filter>last_graph['generate_graph'] == "yes"</filter>
+    </data>
+    <data format="afg" name="velvet_asm" label="${tool.name} on ${on_string}: AMOS.afg" from_work_dir="velvet_asm.afg">
+      <filter>generate_amos['afg'] == "yes"</filter>
+    </data>
+    <data format="fasta" name="unused_reads_fasta" label="${tool.name} on ${on_string}: Unused Reads" from_work_dir="UnusedReads.fa">
+      <filter>unused_reads['generate_unused'] == "yes"</filter>
+    </data>
+    <data format="tabular" name="stats" label="${tool.name} on ${on_string}: Stats" from_work_dir="stats.txt" />
+    <data format="fasta" name="contigs" label="${tool.name} on ${on_string}: Contigs" from_work_dir="contigs.fa" />
+  </outputs>
+  <requirements>
+    <requirement type="package">velvet</requirement>
+  </requirements>
+  <tests>
+    <test>
+      <param name="input" value="velveth_test1/output.html" ftype="velvet" >
+        <composite_data value='velveth_test1/Sequences' ftype="Sequences"/>
+        <composite_data value='velveth_test1/Roadmaps' ftype="Roadmaps"/>
+        <composite_data value='velveth_test1/Log'/>
+      </param>
+      <param name="afg" value="yes" />
+      <param name="generate_unused" value="yes" />
+      <param name="generate_graph" value="no" />
+      <param name="read_trkg" value="-read_trkg no" />
+      <param name="cutoff" value="auto" />
+      <param name="coverage" value="auto" />
+      <param name="use_contig_lgth" value="no" />
+      <param name="paired" value="no" />
+      <!--
+      <output name="LastGraph" file="velvetg_test1/lastgraph.txt" compare="diff"/>
+      -->
+      <output name="velvet_asm" file="velvetg_test1/amos.afg" compare="diff"/>
+      <output name="unused_reads_fasta" file="velvetg_test1/unusedreads.fa" compare="diff"/>
+      <output name="stats" file="velvetg_test1/stats.csv" compare="diff"/>
+      <output name="contigs" file="velvetg_test1/contigs.fa" compare="diff"/>
+    </test>
+  </tests>
+  <help>
+**What it does**
+
+Velvet_ is a de novo genomic assembler specially designed for short read sequencing technologies, such as Solexa or 454, developed by Daniel Zerbino and Ewan Birney at the European Bioinformatics Institute (EMBL-EBI), near Cambridge, in the United Kingdom.
+
+Velvet currently takes in short read sequences, removes errors then produces high quality unique contigs. It then uses paired-end read and long read information, when available, to retrieve the repeated areas between contigs.
+
+Read the Velvet `documentation`__ for details on using the Velvet Assembler.
+
+.. _Velvet: http://www.ebi.ac.uk/~zerbino/velvet/
+
+.. __: http://www.ebi.ac.uk/~zerbino/velvet/Manual.pdf
+
+------
+
+**Input formats**
+
+Velvet can input sequence files in the following formats: fasta fastq fasta.gz fastq.gz eland gerald
+
+The input files are prepared for the velvet assembler using **velveth**.
+
+------
+
+**Outputs**
+
+**Contigs**
+
+The *contigs.fa* file.
+This fasta file contains the sequences of the contigs longer than 2k, where k is the word-length used in velveth. If you have specified a min contig length threshold, then the contigs shorter than that value are omitted.
+Note that the length and coverage information provided in the header of each contig should therefore be understood in k-mers and in k-mer coverage (cf. 5.1) respectively.
+The N's in the sequence correspond to gaps between scaffolded contigs. The number of N's corresponds to the estimated length of the gap. For reasons of compatibility with the archives, any gap shorter than 10bp is represented by a sequence of 10 N's.
+
+**Stats**
+
+The *stats.txt* file.
+This file is a simple tabbed-delimited description of the nodes. The column names are pretty much self-explanatory. Note however that node lengths are given in k-mers. To obtain the length in nucleotides of each node you simply need to add k - 1, where k is the word-length used in velveth.
+The in and out columns correspond to the number of arcs on the 5' and 3' ends of the contig respectively.
+The coverages in columns short1 cov, short1 Ocov, short2 cov, and short2 Ocov are provided in k-mer coverage (5.1).
+Also, the difference between # cov and # Ocov is the way these values are computed. In the first count, slightly divergent sequences are added to the coverage tally. However, in the second, stricter count, only the sequences which map perfectly onto the consensus sequence are taken into account.
+
+**LastGraph**
+
+The *LastGraph* file.
+This file describes in its entirety the graph produced by Velvet.
+
+**AMOS.afg**
+
+The *velvet_asm.afg* file.
+This file is mainly designed to be read by the open-source AMOS genome assembly package. Nonetheless, a number of programs are available to transform this kind of file into other assembly file formats (namely ACE, TIGR, Arachne and Celera). See http://amos.sourceforge.net/ for more information.
+The file describes all the contigs contained in the contigs.fa file (cf 4.2.1).
+
+------
+
+**Velvet parameter list**
+
+This is a list of implemented Velvetg options::
+
+  Standard options:
+        -cov_cutoff  floating-point|auto : removal of low coverage nodes AFTER tour bus or allow the system to infer it
+                (default: no removal)
+        -ins_length  integer             : expected distance between two paired end reads (default: no read pairing)
+        -read_trkg  yes|no               : tracking of short read positions in assembly (default: no tracking)
+        -min_contig_lgth  integer        : minimum contig length exported to contigs.fa file (default: hash length * 2)
+        -amos_file  yes|no               : export assembly to AMOS file (default: no export)
+        -exp_cov  floating point|auto    : expected coverage of unique regions or allow the system to infer it
+                (default: no long or paired-end read resolution)
+
+  Advanced options:
+        -ins_length2  integer            : expected distance between two paired-end reads in the second short-read dataset (default: no read pairing)
+        -ins_length_long  integer        : expected distance between two long paired-end reads (default: no read pairing)
+        -ins_length*_sd  integer         : est. standard deviation of respective dataset (default: 10% of corresponding length)
+                [replace '*' by nothing, '2' or '_long' as necessary]
+        -scaffolding  yes|no             : scaffolding of contigs used paired end information (default: on)
+        -max_branch_length  integer      : maximum length in base pair of bubble (default: 100)
+        -max_divergence  floating-point  : maximum divergence rate between two branches in a bubble (default: 0.2)
+        -max_gap_count  integer          : maximum number of gaps allowed in the alignment of the two branches of a bubble (default: 3)
+        -min_pair_count  integer         : minimum number of paired end connections to justify the scaffolding of two long contigs (default: 10)
+        -max_coverage  floating point    : removal of high coverage nodes AFTER tour bus (default: no removal)
+        -long_mult_cutoff  int           : minimum number of long reads required to merge contigs (default: 2)
+        -unused_reads  yes|no            : export unused reads in UnusedReads.fa file (default: no)
+
+  Output:
+        directory/contigs.fa             : fasta file of contigs longer than twice hash length
+        directory/stats.txt              : stats file (tab-spaced) useful for determining appropriate coverage cutoff
+        directory/LastGraph              : special formatted file with all the information on the final graph
+        directory/velvet_asm.afg         : (if requested) AMOS compatible assembly file
+
+  </help>
+  <expand macro="citation"/>
+</tool>
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/velvetg_wrapper.py	Mon Nov 09 12:02:53 2015 -0500
@@ -0,0 +1,46 @@
+#!/usr/bin/env python
+
+"""
+Classes encapsulating decypher tool.
+James E Johnson - University of Minnesota
+"""
+import os
+import sys
+import subprocess
+
+assert sys.version_info[:2] >= ( 2, 4 )
+
+def stop_err( msg ):
+    sys.stderr.write( "%s\n" % msg )
+    sys.exit()
+
+
+def __main__():
+    #Parse Command Line
+    working_dir = sys.argv[1]
+    inputs = ' '.join(sys.argv[2:])
+    for _ in ('Roadmaps', 'Sequences'):
+        os.symlink(os.path.join(working_dir, _), _)
+    cmdline = 'velvetg . %s' % (inputs)
+    print "Command to be executed: %s" % cmdline
+    try:
+        proc = subprocess.Popen( args=cmdline, shell=True, stderr=subprocess.PIPE )
+        returncode = proc.wait()
+        # get stderr, allowing for case where it's very large
+        stderr = ''
+        buffsize = 1048576
+        try:
+            while True:
+                stderr += proc.stderr.read( buffsize )
+                if not stderr or len( stderr ) % buffsize != 0:
+                    break
+        except OverflowError:
+            pass
+        if returncode != 0:
+            raise Exception, stderr
+    except Exception, e:
+        stop_err( 'Error running velvetg ' + str( e ) )
+
+
+if __name__ == "__main__":
+    __main__()
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/velveth.xml	Mon Nov 09 12:02:53 2015 -0500
@@ -0,0 +1,136 @@
+<tool id="velveth" name="velveth" version="@WRAPPER_VERSION@.0">
+  <description>Prepare a dataset for the Velvet velvetg Assembler</description>
+  <version_command>velveth 2&gt;&amp;1 | grep "Version" | sed -e 's/Version //'</version_command>
+  <macros>
+    <import>macros.xml</import>
+  </macros>
+  <expand macro="requirements"/>
+  <expand macro="stdio"/>
+  <command interpreter="python">
+    velveth_wrapper.py
+           '$out_file1' '$out_file1.extra_files_path'
+           $hash_length
+           $strand_specific
+           #for $i in $inputs
+                ${i.file_format}
+                ${i.read_type}
+                ${i.input}
+           #end for
+  </command>
+  <inputs>
+    <param label="Hash Length" name="hash_length" type="select" help="k-mer length in base pairs of the words being hashed.">
+      <option value="11">11</option>
+      <option value="13">13</option>
+      <option value="15">15</option>
+      <option value="17">17</option>
+      <option value="19">19</option>
+      <option value="21" selected="yes">21</option>
+      <option value="23">23</option>
+      <option value="25">25</option>
+      <option value="27">27</option>
+      <option value="29">29</option>
+    </param>
+    <param name="strand_specific" type="boolean" checked="false" truevalue="-strand_specific" falsevalue="" label="Use strand specific transcriptome sequencing" help="If you are using a strand specific transcriptome sequencing protocol, you may wish to use this option for better results."/>
+    <repeat name="inputs" title="Input Files">
+      <param label="file format" name="file_format" type="select">
+        <option value="-fasta" selected="yes">fasta</option>
+        <option value="-fastq">fastq</option>
+        <option value="-eland">eland</option>
+        <option value="-gerald">gerald</option>
+      </param>
+      <param label="read type" name="read_type" type="select">
+        <option value="-short" selected="yes">short reads</option>
+        <option value="-shortPaired">shortPaired reads</option>
+        <option value="-short2">short2 reads</option>
+        <option value="-shortPaired2">shortPaired2 reads</option>
+        <option value="-long">long reads</option>
+        <option value="-longPaired">longPaired reads</option>
+      </param>
+
+      <param name="input" type="data" format="fasta,fastq,eland,gerald" label="Dataset"/>
+    </repeat>
+  </inputs>
+  <outputs>
+    <data format="velvet" name="out_file1" />
+  </outputs>
+  <requirements>
+    <requirement type="package">velvet</requirement>
+  </requirements>
+  <tests>
+    <test>
+      <param name="hash_length" value="21" />
+      <param name="read_type" value="-shortPaired" />
+      <!-- <repeat name="inputs"> -->
+      <param name="file_format" value="fasta" />
+      <param name="read_type" value="shortPaired reads" />
+      <param name="input" value="velvet_test_reads.fa" ftype="fasta" />
+      <!-- </repeat> -->
+      <param name="strand_specific" value="" />
+      <output name="out_file1" file="velveth_test1/output.html" lines_diff="4">
+        <extra_files type="file" name='Sequences' value="velveth_test1/Sequences" compare="diff" />
+        <extra_files type="file" name='Roadmaps' value="velveth_test1/Roadmaps" compare="diff" />
+      </output>
+    </test>
+  </tests>
+  <help>
+
+**What it does**
+
+Velvet_ is a de novo genomic assembler specially designed for short read sequencing technologies, such as Solexa or 454, developed by Daniel Zerbino and Ewan Birney at the European Bioinformatics Institute (EMBL-EBI), near Cambridge, in the United Kingdom.
+
+Velvet currently takes in short read sequences, removes errors then produces high quality unique contigs. It then uses paired-end read and long read information, when available, to retrieve the repeated areas between contigs.
+
+Read the Velvet `documentation`__ for details on using the Velvet Assembler.
+
+.. _Velvet: http://www.ebi.ac.uk/~zerbino/velvet/
+
+.. __: http://www.ebi.ac.uk/~zerbino/velvet/Manual.pdf
+
+------
+
+**Velveth**
+
+Velveth takes in a number of sequence files, produces a hashtable, then outputs two files in an output directory (creating it if necessary), Sequences and Roadmaps, which are necessary to velvetg.
+
+------
+
+**Hash Length**
+
+The hash length, also known as k-mer length, corresponds to the length, in base pairs, of the words being hashed.
+
+The hash length is the length of the k-mers being entered in the hash table. Firstly, you must observe three technical constraints::
+
+# it must be an odd number, to avoid palindromes. If you put in an even number, Velvet will just decrement it and proceed.
+# it must be below or equal to MAXKMERHASH length (cf. 2.3.3, by default 31bp), because it is stored on 64 bits
+# it must be strictly inferior to read length, otherwise you simply will not observe any overlaps between reads, for obvious reasons.
+
+Now you still have quite a lot of possibilities. As is often the case, it's a trade- off between specificity and sensitivity. Longer kmers bring you more specificity (i.e. less spurious overlaps) but lowers coverage (cf. below). . . so there's a sweet spot to be found with time and experience.
+We like to think in terms of "k-mer coverage", i.e. how many times has a k-mer been seen among the reads. The relation between k-mer coverage Ck and standard (nucleotide-wise) coverage C is Ck = C # (L - k + 1)/L where k is your hash length, and L you read length.
+Experience shows that this kmer coverage should be above 10 to start getting decent results. If Ck is above 20, you might be "wasting" coverage. Experience also shows that empirical tests with different values for k are not that costly to run!
+
+**Input Files**
+
+Velvet works mainly with fasta and fastq formats. For paired-end reads, the assumption is that each read is next to its mate
+read. In other words, if the reads are indexed from 0, then reads 0 and 1 are paired, 2 and 3, 4 and 5, etc.
+
+Supported file formats are::
+
+  fasta
+  fastq
+  fasta.gz
+  fastq.gz
+  eland
+  gerald
+
+Read categories are::
+
+  short (default)
+  shortPaired
+  short2 (same as short, but for a separate insert-size library)
+  shortPaired2 (see above)
+  long (for Sanger, 454 or even reference sequences)
+  longPaired
+
+  </help>
+  <expand macro="citation"/>
+</tool>
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/velveth_wrapper.py	Mon Nov 09 12:02:53 2015 -0500
@@ -0,0 +1,65 @@
+#!/usr/bin/env python
+
+"""
+Classes encapsulating decypher tool.
+James E Johnson - University of Minnesota
+"""
+import pkg_resources
+import logging, os, string, sys, tempfile, glob, shutil, types, urllib
+import shlex, subprocess
+from optparse import OptionParser, OptionGroup
+from stat import *
+
+
+log = logging.getLogger( __name__ )
+
+assert sys.version_info[:2] >= ( 2, 4 )
+
+def stop_err( msg ):
+    sys.stderr.write( "%s\n" % msg )
+    sys.exit()
+
+def __main__():
+    #Parse Command Line
+    s = 'velveth_wrapper.py:  argv = %s\n' % (sys.argv)
+    argcnt = len(sys.argv)
+    html_file = sys.argv[1]
+    working_dir = sys.argv[2]
+    try: # for test - needs this done
+        os.makedirs(working_dir)
+    except Exception, e:
+        stop_err( 'Error running velveth ' + str( e ) )
+    hash_length = sys.argv[3]
+    inputs = string.join(sys.argv[4:],' ')
+    cmdline = 'velveth %s %s %s > /dev/null' % (working_dir, hash_length, inputs)
+    try:
+        proc = subprocess.Popen( args=cmdline, shell=True, stderr=subprocess.PIPE )
+        returncode = proc.wait()
+        # get stderr, allowing for case where it's very large
+        stderr = ''
+        buffsize = 1048576
+        try:
+            while True:
+                stderr += proc.stderr.read( buffsize )
+                if not stderr or len( stderr ) % buffsize != 0:
+                    break
+        except OverflowError:
+            pass
+        if returncode != 0:
+            raise Exception, stderr
+    except Exception, e:
+        stop_err( 'Error running velveth ' + str( e ) )
+    sequences_path = os.path.join(working_dir,'Sequences')
+    roadmaps_path = os.path.join(working_dir,'Roadmaps')
+    rval = ['<html><head><title>Velvet Galaxy Composite Dataset </title></head><p/>']
+    rval.append('<div>%s<p/></div>' % (cmdline) )
+    rval.append('<div>This composite dataset is composed of the following files:<p/><ul>')
+    rval.append( '<li><a href="%s" type="text/plain">%s </a>%s</li>' % (sequences_path,'Sequences','Sequences' ) )
+    rval.append( '<li><a href="%s" type="text/plain">%s </a>%s</li>' % (roadmaps_path,'Roadmaps','Roadmaps' ) )
+    rval.append( '</ul></div></html>' )
+    f = file(html_file,'w')
+    f.write("\n".join( rval ))
+    f.write('\n')
+    f.close()
+
+if __name__ == "__main__": __main__()