# Bio::ViennaNGS 0.17.1

Bio::ViennaNGS is a distribution of Perl modules and utilities for
building efficient Next-Generation Sequencing (NGS) analysis
pipelines. It covers various aspects of NGS data analysis, including
(but not limited to) conversion of sequence annotation, evaluation of
mapped data, expression quantification and visualization.

Bio::ViennaNGS is shipped with a complementary set of modules, classes and
roles:

- Bio::ViennaNGS::AnnoC
  A Moose interface for storage and conversion of sequence annotation
  data.

- Bio::ViennaNGS::Bam
  Routines for high-level manipulation of BAM files.

- Bio::ViennaNGS::Bed 
  A Moose interface for manipulation of genomic interval data in BED
  format.

- Bio::ViennaNGS::BedGraphEntry
  A Moose interface for storing genomic cvoerage and interval data in
  bedGraph format.

- Bio::ViennaNGS::Expression
  A Moose interface for computation of normalized gene / transcript
  expression based on read counts.

- Bio::ViennaNGS::ExtFeature
  A Moose wrapper for extended BED6 elements.

- Bio::ViennaNGS::Fasta
  Routines for accessing genomic sequences implemented through a Moose
  interface to Bio::DB::Fasta.

- Bio::ViennaNGS::Feature
  A Moose-based BED6 wrapper.  

- Bio::ViennaNGS::FeatureChain
  Yet another Moose class for chaining gene annotation features. 

- Bio::ViennaNGS::FeatureInterval
  A Moose interface for handling elementary genomic intervals,
  corresponding to BED3.

- Bio::ViennaNGS::FeatureIO
  A Moose interface for easy input/output operations on common feature
  annotation file formats.

- Bio::ViennaNGS::FeatureLine
  An abstract Moose class for combining several
  Bio::ViennaNGS::FeatureChain objects.

- Bio::ViennaNGS::MinimalFeature
  A Moose interface for handling elementary gene annotation, corresponding
  to BED4.

- Bio::ViennaNGS::Peak
  A Moose interface for identification and characterization of (coverage /
  expression) peaks in RNA-seq data.

- Bio::ViennaNGS::SpliceJunc
  A collection of routines for alternative splicing analysis.

- Bio::ViennaNGS::Subtypes
  Moose subtypes for internal usage.

- Bio::ViennaNGS::Tutorial
  A comprehensive tutorial of the Bio::ViennaNGS core routines with
  real-world NGS data.

- Bio::ViennaNGS::UCSC
  Routines for visualization of genomics data with the UCSC genome
  browser.

- Bio::ViennaNGS::Util
  A collection of wrapper routines for commonly used third-party NGS
  utilities as well as a set of utility functions.


## UTILITIES

In addition, Bio::ViennaNGS comes with a collection of utility
programs for accomplishing routine tasks often required in NGS data
processing. These utilities serve as reference implementation of the
routines implemented in the (sub)modules:

assembly_hub_constructor.pl:
The UCSC genome browser offers the possibility to visualize any
organism (including organisms that are not included in the standard
UCSC browser bundle) through hso called 'Assembly Hubs'. This script
constructs Assembly Hubs from genomic sequence and annotation data.

bam_split.pl: 
Split (paired-end and single-end) BAM alignment files by strand and compute
statistics. Optionally create BED output, as well as normalized bedGraph
and bigWig files for coverage visualization in genome browsers (see
dependencies on third-patry tools below).

bam_to_bigWig.pl:
Produce bigWig coverage profiles from (aligned) BAM files, explicitly
considering strandedness. The most natural use case of this tool is to
create strand-aware coverage profiles in bigWig format for genome browser
visualization.

bam_uniq.pl:
Extract unique and multi mapping reads from BAM alignment files and create
a separate BAM file for both uniqe (.uniq.) and multi (.mult.) mappers.

bed2bedGraph.pl:
Convert BED files to (strand specific) bedGraph files, allowing
additional annotation and automatic generation of bedGraph files which can
easily be converted to big-type files for easy UCSC visualization.

bed2nt2aa.pl:
Extract sequence intervals from Fasta files, provided as BED6
records. Optionally translate nucleotide into amino acid sequences.

bed62bed12.pl:
A simple BED6 -> BED12 converter

fasta_multigrep.pl
Extract individual (whole) sequences from a multi Fasta file

fasta_subgrep.pl:
Extract subsequences from (multi) Fasta files.

gff2bed.pl:
Convert RefSeq GFF3 annotation files to BED12 format. Individual BED12
files are created for each feature type (CDS/tRNA/rRNA/etc.). Tested with
RefSeq bacterial GFF3 annotation.  

kmer_analysis.pl:
Count k-mers of predefined length in FastQ and Fasta files

newUCSCdb.pl:
Create a new genome database to a locally installed instance of the UCSC
genome browser in order to add a novel organism for visualization.

