plucky (3) Bio::SeqFeature::Annotated.3pm.gz

Provided by: libbio-featureio-perl_1.6.905-2_all bug

NAME

       Bio::SeqFeature::Annotated - PLEASE PUT SOMETHING HERE

SYNOPSIS

           # none yet, complain to authors

DESCRIPTION

       None yet, complain to authors.

Implemented Interfaces

       This class implements the following interfaces.

       Bio::SeqFeatureI
           Note that this includes implementing Bio::RangeI.

       Bio::AnnotatableI
       Bio::FeatureHolderI
           Features held by a feature are essentially sub-features.

FEEDBACK

   Mailing Lists
       User feedback is an integral part of the evolution of this and other Bioperl modules. Send your comments
       and suggestions preferably to one of the Bioperl mailing lists.  Your participation is much appreciated.

         bioperl-l@bioperl.org                  - General discussion
         http://bioperl.org/wiki/Mailing_lists  - About the mailing lists

   Support
       Please direct usage questions or support issues to the mailing list:

       bioperl-l@bioperl.org

       rather than to the module maintainer directly. Many experienced and reponsive experts will be able look
       at the problem and quickly address it. Please include a thorough description of the problem with code and
       data examples if at all possible.

   Reporting Bugs
       Report bugs to the Bioperl bug tracking system to help us keep track the bugs and their resolution.  Bug
       reports can be submitted via the web:

         http://bugzilla.open-bio.org/

AUTHOR - Allen Day

       Allen Day <allenday at ucla.edu>

APPENDIX

       The rest of the documentation details each of the object methods. Internal methods are usually preceded
       with a _

PREAMBLE

       Okay, where to start...

       The original idea for this class appears to lump all SeqFeatureI data (primary_tag, source_tag, etc) into
       AnnotationI objects into an Bio::Annotation::Collection. The type is then checked against SOFA.

       There have been several requests to have type checking be optionally run.

       Bio::FeatureHolderI::create_hierarchy_from_ParentIDs Bio::FeatureHolderI::feature_count
       Bio::FeatureHolderI::get_all_SeqFeatures Bio::FeatureHolderI::set_ParentIDs_from_hierarchy
       Bio::RangeI::contains Bio::RangeI::disconnected_ranges Bio::RangeI::equals Bio::RangeI::intersection
       Bio::RangeI::offsetStranded Bio::RangeI::overlap_extent Bio::RangeI::overlaps Bio::RangeI::subtract
       Bio::RangeI::union Bio::SeqFeature::Annotated::Dumper Bio::SeqFeature::Annotated::MAX_TYPE_CACHE_MEMBERS
       Bio::SeqFeature::Annotated::add_Annotation Bio::SeqFeature::Annotated::add_SeqFeature
       Bio::SeqFeature::Annotated::add_tag_value Bio::SeqFeature::Annotated::add_target
       Bio::SeqFeature::Annotated::annotation Bio::SeqFeature::Annotated::attach_seq
       Bio::SeqFeature::Annotated::display_name Bio::SeqFeature::Annotated::each_target
       Bio::SeqFeature::Annotated::end Bio::SeqFeature::Annotated::entire_seq Bio::SeqFeature::Annotated::frame
       Bio::SeqFeature::Annotated::from_feature Bio::SeqFeature::Annotated::get_Annotations
       Bio::SeqFeature::Annotated::get_SeqFeatures Bio::SeqFeature::Annotated::get_all_tags
       Bio::SeqFeature::Annotated::get_tag_values Bio::SeqFeature::Annotated::get_tagset_values
       Bio::SeqFeature::Annotated::has_tag Bio::SeqFeature::Annotated::length
       Bio::SeqFeature::Annotated::location Bio::SeqFeature::Annotated::name Bio::SeqFeature::Annotated::new
       Bio::SeqFeature::Annotated::phase Bio::SeqFeature::Annotated::primary_tag
       Bio::SeqFeature::Annotated::remove_Annotations Bio::SeqFeature::Annotated::remove_SeqFeatures
       Bio::SeqFeature::Annotated::remove_tag Bio::SeqFeature::Annotated::score Bio::SeqFeature::Annotated::seq
       Bio::SeqFeature::Annotated::seq_id Bio::SeqFeature::Annotated::source
       Bio::SeqFeature::Annotated::source_tag Bio::SeqFeature::Annotated::start
       Bio::SeqFeature::Annotated::strand Bio::SeqFeature::Annotated::type
       Bio::SeqFeature::Annotated::uri_escape Bio::SeqFeature::Annotated::uri_unescape
       Bio::SeqFeature::TypedSeqFeatureI::croak Bio::SeqFeature::TypedSeqFeatureI::ontology_term
       Bio::SeqFeatureI::generate_unique_persistent_id Bio::SeqFeatureI::gff_string Bio::SeqFeatureI::primary_id
       Bio::SeqFeatureI::spliced_seq

