Posets
The galactic.algebras.poset
module.
It defines types for representing posets:
And their implementations:
and their elements which are partially comparable:
with their functions:
It provides classes for representing underlying relation order:
It defines also two mixins used in other packages:
- class Neighbourhood(element, successors, predecessors)
Bases:
Generic
[_P
]It represents the neighbourhood in a covering relation.
It associates an element with its direct successors and predecessors. It is a dataclass containing three fields:
the element whose neighbourhood is considered;
the immediate successors of the element;
the immediate predecessors of the element.
- class AbstractFinitePartiallyOrderedSet(*args, **kwargs)
Bases:
Collection
[_P
],Protocol
[_P
]It represents finite partially ordered set (poset).
- abstract isdisjoint(other)
Test if the poset is disjoint from the other.
- Parameters:
other (
Iterable
[TypeVar
(_P
, bound=PartiallyComparable
)]) – An iterable of values.- Returns:
True if the poset is disjoint from the other.
- Return type:
- abstract issubset(other)
Test whether every element in the poset is in other.
- Parameters:
other (
Iterable
[TypeVar
(_P
, bound=PartiallyComparable
)]) – An iterable of values.- Returns:
True if the poset is a subset of the other.
- Return type:
- abstract issuperset(other)
Test whether every element in the other is in the poset.
- Parameters:
other (
Iterable
[TypeVar
(_P
, bound=PartiallyComparable
)]) – An iterable of values.- Returns:
True if the poset is a superset of the other.
- Return type:
- abstract upper_limit(limit, strict=False)
Get the values less than the limit.
- Parameters:
limit (
TypeVar
(_P
, bound=PartiallyComparable
)) – The limit.strict (
bool
, default:False
) – Is the comparison strict?
- Returns:
A collection of values.
- Return type:
Collection[_P]
- abstract lower_limit(limit, strict=False)
Get the values greater than the limit.
- Parameters:
limit (
TypeVar
(_P
, bound=PartiallyComparable
)) – The limit.strict (
bool
, default:False
) – Is the comparison strict?
- Returns:
A collection of values.
- Return type:
Collection[_P]
- abstract property order: AbstractFinitePartialOrder[_P]
Get the partial order of this poset.
- Returns:
The partial order.
- Return type:
- abstract property cover: AbstractFiniteCoveringRelation[_P]
Get the covering relation of this poset.
- Returns:
The covering relation.
- Return type:
- abstract property top: Collection[_P]
Get the top elements.
- Returns:
The top elements.
- Return type:
Collection[_P]
- abstract property maximum: _P | None
Get the maximum element if any.
- Returns:
The maximum element.
- Return type:
_P | None
- abstract property bottom: Collection[_P]
Get the bottom elements.
- Returns:
The bottom elements.
- Return type:
Collection[_P]
- abstract property minimum: _P | None
Get the minimum element if any.
- Returns:
The minimum element.
- Return type:
_P | None
- abstract filter(element)
Get a filter of a poset.
- Parameters:
element (
TypeVar
(_P
, bound=PartiallyComparable
)) – The lower limit- Returns:
A view on the lower bounded poset.
- Return type:
- Raises:
ValueError – If the element does not belong to the poset.
Notes
Unpredictable behavior can occur if the lower bound is no longer part of the original poset.
- abstract ideal(element)
Get an ideal of the poset.
- Parameters:
element (
TypeVar
(_P
, bound=PartiallyComparable
)) – The upper limit- Returns:
A view on the upper bounded set.
- Return type:
- Raises:
ValueError – If the element does not belong to the poset.
Notes
Unpredictable behavior can occur if the upper bound is no longer part of the original poset.
- class FrozenFinitePartiallyOrderedSet(*others, elements=None)
Bases:
FinitePartiallyOrderedSetMixin
[_P
]It implements posets.
The initializer can take 0 or 1 argument that should be iterable.
An instance stores its values in two dictionaries for the immediate successors (\(\succ\)) and the immediate predecessors (\(\prec\)).
Its memory complexity is in \(O(n)\).
Operation complexities:
__contains__()
: \(O(1)\)__len__()
: \(O(1)\)__iter__()
: \(O(1)\)top()
: \(O(1)\)bottom()
: \(O(1)\)successors()
: \(O(1)\)predecessors()
: \(O(1)\)
- Parameters:
*others (
AbstractFinitePartiallyOrderedSet
[TypeVar
(_P
, bound=PartiallyComparable
)]) – A sequence of posetelements (
Iterable
[TypeVar
(_P
, bound=PartiallyComparable
)] |None
, default:None
) – An iterable of values
Example
>>> from galactic.algebras.poset import MutableFinitePartiallyOrderedSet >>> from galactic.algebras.examples.arithmetic import PrimeFactors >>> poset = MutableFinitePartiallyOrderedSet[PrimeFactors]( ... elements=[ ... PrimeFactors(2*3*5*7), ... PrimeFactors(3*5*7*11), ... PrimeFactors(3*5*7), ... PrimeFactors(3*5), ... PrimeFactors(5), ... PrimeFactors(7), ... ] ... ) >>> poset <galactic.algebras.poset.MutableFinitePartiallyOrderedSet object at 0x...>
It’s possible to iterate over the poset elements. The elements are iterated level by level starting from the top ones.
Example
It’s possible to know the poset length.
Example
>>> PrimeFactors(210) in poset True >>> PrimeFactors(211) in poset False
It’s possible to iterate over the top and bottom elements.
Example
It’s possible to iterate over the descendants and the ascendants of an element.
Example
It’s possible to iterate over the (immediate) successors and the (immediate) predecessors of an element.
Example
>>> sorted(list(map(int, poset.cover.successors(PrimeFactors(105))))) [210, 1155] >>> sorted(list(map(int, poset.order.successors(PrimeFactors(105))))) [105, 210, 1155] >>> sorted(list(map(int, poset.cover.predecessors(PrimeFactors(105))))) [7, 15] >>> sorted(list(map(int, poset.order.predecessors(PrimeFactors(105))))) [5, 7, 15, 105]
It’s possible to enlarge a partially ordered set.
Example
- property version: int
Get the version number.
- Returns:
The version number.
- Return type:
Notes
This can be used to detect a change in the poset.
- copy()
Get a copy of the partially ordered set.
- Returns:
The copy of this poset.
- Return type:
Self
- union(*others)
Compute the union of the poset and the others.
- Parameters:
*others (
Iterable
[TypeVar
(_P
, bound=PartiallyComparable
)]) – A sequence of iterable.- Returns:
The union of the poset and the others.
- Return type:
Self
- intersection(*others)
Compute the intersection between the poset and the others.
- difference(*others)
Compute the difference between the poset and the others.
- symmetric_difference(other)
Compute the symmetric difference between the poset and the other.
- Parameters:
other (
Iterable
[TypeVar
(_P
, bound=PartiallyComparable
)]) – An iterable of elements.- Returns:
The symmetric difference between the poset and the other.
- Return type:
Self
- property order: AbstractFinitePartialOrder[_P]
Get the partial order of this poset.
- Returns:
The partial order.
- Return type:
- property cover: AbstractFiniteCoveringRelation[_P]
Get the covering relation of this poset.
- Returns:
The covering relation.
- Return type:
- property top: Collection[_P]
Get the top elements.
- Returns:
The top elements.
- Return type:
Collection[_P]
- property tail: _P | None
Get the tail element if any.
- Returns:
The tail element.
- Return type:
_P | None
- Raises:
KeyError – If the semi-lattice is empty.
- property bottom: Collection[_P]
Get the bottom elements.
- Returns:
The bottom elements.
- Return type:
Collection[_P]
- property head: _P | None
Get the head element if any.
- Returns:
The head element.
- Return type:
_P | None
- Raises:
KeyError – If the semi-lattice is empty.
- filter(element)
Get a filter of a poset.
This is a view of this poset restricted the lower limit.
- Parameters:
element (
TypeVar
(_P
, bound=PartiallyComparable
)) – The lower limit- Returns:
A view on the lower bounded poset.
- Return type:
- Raises:
ValueError – If the element does not belong to the poset.
Notes
Unpredictable behavior can occur if the lower bound is no longer part of the original poset.
- ideal(element)
Get an ideal of the poset.
This is a view of this poset restricted the upper limit.
- Parameters:
element (
TypeVar
(_P
, bound=PartiallyComparable
)) – The upper limit- Returns:
A view on the upper bounded set.
- Return type:
- Raises:
ValueError – If the element does not belong to the poset.
Notes
Unpredictable behavior can occur if the upper bound is no longer part of the original poset.
- isdisjoint(other)
Test if the relation is disjoint from the other.
- Parameters:
other (
Iterable
[TypeVar
(_P
, bound=PartiallyComparable
)]) – An iterable of couples.- Returns:
True if the relation is disjoint from the other.
- Return type:
- issubset(other)
Test whether every element in the relation is in other.
- Parameters:
other (
Iterable
[TypeVar
(_P
, bound=PartiallyComparable
)]) – An iterable of couples.- Returns:
True if the relation is a subset of the other.
- Return type:
- issuperset(other)
Test whether every element in the other relation is in the relation.
- Parameters:
other (
Iterable
[TypeVar
(_P
, bound=PartiallyComparable
)]) – An iterable of couples.- Returns:
True if the relation is a superset of the other.
- Return type:
- lower_limit(limit, strict=False)
Get the values greater than the limit.
- Parameters:
limit (
TypeVar
(_P
, bound=PartiallyComparable
)) – The limit.strict (
bool
, default:False
) – Is the comparison strict?
- Returns:
A collection of values.
- Return type:
Collection[_P]
- upper_limit(limit, strict=False)
Get the values less than the limit.
- Parameters:
limit (
TypeVar
(_P
, bound=PartiallyComparable
)) – The limit.strict (
bool
, default:False
) – Is the comparison strict?
- Returns:
An collection of values.
- Return type:
Collection[_P]
- class MutableFinitePartiallyOrderedSet(*others, elements=None)
Bases:
FrozenFinitePartiallyOrderedSet
[_P
]It represents mutable finite poset.
- add(value)
Add a value to the poset.
- Parameters:
value (
TypeVar
(_P
, bound=PartiallyComparable
)) – The value to add.- Return type:
- remove(value)
Remove a value from the poset.
- Parameters:
value (
TypeVar
(_P
, bound=PartiallyComparable
)) – The value to remove.- Return type:
- discard(value)
Discard a value from the poset.
- Parameters:
value (
TypeVar
(_P
, bound=PartiallyComparable
)) – The value to discard.- Return type:
- pop()
Remove and return the first value of the set.
- Returns:
The value removed.
- Return type:
_P
- popitem(last=False)
Remove and return the first value of the set.
- Parameters:
last (
bool
, default:False
) – Does the remove take place at the end or the beginning?- Returns:
The value removed.
- Return type:
_P
- property bottom: Collection[_P]
Get the bottom elements.
- Returns:
The bottom elements.
- Return type:
Collection[_P]
- copy()
Get a copy of the partially ordered set.
- Returns:
The copy of this poset.
- Return type:
Self
- property cover: AbstractFiniteCoveringRelation[_P]
Get the covering relation of this poset.
- Returns:
The covering relation.
- Return type:
- difference(*others)
Compute the difference between the poset and the others.
- filter(element)
Get a filter of a poset.
This is a view of this poset restricted the lower limit.
- Parameters:
element (
TypeVar
(_P
, bound=PartiallyComparable
)) – The lower limit- Returns:
A view on the lower bounded poset.
- Return type:
- Raises:
ValueError – If the element does not belong to the poset.
Notes
Unpredictable behavior can occur if the lower bound is no longer part of the original poset.
- property head: _P | None
Get the head element if any.
- Returns:
The head element.
- Return type:
_P | None
- Raises:
KeyError – If the semi-lattice is empty.
- ideal(element)
Get an ideal of the poset.
This is a view of this poset restricted the upper limit.
- Parameters:
element (
TypeVar
(_P
, bound=PartiallyComparable
)) – The upper limit- Returns:
A view on the upper bounded set.
- Return type:
- Raises:
ValueError – If the element does not belong to the poset.
Notes
Unpredictable behavior can occur if the upper bound is no longer part of the original poset.
- intersection(*others)
Compute the intersection between the poset and the others.
- isdisjoint(other)
Test if the relation is disjoint from the other.
- Parameters:
other (
Iterable
[TypeVar
(_P
, bound=PartiallyComparable
)]) – An iterable of couples.- Returns:
True if the relation is disjoint from the other.
- Return type:
- issubset(other)
Test whether every element in the relation is in other.
- Parameters:
other (
Iterable
[TypeVar
(_P
, bound=PartiallyComparable
)]) – An iterable of couples.- Returns:
True if the relation is a subset of the other.
- Return type:
- issuperset(other)
Test whether every element in the other relation is in the relation.
- Parameters:
other (
Iterable
[TypeVar
(_P
, bound=PartiallyComparable
)]) – An iterable of couples.- Returns:
True if the relation is a superset of the other.
- Return type:
- lower_limit(limit, strict=False)
Get the values greater than the limit.
- Parameters:
limit (
TypeVar
(_P
, bound=PartiallyComparable
)) – The limit.strict (
bool
, default:False
) – Is the comparison strict?
- Returns:
A collection of values.
- Return type:
Collection[_P]
- property order: AbstractFinitePartialOrder[_P]
Get the partial order of this poset.
- Returns:
The partial order.
- Return type:
- symmetric_difference(other)
Compute the symmetric difference between the poset and the other.
- Parameters:
other (
Iterable
[TypeVar
(_P
, bound=PartiallyComparable
)]) – An iterable of elements.- Returns:
The symmetric difference between the poset and the other.
- Return type:
Self
- property tail: _P | None
Get the tail element if any.
- Returns:
The tail element.
- Return type:
_P | None
- Raises:
KeyError – If the semi-lattice is empty.
- property top: Collection[_P]
Get the top elements.
- Returns:
The top elements.
- Return type:
Collection[_P]
- union(*others)
Compute the union of the poset and the others.
- Parameters:
*others (
Iterable
[TypeVar
(_P
, bound=PartiallyComparable
)]) – A sequence of iterable.- Returns:
The union of the poset and the others.
- Return type:
Self
- upper_limit(limit, strict=False)
Get the values less than the limit.
- Parameters:
limit (
TypeVar
(_P
, bound=PartiallyComparable
)) – The limit.strict (
bool
, default:False
) – Is the comparison strict?
- Returns:
An collection of values.
- Return type:
Collection[_P]
- property version: int
Get the version number.
- Returns:
The version number.
- Return type:
Notes
This can be used to detect a change in the poset.
- extend(iterable)
Extend a poset with the iterable.
- Parameters:
iterable (
Iterable
[TypeVar
(_P
, bound=PartiallyComparable
)]) – An iterable of values- Return type:
- update(*others)
Update a poset with the union of itself and others.
- Parameters:
*others (
Iterable
[TypeVar
(_P
, bound=PartiallyComparable
)]) – A sequence of iterable.- Return type:
- intersection_update(*others)
Update a poset with the intersection of itself and others.
- difference_update(*others)
Update a poset with the difference of itself and others.
- symmetric_difference_update(other)
Update a poset with the symmetric difference of itself and the other.
- Parameters:
other (
Iterable
[TypeVar
(_P
, bound=PartiallyComparable
)]) – An iterable of elements.- Return type:
- class FinitePartiallyOrderedSetView(poset, lower=None, upper=None)
Bases:
FinitePartiallyOrderedSetMixin
[_P
]It represents view on partially ordered sets.
- Parameters:
poset (
AbstractFinitePartiallyOrderedSet
[TypeVar
(_P
, bound=PartiallyComparable
)]) – A poset.lower (
Optional
[TypeVar
(_P
, bound=PartiallyComparable
)], default:None
) – The lower limit.upper (
Optional
[TypeVar
(_P
, bound=PartiallyComparable
)], default:None
) – The upper limit.
Notes
Unpredictable behavior can occur if the lower or the upper bound is no longer part of the original poset.
- isdisjoint(other)
Test if the relation is disjoint from the other.
- Parameters:
other (
Iterable
[TypeVar
(_P
, bound=PartiallyComparable
)]) – An iterable of couples.- Returns:
True if the relation is disjoint from the other.
- Return type:
- issubset(other)
Test whether every element in the relation is in other.
- Parameters:
other (
Iterable
[TypeVar
(_P
, bound=PartiallyComparable
)]) – An iterable of couples.- Returns:
True if the relation is a subset of the other.
- Return type:
- issuperset(other)
Test whether every element in the other relation is in the relation.
- Parameters:
other (
Iterable
[TypeVar
(_P
, bound=PartiallyComparable
)]) – An iterable of couples.- Returns:
True if the relation is a superset of the other.
- Return type:
- lower_limit(limit, strict=False)
Get the values greater than the limit.
- Parameters:
limit (
TypeVar
(_P
, bound=PartiallyComparable
)) – The limit.strict (
bool
, default:False
) – Is the comparison strict?
- Returns:
A collection of values.
- Return type:
Collection[_P]
- upper_limit(limit, strict=False)
Get the values less than the limit.
- Parameters:
limit (
TypeVar
(_P
, bound=PartiallyComparable
)) – The limit.strict (
bool
, default:False
) – Is the comparison strict?
- Returns:
An collection of values.
- Return type:
Collection[_P]
- property version: int
Get the poset version.
- Returns:
The poset version.
- Return type:
Notes
This can be used to detect a change in the poset.
- property order: AbstractFinitePartialOrder[_P]
Get the partial order of this bounded set.
- Returns:
The partial order.
- Return type:
- property cover: AbstractFiniteCoveringRelation[_P]
Get the covering relation of this bounded set.
- Returns:
The covering relation.
- Return type:
- property top: Collection[_P]
Get the top elements.
- Returns:
The top elements.
- Return type:
Collection[_P]
- property bottom: Collection[_P]
Get the bottom elements.
- Returns:
The bottom elements.
- Return type:
Collection[_P]
- filter(element)
Get a filter of a bounded set.
This is a view of this poset restricted by the lower limit.
- Parameters:
element (
TypeVar
(_P
, bound=PartiallyComparable
)) – The lower limit- Returns:
A view on the lower bounded poset.
- Return type:
- Raises:
ValueError – If the element does not belong to the poset.
Notes
Unpredictable behavior can occur if the lower bound is no longer part of the original poset.
- ideal(element)
Get an ideal of the bounded set.
This is a view of this poset restricted by the upper limit.
- Parameters:
element (
TypeVar
(_P
, bound=PartiallyComparable
)) – The upper limit- Returns:
A view on the upper bounded set.
- Return type:
- Raises:
ValueError – If the element does not belong to the poset.
Notes
Unpredictable behavior can occur if the upper bound is no longer part of the original poset.
- class FinitePartiallyOrderedSetMixin
Bases:
Generic
[_P
]It represents finite poset mixin.
- isdisjoint(other)
Test if the relation is disjoint from the other.
- Parameters:
other (
Iterable
[TypeVar
(_P
, bound=PartiallyComparable
)]) – An iterable of couples.- Returns:
True if the relation is disjoint from the other.
- Return type:
- issubset(other)
Test whether every element in the relation is in other.
- Parameters:
other (
Iterable
[TypeVar
(_P
, bound=PartiallyComparable
)]) – An iterable of couples.- Returns:
True if the relation is a subset of the other.
- Return type:
- issuperset(other)
Test whether every element in the other relation is in the relation.
- Parameters:
other (
Iterable
[TypeVar
(_P
, bound=PartiallyComparable
)]) – An iterable of couples.- Returns:
True if the relation is a superset of the other.
- Return type:
- upper_limit(limit, strict=False)
Get the values less than the limit.
- Parameters:
limit (
TypeVar
(_P
, bound=PartiallyComparable
)) – The limit.strict (
bool
, default:False
) – Is the comparison strict?
- Returns:
An collection of values.
- Return type:
Collection[_P]
- lower_limit(limit, strict=False)
Get the values greater than the limit.
- Parameters:
limit (
TypeVar
(_P
, bound=PartiallyComparable
)) – The limit.strict (
bool
, default:False
) – Is the comparison strict?
- Returns:
A collection of values.
- Return type:
Collection[_P]
- class PartiallyComparable(*args, **kwargs)
Bases:
Protocol
Partially comparable elements.
A partially ordered type sets for each pair of elements \(a\), \(b\) either:
\(a \leq b\)
\(b \leq a\)
a and b are incomparable (\(a \| b\))
The relation \(\leq\) must be:
reflexive (\(a \leq a\))
transitive (\(a \leq b\) and \(b \leq c\) implies \(a \leq c\))
anti-symmetric (\(a \leq b\) and \(b \leq a\) implies \(a = b\))
A class implementing the
PartiallyComparable
protocol must be declared by inheriting fromPartiallyComparable
and must implement the methods:Example
Let the integers ordered by the relation \(a \leq b\): is \(a\) a divisor of \(b\)?
implemented by the
PrimeFactors
class:>>> from galactic.algebras.examples.arithmetic import PrimeFactors >>> PrimeFactors(5) <= PrimeFactors(10) # 5 is a divisor of 10 True >>> PrimeFactors(5) <= PrimeFactors(11) # 5 is not a divisor of 11 False >>> PrimeFactors(5) >= PrimeFactors(11) # 5 is not a multiple of 11 False
- abstract __lt__(other)
Test if this element is lesser than the other.
- Parameters:
other (
Self
) – the other element- Returns:
True if this element is lesser than the other.
- Return type:
- abstract __gt__(other)
Test if this element is greater than the other.
- Parameters:
other (
Self
) – the other element- Returns:
True if this element is greater than the other.
- Return type:
- abstract __le__(other)
Test if this element is lesser than or equal to the other.
- Parameters:
other (
Self
) – the other element- Returns:
True if this element is lesser than or equal to the other.
- Return type:
- bottom(iterable)
Compute an iterator over the bottom elements of the iterable.
This operation computes in \(O(n^2)\) where \(n\) is the number of elements in the iterable.
- Parameters:
iterable (
Iterable
[TypeVar
(_P
, bound=PartiallyComparable
)]) – An iterable of partially ordered elements.- Returns:
An iterator over the bottom elements.
- Return type:
Iterator[_P]
- top(iterable)
Compute an iterator over the top elements of the iterable.
This operation computes in \(O(n^2)\) where \(n\) is the number of elements in the iterable.
- Parameters:
iterable (
Iterable
[TypeVar
(_P
, bound=PartiallyComparable
)]) – An iterable of partially ordered elements.- Returns:
An iterator over the top elements.
- Return type:
Iterator[_P]
- lower_limit(iterable, limit, strict=False)
Compute an iterator over the elements greater than the limit.
This operation computes in \(O(n)\) where \(n\) is the number of elements in the iterable.
- Parameters:
iterable (
Iterable
[TypeVar
(_P
, bound=PartiallyComparable
)]) – An iterable of partially ordered elements.limit (
TypeVar
(_P
, bound=PartiallyComparable
)) – The lower limitstrict (
bool
, default:False
) – Is the comparison strict?
- Yields:
_P – A selected element
- Return type:
Iterator
[TypeVar
(_P
, bound=PartiallyComparable
)]
Example
>>> from galactic.algebras.poset import lower_limit >>> values = [{1, 2}, {1, 2, 3}, {2, 3}] >>> list(lower_limit(list(map(frozenset, values)), frozenset({2, 3}))) [frozenset({1, 2, 3}), frozenset({2, 3})]
# noqa: DAR301
- upper_limit(iterable, limit, strict=False)
Compute an iterator over the elements lesser than the limit.
This operation computes in \(O(n)\) where \(n\) is the number of elements in the iterable.
- Parameters:
iterable (
Iterable
[TypeVar
(_P
, bound=PartiallyComparable
)]) – An iterable of partially ordered elements.limit (
TypeVar
(_P
, bound=PartiallyComparable
)) – The upper limitstrict (
bool
, default:False
) – Is the comparison strict?
- Yields:
_P – A selected element.
- Return type:
Iterator
[TypeVar
(_P
, bound=PartiallyComparable
)]
Example
>>> from galactic.algebras.poset import upper_limit >>> values = [{1, 2}, {1, 2, 3}, {2, 3}] >>> list(upper_limit(list(map(frozenset, values)), frozenset({2, 3}))) [frozenset({2, 3})]
# noqa: DAR301
- class AbstractFinitePartialOrder(*args, **kwargs)
Bases:
AbstractFiniteDirectedAcyclicRelation
[_P
],Protocol
[_P
]It represents finite partial orders.
- abstract property co_domain: Collection[_F]
Get the co-domain of this binary relation.
It returns the second universe.
- Return type:
The co-domain of this binary relation.
- abstract property domain: Collection[_E]
Get the domain of this binary relation.
It returns the first universe.
- Return type:
The domain of this binary relation.
- abstract predecessors(element)
Get the predecessors of an element.
- Parameters:
element (
TypeVar
(_F
)) – The element whose predecessors are requested- Returns:
The predecessors.
- Return type:
Collection[_E]
- Raises:
- abstract property sinks: Collection[_E]
Get the sinks of this DAG.
- Returns:
The sinks of this DAG.
- Return type:
Collection[_E]
- abstract property sources: Collection[_E]
Get the sources of this DAG.
- Returns:
The sources of this DAG.
- Return type:
Collection[_E]
- abstract successors(element)
Get the successors of an element.
- Parameters:
element (
TypeVar
(_E
)) – The element whose successors are requested- Returns:
The successors.
- Return type:
Collection[_F]
- Raises:
- abstract property universes: tuple[Collection[_E], Collection[_F]]
Get the universes of this relation.
- Return type:
The universes of this relation.
- class FinitePartialOrder(poset)
Bases:
FiniteRelationMixin
,Generic
[_P
]It represents a partial order.
- Parameters:
poset (
AbstractFinitePartiallyOrderedSet
[TypeVar
(_P
, bound=PartiallyComparable
)]) – A poset.
- property universes: tuple[Collection[_P], Collection[_P]]
Get the universes.
- Returns:
The universes.
- Return type:
tuple[Collection[_P], Collection[_P]]
- property domain: Collection[_P]
Get the domain.
- Returns:
The domain.
- Return type:
Collection[_P]
- property co_domain: Collection[_P]
Get the co-domain of this partial order.
- Returns:
The co-domain of this partial order.
- Return type:
Collection[_P]
Notes
The domain and the co-domain of a partial order are identical.
- property sinks: Collection[_P]
Get the sink elements.
- Returns:
The sink elements.
- Return type:
Collection[_P]
- property sources: Collection[_P]
Get the source elements.
- Returns:
The source elements.
- Return type:
Collection[_P]
- isdisjoint(other)
Test if the relation is disjoint from the other.
- issubset(other)
Test whether every element in the relation is in other.
- issuperset(other)
Test whether every element in the other relation is in the relation.
- successors(element)
Get the successors of an element.
- Parameters:
element (
TypeVar
(_P
, bound=PartiallyComparable
)) – The element whose successors are requested.- Returns:
The successors.
- Return type:
Collection[_P]
- Raises:
ValueError – If the element does not belong to the poset.
- predecessors(element)
Get the predecessors of an element.
- Parameters:
element (
TypeVar
(_P
, bound=PartiallyComparable
)) – The element whose predecessors are requested.- Returns:
The predecessors.
- Return type:
Collection[_P]
- Raises:
ValueError – If the element does not belong to the poset.
- class AbstractFiniteCoveringRelation(*args, **kwargs)
Bases:
AbstractFiniteDirectedAcyclicRelation
[_P
],Protocol
[_P
]It represents a covering relation.
- abstract neighbourhoods(reverse=False)
Get an iterator over the neighbourhoods of an element.
- Parameters:
reverse (
bool
, default:False
) – Is this a bottom-up generation ?- Returns:
An iterable giving a triple (element, successors, predecessors) for each element in the covering relation represented by a neighbourhood.
- Return type:
Iterator[Neighbourhood[_P]]
- Raises:
- abstract property co_domain: Collection[_F]
Get the co-domain of this binary relation.
It returns the second universe.
- Return type:
The co-domain of this binary relation.
- abstract property domain: Collection[_E]
Get the domain of this binary relation.
It returns the first universe.
- Return type:
The domain of this binary relation.
- abstract predecessors(element)
Get the predecessors of an element.
- Parameters:
element (
TypeVar
(_F
)) – The element whose predecessors are requested- Returns:
The predecessors.
- Return type:
Collection[_E]
- Raises:
- abstract property sinks: Collection[_E]
Get the sinks of this DAG.
- Returns:
The sinks of this DAG.
- Return type:
Collection[_E]
- abstract property sources: Collection[_E]
Get the sources of this DAG.
- Returns:
The sources of this DAG.
- Return type:
Collection[_E]
- abstract successors(element)
Get the successors of an element.
- Parameters:
element (
TypeVar
(_E
)) – The element whose successors are requested- Returns:
The successors.
- Return type:
Collection[_F]
- Raises:
- abstract property universes: tuple[Collection[_E], Collection[_F]]
Get the universes of this relation.
- Return type:
The universes of this relation.
- class FiniteCoveringRelationMixin(poset)
Bases:
FiniteRelationMixin
,Generic
[_P
]It represents finite covering relation.
- Parameters:
poset (
AbstractFinitePartiallyOrderedSet
[TypeVar
(_P
, bound=PartiallyComparable
)]) – A poset.
- property universes: tuple[Collection[_P], Collection[_P]]
Get the universes of this covering relation.
- Returns:
The universes of this covering relation.
- Return type:
tuple[Collection[_P], Collection[_P]]
- property domain: Collection[_P]
Get the domain of this covering relation.
- Returns:
The domain of this covering relation.
- Return type:
Collection[_P]
Notes
The domain and the co-domain of a covering relation are identical.
- property co_domain: Collection[_P]
Get the co-domain of this covering relation.
- Returns:
The co-domain of this covering relation.
- Return type:
Collection[_P]
Notes
The domain and the co-domain of a covering relation are identical.
- abstract successors(element)
Get the successors of an element.
- Parameters:
element (
TypeVar
(_P
, bound=PartiallyComparable
)) – The element whose successors are requested- Returns:
The successors.
- Return type:
Collection[_P]
- Raises:
ValueError – If the element does not belong to the poset.
Notes
Unpredictable behavior can occur if the element is no longer part of the original poset.
- isdisjoint(other)
Test if the relation is disjoint from the other.
- issubset(other)
Test whether every element in the relation is in other.
- issuperset(other)
Test whether every element in the other relation is in the relation.
- abstract predecessors(element)
Get the predecessors of an element.
- Parameters:
element (
TypeVar
(_P
, bound=PartiallyComparable
)) – The element whose predecessors are requested- Returns:
The predecessors.
- Return type:
Collection[_P]
- Raises:
ValueError – If the element does not belong to the poset.
Notes
Unpredictable behavior can occur if the element is no longer part of the original poset.
- property sinks: Collection[_P]
Get the elements with no successors.
- Returns:
The elements with no successors.
- Return type:
Collection[_P]
- property sources: Collection[_P]
Get the elements with no predecessors.
- Returns:
The elements with no predecessors.
- Return type:
Collection[_P]
- abstract neighbourhoods(reverse=False)
Get an iterator over the neighbourhoods of an element.
- Parameters:
reverse (
bool
, default:False
) – Is this a bottom-up generation ?- Returns:
An iterator giving a triple (element, successors, predecessors) for each element in the covering relation represented by a neighbourhood.
- Return type:
Iterator[Neighbourhood[_P]]
- Raises:
- class Bottom(poset, lower, upper)
Bases:
Generic
[_P
]It represents the bottom elements in a bounded set.
- Parameters:
poset (
AbstractFinitePartiallyOrderedSet
[TypeVar
(_P
, bound=PartiallyComparable
)]) – The inner poset.lower (
Optional
[TypeVar
(_P
, bound=PartiallyComparable
)]) – The lower bound.upper (
Optional
[TypeVar
(_P
, bound=PartiallyComparable
)]) – The upper bound.
- class Top(poset, lower, upper)
Bases:
Generic
[_P
]It represents the top elements in a bounded set.
- Parameters:
poset (
AbstractFinitePartiallyOrderedSet
[TypeVar
(_P
, bound=PartiallyComparable
)]) – The inner poset.lower (
Optional
[TypeVar
(_P
, bound=PartiallyComparable
)]) – The lower bound.upper (
Optional
[TypeVar
(_P
, bound=PartiallyComparable
)]) – The upper bound.