TruSPAdes 1.0 Manual
1. About truSPAdes
    1.1. Illumina TruSeq data
    1.2. TruSPAdes input
    1.3. TruSPAdes performance
    1.4. Installation
2. TruSPAdes input format
    1.2.1. Dataset file format
    1.2.2. Read files naming for automatic dataset file generation
3. Running truSPAdes
    3.1. TruSPAdes command line options
    3.2. TruSPAdes output
4. Citation
5. Feedback and bug reports
1. About truSPAdes
    TruSPAdes is an assembler for short reads produced by Illumina TruSeq Long Read technology.
    TruSPAdes accepts as an input a collection of demultiplexed TruSeq reads and assembles long virtual reads.
    This manual will help you to use truSPAdes.
1.1 Illumina TruSeq data
    TruSeq Synthetic Long Reads technology is based on fragmenting genomic DNA into large segments (about 10Kb long) and forming random pools of the resulting segments (each pool contains about 300 segments).
    Next, these fragments are clonally amplified, sheared, and marked with a unique barcode.
    Afterwards, they are sequenced using the standard Illumina short reads technology.
    All short reads originating from the same barcode are assembled together resulting in a set of long contigs (this step is called TruSeq barcode assembly).
    Ideally, the result of such sequencing effort for a single barcode is the collection of 300 fragments (each fragment is about 10kb long) from a genome forming 300 long virtual reads.
    Together, these segments are expected to cover about 3 million nucleotides (barcode span).
    TruSPAdes is a tool for barcode assembly.
    TruSPAdes assembles each barcode separately and outputs assembled contigs as Virtual TruSeq Long Reads (TSLRs).
1.2 TruSPAdes input
    TruSPAdes requires demultiplexed sequencing data as an input.
    Each barcode is assembled from one or several (in case multiple lanes are available) libraries of paired-end reads in fastq format.
    Also note that truSPAdes can handle both compressed and decompressed reads.
    TruSPAdes uses dataset file format for TruSeq dataset description.
    Dataset file can be either created manually or generated automatically. 
    Since TruSeq reads are provided as a service by Illumina, most TruSeq read files have particular naming patterns that we use for autogeneration of dataset file.
    See details in section 2.
1.3 TruSPAdes performance
    TruSPAdes assembles standard Illumina TruSeq dataset (consisting of 384 barcodes) in 30 hours using 8 threads of Intel Xeon 2.27GHz processor and requires less than 16 Gb RAM (2Gb RAM per thread).
1.4 Installation
    TruSPAdes comes as a part of SPAdes genome assembler. See SPAdes manual for installation instructions.
2. TruSPAdes input format
    TruSPAdes uses dataset file format for TruSeq dataset description.
    Dataset file can be either created manually or generated automatically.
    Below we describe dataset file format and conditions that enable automatic generation of dataset files.
2.1 Dataset file format
    Dataset file describes a collection of read files.
    Each line in dataset file contains description of reads corresponding to a single barcode.
    Description should start with id of barcode (a string consisting of letters and digits) followed by paths to reads.
    For example, for dataset with three barcodes dataset file should look like this:
    barcodeId1 /FULL_PATH_TO_LEFT_READS1/LEFT_READS_FILE_NAME1.fastq.gz /FULL_PATH_TO_RIGHT_READS1/RIGHT_READS_FILE_NAME1.fastq.gz
    barcodeId2 /FULL_PATH_TO_LEFT_READS2/LEFT_READS_FILE_NAME2.fastq.gz /FULL_PATH_TO_RIGHT_READS2/RIGHT_READS_FILE_NAME2.fastq.gz
    barcodeId3 /FULL_PATH_TO_LEFT_READS3/LEFT_READS_FILE_NAME3.fastq.gz /FULL_PATH_TO_RIGHT_READS3/RIGHT_READS_FILE_NAME3.fastq.gz
    In case several lanes are available for a barcode, reads for each lane should be provided in the same line.
    Reads from the same barcode should be written consequently, e.g., in case two lanes are available for barcode, its description should look like this:
    barcodeId /LEFT_READS_PATH_L1.fastq.gz /RIGHT_READS_PATH_L1.fastq.gz /LEFT_READS_PATH_L2.fastq.gz /RIGHT_READS_PATH_L2.fastq.gz
Dataset file can be provided using --dataset option (see section 3).
2.2 Read files naming for automatic dataset file generation
    Since TruSeq reads are provided as a service by Illumina, most TruSeq read files have particular naming patterns that we use to automatically generate dataset files.
    If read naming in your dataset reads satisfies conditions described below you can avoid manual creation of dataset file and use --input-dir option instead (see section 3).
    The conditions that enable automatic dataset file generation are as follows:
    
        - All reads should be in one or several directories provided using --input-diroption
- No other files should be present in these directories
- Names of files with left (right) reads should contain "R1" ("R2") as their substring.
- Files with left and right reads of the same library should be in the same directory and their names should differ only by substitution of "R1" to "R2"
- In case several lanes are available, reads from the same lane can be marked with "L<n>" label (i.e. contain it as a substring of read name) where <n> is the lane number. 
- Reads from the same barcode but from different lanes can be put into different directories but their names should either coinside or differ only by "L" markings.
- All barcodes should have the same number of paired-end libraries (lanes). This is to check for possibly missing or extra files in input directories.
For example dataset with two lanes and two barcodes can be put into single directory with the following file naming:
    dataset-directory:
        reads_L1_R1.fastq
        reads_L1_R2.fastq
        reads_L2_R1.fastq
        reads_L2_R2.fastq
 
    Or dataset files can be put into two directories:
    dataset_directory_L1:
        reads_R1.fastq
        reads_R2.fastq
    dataset_directory_L2:
        reads_R1.fastq
        reads_R2.fastq
 
    
3. Running truSPAdes
3.1 TruSPAdes command line options 
    To run truSPAdes from the command line, type 
    truspades.py [options] -o <output_dir>
Note that we assume that truSPAdes installation directory is added to the PATH variable (provide full path to truSPAdes executable otherwise: <truspades installation dir>/truspades.py). 
Basic options
    -o <output_dir> 
        Specify the output directory. Required option.
    -h (or --help)
        Prints help.
    -v (or --version)
        Prints version.
    --continue
        Continues truSPAdes run from the specified output folder.
    -t <int> (or --threads <int>)
        Number of threads. The default value is 8.
Input data
    --dataset <file_name> 
        Dataset file foratted as specified in section 2.1.
    --input-dir <dir_name> 
        Directory containing reads. Note that naming of read files should satisfy conditions described in section 2.2.
3.2. TruSPAdes output
    TruSPAdes stores all output files in <output_dir> , which is set by the user.
    Resulting TruSeq long reads will be stored in <output_dir>/TSLRs.fastq
    The full list of <output_dir> content is presented below: 
    TSLRs.fastq – resulting truseq long reads
    TSLRs.fasta – resulting truseq long reads in fasta format
    dataset.info – dataset file
    truspades.log – truSPAdes log file
    barcodes – directory containing output files for separate barcodes
    logs – directory containing log files for barcode assembly
4. Citation
    If you use truSPAdes in your research, please include Bankevich & Pevzner, 2016 in your reference list.
5. Feedback and bug reports
    Your comments, bug reports, and suggestions are very welcomed. They will help us to further improve truSPAdes.
    
    If you have any troubles running truSPAdes, please send us dataset.info and truspades.log from the directory <output_dir>.
    Address for communications: spades.support@bioinf.spbau.ru.