The London Perl and Raku Workshop takes place on 26th Oct 2024. If your company depends on Perl, please consider sponsoring and/or attending.

NAME

Tree::Interval::Fast::Interval - Represents an interval in an instance of Tree::Interval::Fast

VERSION

Version 0.0.1

DESCRIPTION

An interval in an interval tree. It is meant to be used in conjuction with an instance of Tree::Interval::Fast.

SEE ALSO

Tree::Interval::Fast - The interval tree storing instances of Tree::Interval::Fast::Interval

SYNOPSIS

You can create an interval by specifying the range and the data it holds.

    use Tree::Interval::Fast::Interval;

    # create an interval representing the range (15.0, 20.0) which holds
    # a simple integer
    my $interval1 = Tree::Interval::Fast::Interval->new(15, 20, 10);
    
    # another interval with more complicated data
    my $interval2 = Tree::Interval::Fast::Interval->new(10.0, 30.0, [1, 2, 3]);

    # this one holds a hash instead
    my $interval2 = Tree::Interval::Fast::Interval->new(10.0, 30.0, { a=>1, b=>2 });
    ...

    # can get the left/right boundaries of each of the intervals
    printf "I1: (%.2f, %.2f)\n", $interval1->low, $interval1->high;

    # can get the data associated with each interval
    use Data::Dumper;
    print Dumper $interval2->data;
    

METHODS

new

  Arg [1]     : Float; the left boundary of the interval
  Arg [2]     : Float; the right boundary of the interval
  Arg [3]     : Anything; the data associated with the interval

  Example     : my $i = Tree::Interval::Fast::Interval->new(10, 20, [1,2,3]);
                carp "Unable to instantiate tree" unless defined $i;

  Description : Creates a new interval tree object which holds some data

  Returntype  : An instance of Tree::Interval::Fast::Interval or undef
  Exceptions  : None
  Caller      : General
  Status      : Stable

low

  Arg [...]   : None
  
  Example     : my $left = $tree->low;

  Description : Get the left boundary of the interval.

  Returntype  : Float
  Exceptions  : None
  Caller      : General
  Status      : Stable

high

  Arg [...]   : None
  
  Example     : my $right = $tree->high;

  Description : Get the right boundary of the interval.

  Returntype  : Float
  Exceptions  : None
  Caller      : General
  Status      : Stable

data

  Arg [...]   : None
  
  Example     : print Dumper $tree->data;

  Description : Get the data associated to the interval.

  Returntype  : The type of the data stored in the interval 
  Exceptions  : None
  Caller      : General
  Status      : Stable

EXPORT

None

AUTHOR

Alessandro Vullo, <avullo at cpan.org>

BUGS

Please report any bugs or feature requests to bug-tree-interval-fast at rt.cpan.org, or through the web interface at http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Tree-Interval-Fast. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes.

CONTRIBUTING

You can obtain the most recent development version of this module via the GitHub repository at https://github.com/avullo/AVLTree. Please feel free to submit bug reports, patches etc.

SUPPORT

You can find documentation for this module with the perldoc command.

    perldoc Tree::Interval::Fast::Interval

You can also look for information at:

LICENSE AND COPYRIGHT

Copyright 2018 Alessandro Vullo.

This program is free software; you can redistribute it and/or modify it under the terms of either: the GNU General Public License as published by the Free Software Foundation; or the Artistic License.

See http://dev.perl.org/licenses/ for more information.