normalize_multicov.pl: 
Compute normalized expression data in TPM and RPKM from (raw) read counts
in bedtools multicov format. TPM reference: Wagner et al, Theory
Biosci. 131(4), pp 281-85 (2012).

rnaseq_peakfinder.pl:
Find and characterize peaks/enriched regions of certain size and coverage
in RNA-seq data.

sj_visualizer.pl:
Convert splice junctions from mapped RNA-seq data in segemehl BED6 splice
junction format to BED12 for easy visualization in genome browsers.

splice_site_summary.pl:
Identify and characterize splice junctions from RNA-seq data by
intersecting them with annotated splice junctions.

track_hub_constructor.pl:
Analogous to assembly_hub_constructor.pl, construct a Track Hub for an
organism listed in the UCSC Genome Browser.

trim_fastq.pl:
Trim sequence and quality string fields in a Fastq file by user
defined length.


## TUTORIAL

See Bio::ViennaNGS::Tutorial 


## INSTALLATION

We have compiled a comprehensive `ViennaNGS Installation HOWTO` which
covers the setup of third party and Perl dependencies in detail:

http://rna-seq.at/blog/2015/03/03/viennangs-installation-howto/

If you have already installed all dependencies, the ViennaNGS distribution
can be installed with the following commands:

   perl Makefile.PL
   make
   make test
   make install

However, we highly recommend using *cpanminus* for installing ViennaNGS. If
you have cpanm available on your system, simply type

  cpanm Bio::ViennaNGS

This command will grab the lastest ViennaNGS release from CPAN together
with all Perl dependencies and install the suite automatically (provided
you have samtools <= 0.1.19 installed, see the HOWTO link above).


## SUPPORT AND DOCUMENTATION

After installing, you can find documentation for this module with the
perldoc command.

    perldoc Bio::ViennaNGS

You can also look for information at:

    RT, CPAN's request tracker (report bugs here)
        http://rt.cpan.org/NoAuth/Bugs.html?Dist=Bio-ViennaNGS

    AnnoCPAN, Annotated CPAN documentation
        http://annocpan.org/dist/Bio-ViennaNGS

    CPAN Ratings
        http://cpanratings.perl.org/d/Bio-ViennaNGS

    Search CPAN
        http://search.cpan.org/dist/Bio-ViennaNGS


## DEPENDENCIES

Bio::ViennaNGS depends on a set of third-party tools and libraries which
are required for specific filtering and file format conversion tasks as
well as for building internally used Perl modules:

* bedtools2 >= 2.17 (https://github.com/arq5x/bedtools2) 
* bedGraphToBigWig, fetchChromSizes, faToTwoBit from the UCSC Genome
  Browser applications (http://hgdownload.cse.ucsc.edu/admin/exe/)
* the R Statistics software (http://www.r-project.org/)
* samtools <= v0.1.19 for building Bio::DB::Sam. Please note that more
  recent HTSlib-based versions of samtools will not work with Bio::DB::Sam 

Please ensure that all third-party utilities are available on your system
and accessible to the Perl interpreter.

Moreover, Bio::ViennaNGS depends on a ste of Perl packages that are not
shipped with the Perl core distribution, most notably Bio::Perl >=
1.00690001 and Bio::DB::Sam >= 1.37.


## SOURCE AVAILABILITY

This source is available on Github: 
              https://github.com/mtw/Bio-ViennaNGS


## VIENNANGS PAPER

If the Bio::ViennaNGS suite is useful for your work or if you use any
component of Bio::ViennaNGS in a custom pipeline, please cite the following
publication:

"ViennaNGS - A toolbox for building efficient next-generation sequencing
analysis pipelines"
Michael T. Wolfinger, Joerg Fallmann, Florian Eggenhofer and Fabian Amman
F1000Research 4:50 (2015)
DOI: http://dx.doi.org/10.12688/f1000research.6157.2


## NOTES

The Bio::ViennaNGS suite is actively developed and tested on different
flavours of Linux and Mac OS X. We have taken care of writing
platform-independent code that should run out of the box on most UNIX-based
systems, however we do not have access to machines running Microsoft
Windows. As such Microsoft Windows compatibility is not tested.


## BUGS

Please report bugs through the Github issue tracker at
https://github.com/mtw/Bio-ViennaNGS/issues


## AUTHORS

Michael T. Wolfinger <michael@wolfinger.eu>
Joerg Fallmann <fall@tbi.univie.ac.at>
Florian Eggenhofer <florian.eggenhofer@tbi.univie.ac.at>
Fabian Amman <fabian@tbi.univie.ac.at>


## COPYRIGHT AND LICENCE

Copyright (C) 2014-2017 Michael T. Wolfinger <michael@wolfinger.eu>

This library is free software; you can redistribute it and/or modify it
under the same terms as Perl itself, either Perl version 5.10.0 or, at your
option, any later version of Perl 5 you may have available.

This program is distributed in the hope that it will be useful, but WITHOUT
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
more details.