ATTRIBUTE ACCESSORS FOR Bio::SeqFeature::Annotated

   from_feature
         Usage: $obj->from_feature($myfeature);
         Desc : initialize this object with the contents of another feature
                object.  Useful for converting objects like
                L<Bio::SeqFeature::Generic> to this class
         Ret  : nothing meaningful
         Args : a single object of some other feature type,
         Side Effects: throws error on failure
         Example:

   seq_id()
        Usage   : $obj->seq_id($newval)
        Function: holds a string corresponding to the unique
                  seq_id of the sequence underlying the feature
                  (e.g. database accession or primary key).
        Returns : string representing the seq_id.
        Args    : on set, some string or a Bio::Annotation::SimpleValue object.

   name()
        Usage   : $obj->name($newval)
        Function: human-readable name for the feature.
        Returns : value of name (a scalar)
        Args    : on set, new value (a scalar or undef, optional)

   type()
        Usage   : $obj->type($newval)
        Function: a SOFA type for the feature.
        Returns : Bio::Annotation::OntologyTerm object representing the type.
                  NB: to get a string, use primary_tag().
        Args    : on set, Bio::Annotation::OntologyTerm object.
                  NB: to set a string (SOFA name or identifier), use primary_tag()

   source()
        Usage   : $obj->source($newval)
        Function: holds the source of the feature.
        Returns : a Bio::Annotation::SimpleValue representing the source.
                  NB: to get a string, use source_tag()
        Args    : on set, a Bio::Annotation::SimpleValue object.
                  NB: to set a string, use source_tag()

   score()
        Usage   : $score = $feat->score()
                  $feat->score($score)
        Function: holds a value corresponding to the score of the feature.
        Returns : a string representing the score.
        Args    : on set, a scalar or a Bio::Annotation::SimpleValue object.

   phase()
        Usage   : $phase = $feat->phase()
                  $feat->phase($phase)
        Function: get/set on phase information
        Returns : a string 0,1,2,'.'
        Args    : on set, one of 0,1,2,'.' or a Bio::Annotation::SimpleValue
                  object holding one of 0,1,2,'.' as its value.

   frame()
        Usage   : $frame = $feat->frame()
                  $feat->frame($phase)
        Function: get/set on phase information
        Returns : a string 0,1,2,'.'
        Args    : on set, one of 0,1,2,'.' or a Bio::Annotation::SimpleValue
                  object holding one of 0,1,2,'.' as its value.

SHORTCUT METHODS TO ACCESS Bio::AnnotatableI INTERFACE METHODS

   add_Annotation()
        Usage   :
        Function: $obj->add_Annotation() is a shortcut to $obj->annotation->add_Annotation
        Returns :
        Args    :

   remove_Annotations()
        Usage   :
        Function: $obj->remove_Annotations() is a shortcut to $obj->annotation->remove_Annotations
        Returns :
        Args    :

INTERFACE METHODS FOR Bio::SeqFeatureI

       Note that no methods are deprecated.  Any SeqFeatureI methods must return strings (no objects).

   display_name()
   primary_tag()
   source_tag()
   attach_seq()
        Usage   : $sf->attach_seq($seq)
        Function: Attaches a Bio::Seq object to this feature. This
                  Bio::Seq object is for the *entire* sequence: ie
                  from 1 to 10000
        Returns : TRUE on success
        Args    : a Bio::PrimarySeqI compliant object

   seq()
        Usage   : $tseq = $sf->seq()
        Function: returns a truncated version of seq() with bounds matching this feature
        Returns : sub seq (a Bio::PrimarySeqI compliant object) on attached sequence
                  bounded by start & end, or undef if there is no sequence attached
        Args    : none

   entire_seq()
        Usage   : $whole_seq = $sf->entire_seq()
        Function: gives the entire sequence that this seqfeature is attached to
        Returns : a Bio::PrimarySeqI compliant object, or undef if there is no
                  sequence attached
        Args    : none

INTERFACE METHODS FOR Bio::RangeI

        as inherited via Bio::SeqFeatureI

   length()
        Usage   : $feature->length()
        Function: Get the feature length computed as $feat->end - $feat->start + 1
        Returns : integer
        Args    : none

   start()
        Usage   : $obj->start($newval)
        Function: Get/set on the start coordinate of the feature
        Returns : integer
        Args    : on set, new value (a scalar or undef, optional)

   end()
        Usage   : $obj->end($newval)
        Function: Get/set on the end coordinate of the feature
        Returns : integer
        Args    : on set, new value (a scalar or undef, optional)

   strand()
        Usage   : $strand = $feat->strand($newval)
        Function: get/set on strand information, being 1,-1 or 0
        Returns : -1,1 or 0
        Args    : on set, new value (a scalar or undef, optional)

INTERFACE METHODS FOR Bio::FeatureHolderI

       This includes methods for retrieving, adding, and removing features. Since this is already a feature,
       features held by this feature holder are essentially sub-features.

   get_SeqFeatures
        Usage   : @feats = $feat->get_SeqFeatures();
        Function: Returns an array of Bio::SeqFeatureI objects
        Returns : An array
        Args    : none

   add_SeqFeature()
        Usage   : $feat->add_SeqFeature($subfeat);
                  $feat->add_SeqFeature($subfeat,'EXPAND')
        Function: adds a SeqFeature into the subSeqFeature array.
                  with no 'EXPAND' qualifer, subfeat will be tested
                  as to whether it lies inside the parent, and throw
                  an exception if not.

                  If EXPAND is used, the parent''s start/end/strand will
                  be adjusted so that it grows to accommodate the new
                  subFeature
        Example :
        Returns : nothing
        Args    : a Bio::SeqFeatureI object

   remove_SeqFeatures()
        Usage   : $obj->remove_SeqFeatures
        Function: Removes all sub SeqFeatures.  If you want to remove only a subset,
                  remove that subset from the returned array, and add back the rest.
        Returns : The array of Bio::SeqFeatureI implementing sub-features that was
                  deleted from this feature.
        Args    : none

INTERFACE METHODS FOR Bio::AnnotatableI

   annotation()
        Usage   : $obj->annotation($annot_obj)
        Function: Get/set the annotation collection object for annotating this
                  feature.
        Returns : A Bio::AnnotationCollectionI object
        Args    : newvalue (optional)

   location()
        Usage   : my $location = $seqfeature->location()
        Function: returns a location object suitable for identifying location
                  of feature on sequence or parent feature
        Returns : Bio::LocationI object
        Args    : [optional] Bio::LocationI object to set the value to.

   add_target()
        Usage   : $seqfeature->add_target(Bio::LocatableSeq->new(...));
        Function: adds a target location on another reference sequence for this feature
        Returns : true on success
        Args    : a Bio::LocatableSeq object

   each_target()
        Usage   : @targets = $seqfeature->each_target();
        Function: Returns a list of Bio::LocatableSeqs which are the locations of this object.
                  To obtain the "primary" location, see L</location()>.
        Returns : a list of 0..N Bio::LocatableSeq objects
        Args    : none

   _expand_region
        Title   : _expand_region
        Usage   : $self->_expand_region($feature);
        Function: Expand the total region covered by this feature to
                  accomodate for the given feature.

                  May be called whenever any kind of subfeature is added to this
                  feature. add_SeqFeature() already does this.
        Returns :
        Args    : A Bio::SeqFeatureI implementing object.

   get_Annotations
        Usage   : my $parent   = $obj->get_Annotations('Parent');
                  my @parents = $obj->get_Annotations('Parent');
        Function: a wrapper around Bio::Annotation::Collection::get_Annotations().
        Returns : returns annotations as
                  Bio::Annotation::Collection::get_Annotations() does, but
                  additionally returns a single scalar in scalar context
                  instead of list context so that if an annotation tag
                  contains only a single value, you can do:

                  $parent = $feature->get_Annotations('Parent');

                  instead of:

                  ($parent) = ($feature->get_Annotations('Parent'))[0];

                  if the 'Parent' tag has multiple values and is called in a
                  scalar context, the number of annotations is returned.

        Args    : an annotation tag name.

Bio::SeqFeatureI implemented methods

       These are specialized implementations of SeqFeatureI methods which call the internal
       Bio::Annotation::AnnotationCollection object. Just prior to the 1.5 release the below methods were moved
       from Bio::SeqFeatureI to Bio::AnnotatableI, and having Bio::SeqFeatureI inherit Bio::AnnotatableI. This
       behavior forced all Bio::SeqFeatureI-implementing classes to use Bio::AnnotationI objects for any data.
       It is the consensus of the core developers that this be rolled back in favor of a more flexible approach
       by rolling back the above changes and making this class Bio::AnnotatableI. The SeqFeatureI tag-related
       methods are reimplemented in order to approximate the same behavior as before.

       The methods below allow mapping of the "get_tag_values()"-style annotation access to
       Bio::AnnotationCollectionI. These need not be implemented in a Bio::AnnotationCollectionI compliant
       class, as they are built on top of the methods.  For usage, see Bio::SeqFeatureI.

   has_tag
   add_tag_value
   get_tag_values
        Usage   : @annotations = $obj->get_tag_values($tag)
        Function: returns annotations corresponding to $tag
        Returns : a list of scalars
        Args    : tag name

   get_tagset_values
        Usage   : @annotations = $obj->get_tagset_values($tag1,$tag2)
        Function: returns annotations corresponding to a list of tags.
                  this is a convenience method equivalent to multiple calls
                  to get_tag_values with each tag in the list.
        Returns : a list of Bio::AnnotationI objects.
        Args    : a list of tag names

   get_all_tags
        Usage   : @tags = $obj->get_all_tags()
        Function: returns a list of annotation tag names.
        Returns : a list of tag names
        Args    : none

   remove_tag
        Usage   : See remove_Annotations().
        Function:
        Returns :
        Args    :
        Note    : Contrary to what the name suggests, this method removes
                  all annotations corresponding to $tag, not just a
                  single anntoation.