Binary Relation
MutableFiniteBinaryRelation
can be used to store a mutable binary relation. You can use FrozenFiniteBinaryRelation
for frozen binary relation.
[1]:
from galactic.algebras.relational import MutableFiniteBinaryRelation
from galactic.algebras.relational.renderer import SagittalDiagram
It can be initialized using an iterable of couples.
[2]:
relation = MutableFiniteBinaryRelation[int, int](
(1, 2, 3),
(1, 2, 3),
elements=[(1, 2), (1, 3), (2, 3)],
)
diagram = SagittalDiagram(relation)
diagram
[2]:
[3]:
list(relation)
[3]:
[(1, 2), (1, 3), (2, 3)]
Binary relation are considered as sets.
[4]:
len(relation)
[4]:
3
They have a domain and a co-domain also accessible by a tuple of universes.
[5]:
list(relation.domain)
[5]:
[1, 2, 3]
[6]:
list(relation.universes[0])
[6]:
[1, 2, 3]
[7]:
list(relation.co_domain)
[7]:
[1, 2, 3]
[8]:
list(relation.universes[1])
[8]:
[1, 2, 3]
[9]:
relation.add((2, 1))
diagram
[9]:
[10]:
list(relation)
[10]:
[(1, 2), (1, 3), (2, 3), (2, 1)]
[11]:
list(relation.domain)
[11]:
[1, 2, 3]
[12]:
list(relation.co_domain)
[12]:
[1, 2, 3]
Successors and predecessors of an element are considered as sets. They are equivalent to a combination of a selection and a projection.
[13]:
relation.successors(1)
[13]:
<MutableSuccessors object at 0x7ab1ac1f6de0>
[14]:
list(relation.successors(1))
[14]:
[2, 3]
[15]:
relation.successors(1).add(1)
diagram
[15]:
[16]:
list(relation)
[16]:
[(1, 2), (1, 3), (1, 1), (2, 3), (2, 1)]
[17]:
relation.successors(1).discard(3)
diagram
[17]:
[18]:
list(relation)
[18]:
[(1, 2), (1, 1), (2, 3), (2, 1)]
[19]:
relation.domain.add(4)
list(relation.domain)
[19]:
[1, 2, 3, 4]
[20]:
list(relation.co_domain)
[20]:
[1, 2, 3]
[21]:
relation.successors(2).clear()
diagram
[21]:
[22]:
list(relation)
[22]:
[(1, 2), (1, 1)]
[23]:
list(relation.predecessors(2))
[23]:
[1]
[24]:
predecessors = relation.predecessors(2)
predecessors.extend({2, 3, 4})
diagram
[24]:
[25]:
list(relation)
[25]:
[(1, 2), (1, 1), (2, 2), (3, 2), (4, 2)]
[26]:
relation.domain.discard(1)
diagram
[26]:
[27]:
list(relation)
[27]:
[(2, 2), (3, 2), (4, 2)]
Endo Relation
MutableFiniteEndoRelation
can be used to store a mutable endo relation. You can use FrozenFiniteEndoRelation
for frozen endo relation.
[28]:
from galactic.algebras.relational import MutableFiniteEndoRelation
from galactic.algebras.relational.renderer import EndoDiagram, SagittalDiagram
It can be initialized using an iterable of couples.
[29]:
relation = MutableFiniteEndoRelation[int, int](
(1, 2, 3),
elements=[(1, 2), (1, 3), (2, 3)],
)
diagram = EndoDiagram(relation)
diagram
[29]:
[30]:
SagittalDiagram(relation)
[30]:
All operations that are possible on binary relations are possible on endo relation.
[31]:
list(relation)
[31]:
[(1, 2), (1, 3), (2, 3)]
[32]:
list(relation.domain)
[32]:
[1, 2, 3]
[33]:
list(relation.co_domain)
[33]:
[1, 2, 3]
[34]:
relation.successors(1)
[34]:
<MutableSuccessors object at 0x7ab1ac009130>
[35]:
list(relation.successors(1))
[35]:
[2, 3]
[36]:
relation.successors(1).add(1)
diagram
[36]:
[37]:
list(relation)
[37]:
[(1, 2), (1, 3), (1, 1), (2, 3)]
[38]:
relation.successors(1).discard(3)
diagram
[38]:
[39]:
relation.domain.add(4)
list(relation.domain)
[39]:
[1, 2, 3, 4]
[40]:
list(relation.co_domain)
[40]:
[1, 2, 3, 4]
[41]:
diagram
[41]:
[42]:
relation.successors(1).add(4)
diagram
[42]:
[43]:
relation.successors(4).add(3)
diagram
[43]:
[44]:
list(relation)
[44]:
[(1, 2), (1, 1), (1, 4), (2, 3), (4, 3)]
[45]:
list(relation.successors(1))
[45]:
[2, 1, 4]
[46]:
list(relation.successors(2))
[46]:
[3]
[47]:
list(relation.successors(3))
[47]:
[]
[48]:
list(relation.successors(4))
[48]:
[3]
[49]:
list(relation.predecessors(1))
[49]:
[1]
[50]:
list(relation.predecessors(2))
[50]:
[1]
[51]:
list(relation.predecessors(3))
[51]:
[2, 4]
[52]:
list(relation.predecessors(4))
[52]:
[1]
[53]:
relation.co_domain.remove(3)
diagram
[53]:
[54]:
list(relation.domain)
[54]:
[1, 2, 4]
[55]:
list(relation.co_domain)
[55]:
[1, 2, 4]
[56]:
relation.pop()
[56]:
(1, 2)
[57]:
diagram
[57]:
[58]:
relation.pop()
[58]:
(1, 1)
[59]:
diagram
[59]:
[60]:
relation.pop()
[60]:
(1, 4)
[61]:
diagram
[61]: