PhyloSoC:BioPerl integration of the NeXML exchange standard and Bio::Phylo toolkit/nexml module design

From Phyloinformatics
Revision as of 08:16, 15 June 2009 by Chmille4 (talk) (Nexml Item Module Design (work in progress))
Jump to: navigation, search

Nexml Item Module Design (work in progress)

Overview

Currently, parsing a nexml file into Bioperl makes use of the *IO modules (AlignIO, SeqIO, and TreeIO) to load nexml represented data into Bioperl objects. These modules will handle each data type separately, but the ultimate goal is to make this easier on the user and allow the full parsing of a nexml document into a bioperl object that can contain each data type and maintain the relationships between them. To accomplish this, a Bio::Nexml module will be created that will act as a representation of an entire Nexml document and will hold seq, aln, and tree objects. Creating a new class will provide a way to maintain relationships between the data and will also make it more clear to the user that this represents an entire nexml document. It will be a simple container that lets the majority of the work be done by the object classes it contains making use of the modules/methods previously written during this project.

Synopsis

#something like this
#create and cache an xml parser linked to the stream
$nexml_doc = Bio::NeXML->new(-file=>'a_nexml_file.xml');
#allow reading of different object types
#by using previously implemented method Bio::TreeIO::Nexml->next_tree()
$tree = $nexml_doc->next_tree()

Data Relationships to Maintain

  • Sequences <=> Nodes
  • Alignments <=> Trees
  • Taxa <=> Trees
  • Taxa <=> Alignments
  • Taxon <=> Node