NAME

Set::Infinite::Basic - Sets of intervals

SYNOPSIS

use Set::Infinite::Basic;

$a = Set::Infinite::Basic->new(1,2);    # [1..2]
print $a->union(5,6);            # [1..2],[5..6]

DESCRIPTION

Set::Infinite::Basic is a Set Theory module for infinite sets.

It works on reals, integers, and objects.

This module does not support recurrences. Recurrences are implemented in Set::Infinite.

METHODS

until

Extends a set until another:

0,5,7 -> until 2,6,10

gives

[0..2), [5..6), [7..10)

Note: this function is still experimental.

copy

Makes a new object from the object's data.

Mode functions:

$a->real;

$a->integer;

Logic functions:

$logic = $a->intersects($b);

$logic = $a->contains($b);

$logic = $a->is_null;

Set functions:

$i = $a->union($b);    

$i = $a->intersection($b);

$i = $a->complement;
$i = $a->complement($b);

$i = $a->span;   

    result is (min .. max)

Scalar functions:

$i = $a->min;

$i = $a->max;

$i = $a->size;  

$i = $a->count;  # number of spans

Overloaded Perl functions:

print    

sort, <=> 

Global functions:

separators(@i)

    chooses the interval separators. 

    default are [ ] ( ) '..' ','.

INFINITY

    returns an 'Infinity' number.

NEG_INFINITY

    returns a '-Infinity' number.

iterate ( sub { } )

    Iterates over a subroutine. 
    Returns the union of partial results.

first

    In scalar context returns the first interval of a set.

    In list context returns the first interval of a set, and the
    'tail'.

    Works in unbounded sets

type($i)

    chooses an object data type. 

    default is none (a normal perl SCALAR).

    examples: 

    type('Math::BigFloat');
    type('Math::BigInt');
    type('Set::Infinite::Date');
        See notes on Set::Infinite::Date below.

tolerance(0)    defaults to real sets (default)
tolerance(1)    defaults to integer sets

real            defaults to real sets (default)

integer         defaults to integer sets

Internal functions:

$a->fixtype; 

$a->numeric;

CAVEATS

$a = Set::Infinite->new(10,1);
    Will be interpreted as [1..10]

$a = Set::Infinite->new(1,2,3,4);
    Will be interpreted as [1..2],[3..4] instead of [1,2,3,4].
    You probably want ->new([1],[2],[3],[4]) instead,
    or maybe ->new(1,4) 

$a = Set::Infinite->new(1..3);
    Will be interpreted as [1..2],3 instead of [1,2,3].
    You probably want ->new(1,3) instead.

INTERNALS

The internal representation of a span is a hash:

{ a =>   start of span,
  b =>   end of span,
  open_begin =>   '0' the span starts in 'a'
                  '1' the span starts after 'a'
  open_end =>     '0' the span ends in 'b'
                  '1' the span ends before 'b'
}

For example, this set:

[100..200),300,(400..infinity)

is represented by the array of hashes:

list => [
    { a => 100, b => 200, open_begin => 0, open_end => 1 },
    { a => 300, b => 300, open_begin => 0, open_end => 0 },
    { a => 400, b => infinity, open_begin => 0, open_end => 1 },
]

The density of a set is stored in the tolerance variable:

tolerance => 0;  # the set is made of real numbers.

tolerance => 1;  # the set is made of integers.

The type variable stores the class of objects that will be stored in the set.

type => 'DateTime';   # this is a set of DateTime objects

The infinity value is generated by Perl, when it finds a numerical overflow:

$inf = 100**100**100;

SEE ALSO

Set::Infinite

AUTHOR

Flavio Soibelmann Glock <fglock@pucrs.br>