NAME

Set::Infinite - Sets of intervals

SYNOPSIS

use Set::Infinite;

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

DESCRIPTION

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

It works with reals, integers, and objects (such as dates).

CONSTRUCTOR

new

Creates a new set object:

$set = Set::Infinite->new;             # empty set
$set = Set::Infinite->new( 10 );       # single element
$set = Set::Infinite->new( 10, 20 );   # single range
$set = Set::Infinite->new( 
          [ 10, 20 ], [ 50, 70 ] );    # two ranges
empty set
$set = Set::Infinite->new;
set with a single element
$set = Set::Infinite->new( 10 );

$set = Set::Infinite->new( [ 10 ] );
set with a single span
$set = Set::Infinite->new( 10, 20 );

$set = Set::Infinite->new( [ 10, 20 ] );
# 10 <= x <= 20
set with a single, open span
$set = Set::Infinite->new(
    {
        a => 10, open_begin => 0,
        b => 20, open_end => 1,
    }
);
# 10 <= x < 20
set with multiple spans
$set = Set::Infinite->new( 10, 20,  100, 200 );

$set = Set::Infinite->new( [ 10, 20 ], [ 100, 200 ] );

$set = Set::Infinite->new(
    {
        a => 10, open_begin => 0,
        b => 20, open_end => 0,
    },
    {
        a => 100, open_begin => 0,
        b => 200, open_end => 0,
    }
);

The new() method expects ordered parameters.

If you have unordered ranges, you can build the set using union:

@ranges = ( [ 10, 20 ], [ -10, 1 ] );
$set = Set::Infinite->new;
$set = $set->union( @$_ ) for @ranges;

The data structures passed to new must be immutable. So this is not good practice:

$set = Set::Infinite->new( $object_a, $object_b );
$object_a->set_value( 10 );

This is the recommended way to do it:

$set = Set::Infinite->new( $object_a->clone, $object_b->clone );
$object_a->set_value( 10 );

SET FUNCTIONS

union

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

Returns the set of all elements from both sets.

This function behaves like a "or" operation.

$set1 = new Set::Infinite( [ 1, 4 ], [ 8, 12 ] );
$set2 = new Set::Infinite( [ 7, 20 ] );
print $set1->union( $set2 );
# output: [1..4],[7..20]

intersection

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

Returns the set of elements common to both sets.

This function behaves like a "and" operation.

$set1 = new Set::Infinite( [ 1, 4 ], [ 8, 12 ] );
$set2 = new Set::Infinite( [ 7, 20 ] );
print $set1->intersection( $set2 );
# output: [8..12]

complement

$set = $a->complement;

Returns the set of all elements that don't belong to the set.

$set1 = new Set::Infinite( [ 1, 4 ], [ 8, 12 ] );
print $set1->complement;
# output: (-inf..1),(4..8),(12..inf)

The complement function might take a parameter:

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

Returns the set-difference, that is, the elements that don't belong to the given set.

$set1 = new Set::Infinite( [ 1, 4 ], [ 8, 12 ] );
$set2 = new Set::Infinite( [ 7, 20 ] );
print $set1->complement( $set2 );
# output: [1..4]

DENSITY FUNCTIONS

real

$a->real;

Returns a set with density "0".

integer

$a->integer;

Returns a set with density "1".

LOGIC FUNCTIONS

intersects

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

contains

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

is_null

$logic = $a->is_null;

is_too_complex

Sometimes a set might be too complex to enumerate or print.

This happens with sets that represent infinite recurrences, such as when you ask for a quantization on a set bounded by -inf or inf.

See also: count.

SCALAR FUNCTIONS

min

$i = $a->min;

max

$i = $a->max;

size

$i = $a->size;  

count

$i = $a->count;

OVERLOADED LANGUAGE OPERATORS

stringification

print $set;

$str = "$set";

See also: as_string.

comparison

sort

> < == >= <= <=> 

See also: spaceship.

CLASS METHODS

separators(@i)

    chooses the interval separators for stringification. 

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

inf

    returns an 'Infinity' number.

minus_inf

    returns '-Infinity' number.

type

type($i)

Chooses a default object data type.

default is none (a normal Perl SCALAR).

