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.