/rgfa

Ruby library for handling GFA files

Primary LanguageRubyOtherNOASSERTION

The Graphical Fragment Assembly (GFA) is a proposed format which allow to describe the product of sequence assembly. This gem implements the proposed specifications for the GFA format described under https://github.com/GFA-spec/GFA-spec/blob/master/GFA-spec.md as close as possible.

The library allows to create a RGFA object from a file in the GFA format or from scratch, to enumerate the graph elements (segments, links, containments, paths and header lines), to traverse the graph (by traversing all links outgoing from or incoming to a segment), to search for elements (e.g. which links connect two segments) and to manipulate the graph (e.g. to eliminate a link or a segment or to duplicate a segment distributing the read counts evenly on the copies).

Installation

The latest release of the gem can be installed from the rubygems repository using: gem install rgfa

Alternatively this git repository can be cloned or the source code installed from a release archive, and then the gem created and installed using: rake install

Usage

To use the library in your Ruby scripts, just require it as follows: require "rgfa"

Additional functionality, which requires custom tags and additional conventions, is included in a separate part of the code named {RGFATools} and can be accessed with: require "rgfatools"

Documentation

A cheatsheet is available as pdf under https://github.com/ggonnella/rgfa/blob/master/cheatsheet/rgfa-cheatsheet-1.3.1.pdf

The full API documentation is available as pdf under https://github.com/ggonnella/rgfa/blob/master/pdfdoc/rgfa-api-1.3.1.pdf or in HTML format (http://www.rubydoc.info/github/ggonnella/rgfa/master/RGFA).

The main class of the library is {RGFA}, which is a good starting point when reading the documentation.

References

Gonnella G, Kurtz S. (2016) RGFA: powerful and convenient handling of assembly graphs. PeerJ 4:e2681 https://doi.org/10.7717/peerj.2681