SPECIAL SET FUNCTIONS (WIDGETS)

span

$i = $a->span;

    result is INTERVAL, (min .. max)

until

Extends a set until another:

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

gives

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

start_set

end_set

These methods do the inverse of the "until" method.

Given:

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

start_set is:

0,5,7

end_set is:

2,6,10

quantize

quantize( parameters )

    Makes equal-sized subsets.

    Returns an ordered set of equal-sized subsets.

    Example: 

        $a = Set::Infinite->new([1,3]);
        print join (" ", $a->quantize( quant => 1 ) );

    Gives: 

        [1..2) [2..3) [3..4)

select

select( parameters )

Selects set members based on their ordered positions

select has a behaviour similar to an array slice.

           by       - default=All
           count    - default=Infinity

0  1  2  3  4  5  6  7  8      # original set
0  1  2                        # count => 3 
   1              6            # by => [ -2, 1 ]

offset

offset ( parameters )

    Offsets the subsets. Parameters: 

        value   - default=[0,0]
        mode    - default='offset'. Possible values are: 'offset', 'begin', 'end'.
        unit    - type of value. Can be 'days', 'weeks', 'hours', 'minutes', 'seconds'.

iterate

iterate ( sub { } , @args )

Iterates on the set spans, over a callback subroutine. Returns the union of all partial results.

The callback argument $_[0] is a span. If there are additional arguments they are passed to the callback.

The callback can return a span, a hashref (see Set::Infinite::Basic), a scalar, an object, or undef.

first / last

first / last

In scalar context returns the first or last interval of a set.

In list context returns the first or last interval of a set, and the remaining set (the 'tail').

type

type($i)

Chooses a default object data type.

default is none (a normal perl SCALAR).

INTERNAL FUNCTIONS

_cleanup

$a->_cleanup;

Internal function to fix the internal set representation. This is used after operations that might return invalid values.

_backtrack

$a->_backtrack( 'intersection', $b );

Internal function to evaluate recurrences.

numeric

$a->numeric;

Internal function to ignore the set "type". It is used in some internal optimizations, when it is possible to use scalar values instead of objects.

fixtype

$a->fixtype;

Internal function to fix the result of operations that use the numeric() function.

tolerance

$a->tolerance(0)    # defaults to real sets (default)
$a->tolerance(1)    # defaults to integer sets

Internal function for changing the set "density".

min_a

($min, $min_is_open) = $set->min_a;

max_a

($max, $max_is_open) = $set->max_a;

as_string

Implements the "stringification" operator.

Stringification of unbounded recurrences is not implemented.

Unbounded recurrences are stringified as "function descriptions", if the class variable $PRETTY_PRINT is set.

spaceship

Implements the "comparison" operator.

Comparison of unbounded recurrences is not implemented.

CAVEATS

  • "span" notation

    $a = Set::Infinite->new(10,1);

    Will be interpreted as [1..10]

  • "multiple-span" notation

    $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)

  • "range operator"

    $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 base set object, without recurrences, is a Set::Infinite::Basic.

A recurrence-set is represented by a method name, one or two parent objects, and extra arguments. The list key is set to an empty array, and the too_complex key is set to 1.

This is a structure that holds a union of two "complex sets":

{
  too_complex => 1,             # "this is a recurrence"
  list   => [ ],                # not used
  method => 'union',            # function name
  parent => [ $set1, $set2 ],   # "leaves" in the syntax-tree
  param  => [ ]                 # optional arguments for the function
}

This is a structure that holds the complement of a "complex set":

{
  too_complex => 1,             # "this is a recurrence"
  list   => [ ],                # not used
  method => 'complement',       # function name
  parent => $set,               # "leaf" in the syntax-tree
  param  => [ ]                 # optional arguments for the function
}

SEE ALSO

See modules DateTime::Set, DateTime::Event::Recurrence, and DateTime::Event::ICal for up-to-date information on date-sets.

DateTime::Set

The perl-date-time project <http://datetime.perl.org>

AUTHOR

Flavio Soibelmann Glock <fglock@pucrs.br>

COPYRIGHT

Copyright (c) 2003 Flavio Soibelmann Glock. All rights reserved. This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.

The full text of the license can be found in the LICENSE file included with this module.