Ë

����†£éf‚h��ã�������������������óâ��—�d�Z�ddlZddlmZmZmZ�ddlmZ�ddlm	Z	��G�d„�d«������Z
�G�d„�d	e
«������Zd
„�Z�G�d„�de
«������Z
d
„�Z�G�d„�de
«������Zd„�Z�G�d„�d«������Z�G�d„�d«������Z�G�d„�de
«������Zd„�Zej*������������������fd„Zd„�Zd„�Zd„�Zd„�Zd„�Z�G�d„�d«������Z�G�d „�d!e«������Z�G�d"„�d#e«������Z�G�d$„�d%e«������Z �G�d&„�d'e«������Z!d(„�Z"d2d)„Z#d3d*„Z$d3d+„Z%�G�d,„�d-«������Z&�G�d.„�d/«������Z'd0e(fd1„Z)y)4z0
The Python wrapper for Hyperon Atom Rust types
é����N)ÚAtomKindÚSerialResultÚ
Serializer)ÚUnion)ÚConvertingSerializerc�������������������óJ���—�e�Zd�ZdZd„�Zd„�Zd„�Zd„�Zd„�Zd„�Z	d„�Z
ed	„�«�������Zy
)ÚAtomzRepresents an Atom of any typec�����������������ó���—�||�_���������y)zInitialize an AtomN)Úcatom©Úselfr���s���  úV/var/lib/jenkins/workspace/mettalog/venv/lib/python3.12/site-packages/hyperon/atoms.pyÚ__init__z
Atom.__init__
���s	���€�àˆ
ó����c�����������������óB���—�t��������j������������������|�j������������������«�������y)z+Frees an Atom and all associated resources.N)ÚhpÚ	atom_freer���©r
���s��� r���Ú__del__zAtom.__del__���s���€�ä
‰T—Z‘ZÕ r���c�����������������óz���—�t��������|t��������«������xr*�t��������j������������������|�j������������������|j������������������«������S�)z>Checks if two atom objects represent the same conceptual Atom.)Ú
isinstancer	���r���Úatom_eqr���©r
���Úothers���  r���Ú__eq__zAtom.__eq__���s,���€�ä˜5¤$Ó'ò�4Ü—
‘
˜4Ÿ:™: u§{¡{Ó3ð	5r���c�����������������ó@���—�t��������j������������������|�j������������������«������S�)z6Renders a human-readable text description of the Atom.)r���Úatom_to_strr���r���s��� r���Ú__repr__z
Atom.__repr__���s���€�ä~‰~˜dŸj™jÓ)Ð)r���c�����������������ó@���—�t��������j������������������|�j������������������«������S�)z5Gets the metatype (kind) of the current Atom instance)r���Úatom_get_metatyper���r���s��� r���Úget_metatypezAtom.get_metatype���s���€�ä×#Ñ# D§J¡JÓ/Ð/r���c�����������������óž���—�t��������j������������������|�j������������������«������}g�}|D�]&��}|j������������������t��������j������������������|«������«�������Œ(�|S�)zXPerforms a depth-first exhaustive iteration of an Atom and all its children recursively.)r���Úatom_iterater���Úappendr	���Ú_from_catom)r
���ÚresÚresultÚrs���    r���ÚiteratezAtom.iterate"���s?���€�äo‰o˜dŸj™jÓ)ˆØˆÛˆAØM‰Mœ$×*Ñ*¨1Ó-Õ.ð�àˆ
r���c�����������������óh���—�t��������t��������j������������������|�j������������������|j������������������«������«������S�)zBMatches one Atom with another, establishing bindings between them.)ÚBindingsSetr���Úatom_match_atomr���)r
���Úbs���  r���Ú
match_atomzAtom.match_atom*���s"���€�äœ2×-Ñ-¨d¯j©j¸!¿'¹'ÓBÓCÐCr���c�����������������óJ��—�t��������j������������������|�«������}|t��������j������������������k(��rt	��������|�«������S�|t��������j
������������������k(��rt
��������|�«������S�|t��������j������������������k(��rt��������|�«������S�|t��������j������������������k(��rt��������|�«������S�t��������dt��������|«������z���«������‚)z'Constructs an Atom by wrapping a C AtomzUnexpected type of the Atom: )
r���r ���r���ÚSYMBOLÚ
SymbolAtomÚVARIABLEÚVariableAtomÚEXPRÚExpressionAtomÚGROUNDEDÚGroundedAtomÚ	ExceptionÚstr)r���Útypes���  r���r%���zAtom._from_catom.���s‰���€�ô�×#Ñ# EÓ*ˆØ”8—?‘?Ò"ܘeÓ$Ð$Ø
”X×&Ñ&Ò
&Ü Ó&Ð&Ø
”X—]‘]Ò
"Ü! %Ó(Ð(Ø
”X×&Ñ&Ò
&Ü Ó&Ð&äÐ;¼cÀ$»iÑGÓHÐHr���N)
Ú__name__Ú
__module__Ú__qualname__Ú__doc__r���r���r���r���r!���r)���r.���Ústaticmethodr%���©�r���r���r	���r	���
���s?���„�Ù(òò!ò5ò
*ò0òòDð�ñIó�ñIr���r	���c�������������������ó(���‡�—�e�Zd�ZdZˆ�fd„Zd„�Zˆ�xZS�)r1���z…A SymbolAtom represents a single concept, identified by name. If two symbols
    have the same name, they reference the same concept.c�����������������ó$���•—�t���������‰|���|«�������y)zInitialize a SymbolAtomN©Úsuperr���©r
���r���Ú	__class__s���  €r���r���zSymbolAtom.__init__A���ó���ø€�ä
‰Ñ˜Õr���c�����������������ó@���—�t��������j������������������|�j������������������«������S�©zReturns the name of the Atom.©r���Ú
atom_get_namer���r���s��� r���Úget_namezSymbolAtom.get_nameE���ó���€�ä×Ñ §
¡
Ó+Ð+r���)r;���r<���r=���r>���r���rL���Ú
__classcell__©rF���s���@r���r1���r1���=���s���ø„�ñ<ô ö,r���r1���c�����������������ó>���—�t��������t��������j������������������|�«������«������S�)z-A convenient method to construct a SymbolAtom)r1���r���Úatom_sym©Únames��� r���ÚSrT���I���s���€�ä”b—k‘k $Ó'Ó(Ð(r���c�������������������ó8���‡�—�e�Zd�ZdZˆ�fd„Zd„�Zed„�«�������Zˆ�xZS�)r3���zˆA VariableAtom represents a variable in an expression. It serves as a
    placeholder that can be matched with, or bound to other Atoms.c�����������������ó$���•—�t���������‰|���|«�������y)zInitialize a VariableAtomNrC���rE���s���  €r���r���zVariableAtom.__init__Q���rG���r���c�����������������ó@���—�t��������j������������������|�j������������������«������S�rI���rJ���r���s��� r���rL���zVariableAtom.get_nameU���rM���r���c�����������������ó>���—�t��������t��������j������������������|�«������«������S�)zXConstruct new VariableAtom instance from VariableAtom.get_name()
        method results.)r3���r���Úatom_var_parse_namerR���s��� r���Ú
parse_namezVariableAtom.parse_nameY���s���€�ô�œB×2Ñ2°4Ó8Ó9Ð9r���)	r;���r<���r=���r>���r���rL���r?���rZ���rN���rO���s���@r���r3���r3���M���s'���ø„�ñFô ò,ð�ñ:ó�ô:r���r3���c�����������������ó>���—�t��������t��������j������������������|�«������«������S�)z/A convenient method to construct a VariableAtom)r3���r���Úatom_varrR���s��� r���ÚVr]���_���s���€�䜟™ DÓ)Ó*Ð*r���c�������������������ó(���‡�—�e�Zd�ZdZˆ�fd„Zd„�Zˆ�xZS�)r5���zKAn ExpressionAtom combines different kinds of Atoms, including expressions.c�����������������ó$���•—�t���������‰|���|«�������y)zInitialize an expression atomNrC���rE���s���  €r���r���zExpressionAtom.__init__f���rG���r���c�����������������óŒ���—�t��������j������������������|�j������������������«������D�cg�c]��}t��������j	������������������|«������‘Œ�c}S�c�c}w�)z+Returns all children Atoms of an expression)r���Úatom_get_childrenr���r	���r%���r���s���  r���Úget_childrenzExpressionAtom.get_childrenj���s0���€�ä57×5IÑ5IÈ$Ï*É*Ó5UÖV¨E”× Ñ  Õ'ÒVÐVùÒVs���¢A)r;���r<���r=���r>���r���rb���rN���rO���s���@r���r5���r5���c���s���ø„�ÙUô öWr���r5���c������������������óx���—�t��������t��������j������������������|�D�cg�c]��}|j������������������‘Œ�c}«������«������S�c�c}w�)z2A convenient method to construct an ExpressionAtom)r5���r���Ú	atom_exprr���)ÚargsÚatoms���  r���ÚErg���o���s(���€�äœ"Ÿ,™,¸tÖ'D°t¨¯
«
Ò'DÓEÓFÐFùÒ'Ds���™7c�������������������óª��—�e�Zd�ZdZej������������������ej������������������j������������������«������Zej������������������ej������������������j������������������«������Z	ej������������������ej������������������j������������������«������Z
ej������������������ej������������������j������������������«������Zej������������������ej������������������j������������������«������Zej������������������ej������������������j������������������«������Z
ej������������������ej������������������j������������������«������Zej������������������ej������������������j������������������«������Zej������������������ej������������������j ������������������«������Zy)ÚAtomTypezDefines all Atom typesN)r;���r<���r=���r>���r	���r%���r���Ú	CAtomTypeÚ	UNDEFINEDÚTYPEÚATOMr0���r2���Ú
EXPRESSIONr6���ÚGROUNDED_SPACEÚUNITr@���r���r���ri���ri���s���sï���„�Ù à× Ñ  §¡×!7Ñ!7Ó8€IØ×јBŸL™L×-Ñ-Ó.€DØ×јBŸL™L×-Ñ-Ó.€DØ
×
Ñ
˜bŸl™l×1Ñ1Ó
2€FØ×Ñ §¡× 5Ñ 5Ó6€HØ×!Ñ! "§,¡,×"9Ñ"9Ó:€JØ×Ñ §¡× 5Ñ 5Ó6€HØ×%Ñ% b§l¡l×&AÑ&AÓB€NØ×јBŸL™L×-Ñ-Ó.Dr���ri���c�������������������óê���—�e�Zd�Zej	������������������ej������������������j������������������«������Zej	������������������ej������������������j������������������«������Zej	������������������ej������������������j������������������«������Z	y)ÚAtomsN)
r;���r<���r=���r	���r%���r���ÚCAtomsÚEMPTYrp���ÚMETTAr@���r���r���rr���rr���€���sJ���„�à×Ñ˜RŸY™YŸ_™_Ó-€EØ×јBŸI™IŸN™NÓ+€DØ×Ñ˜RŸY™YŸ_™_Ó-Er���rr���c�������������������ó.���‡�—�e�Zd�ZdZˆ�fd„Zd„�Zd„�Zˆ�xZS�)r7���a¿��
    A GroundedAtom represents sub-symbolic knowledge. At the API level, it allows
    keeping data and behaviour inside an Atom. There are three aspects of a GroundedAtom
    which can be customized:

        - the type of GroundedAtom is provided by the Atom itself;
        - the matching algorithm used by the Atom;
        - an Atom can be made executable, and used to apply sub-symbolic
          operations to other Atoms as arguments.
    c�����������������ó$���•—�t���������‰|���|«�������y)zInitialize a GroundedAtomNrC���rE���s���  €r���r���zGroundedAtom.__init__’���rG���r���c�����������������ó”���—�t��������j������������������|�j������������������«������rt��������j������������������|�j������������������«������S�t	��������|�«������S�)z«Returns the GroundedAtom object, or the Space wrapped inside a GroundedAtom,
           or convert supported Rust grounded objects into corresponding ValueObjects
        )r���Úatom_is_cgroundedr���Úatom_get_objectÚ_priv_gnd_get_objectr���s��� r���Ú
get_objectzGroundedAtom.get_object–���s6���€�ô�×Ñ §
¡
Ô+Ü×%Ñ% d§j¡jÓ1Ð1ä'¨Ó-Ð-r���c�����������������óf���—�t���������j������������������t��������j������������������|�j������������������«������«������S�)z/Retrieve the grounded type of the GroundedAtom.)r	���r%���r���Úatom_get_grounded_typer���r���s��� r���Úget_grounded_typezGroundedAtom.get_grounded_type¢���s"���€�ä×Ñ¤× 9Ñ 9¸$¿*¹*Ó EÓFÐFr���)r;���r<���r=���r>���r���r|���r���rN���rO���s���@r���r7���r7���†���s���ø„�ñ	ô ò
.öGr���r7���c�����������������ó¶��—�|�j������������������«�������}|t��������j������������������k(��r4ddlm}�|j������������������t
��������j������������������|�j������������������«������«������S�|t��������d«������k(��s|t��������d«������k(��rYt��������«�������}t
��������j������������������|�j������������������|«�������|j������������������€t��������d|�›�«������‚t��������|j������������������«������S�t��������d|�›�«������‚)z·
    Tries to convert grounded object into a one of the standard Python values.
    This implementation is used to automatically convert values from other
    runtimes to Python.
    é���)ÚSpaceRefÚBoolÚNumberzCould not convert atom z'Cannot get_object of unsupported non-C )r���ri���ro���Úbaser‚���Ú_from_cspacer���Úatom_get_spacer���rT���r���Úatom_gnd_serializeÚvalueÚRuntimeErrorÚValueObjectÚ	TypeError)rf���Útypr‚���Ú	converters���    r���r{���r{���¦���s·���€�ð�×
 Ñ
 Ó
"€Cð�Œh×%Ñ%Ò%Ý"Ø×$Ñ$¤R×%6Ñ%6°t·z±zÓ%BÓCÐCØ	”&“	Ò	˜S¤A h£KÒ/Ü(Ó*ˆ	Ü
×јdŸj™j¨)Ô4؏?‰?Ð"ÜÐ!8¸¸Ð?Ó@Ð@ä˜yŸ™Ó/Ð/äÐAÀ$ÀÐHÓIÐIr���c�����������������óz���—�t��������|�d«������sJ�d«�������‚t��������t��������j������������������|�|j������������������«������«������S�)z/A convenient method to construct a GroundedAtomÚcopyz4Method copy should be implemented by grounded object)Úhasattrr7���r���Úatom_gndr���)Úobjectr:���s���  r���ÚGr”���½���s2���€�ä6˜6Ô"ÐZÐ$ZÓZÐ"ÜœŸ™ F¨D¯J©JÓ7Ó8Ð8r���c�����������������ó6��—�t��������j������������������|«������t��������j������������������k7��rt��������j
������������������n*t��������j������������������t��������j������������������|«������d���«������}|D�cg�c]��}t��������j������������������|«������‘Œ�}}�|�j������������������|d|iŽS�c�c}w�)zQ
    Private glue for Hyperonpy implementation.
    Executes grounded Atoms.
    éÿÿÿÿÚres_typ)
r���r ���r���r4���ri���rk���r	���r%���ra���Úexecute)Úgndr���re���r—���r���s���     r���Ú#_priv_call_execute_on_grounded_atomrš���Â���s���€�ô�%'×$8Ñ$8¸Ó$=ÄÇÁÒ$NŒh× Ò Ü
×
Ñ
œb×2Ñ2°3Ó7¸Ñ;Ó
<ð�à15Ö6¨ŒD×Ñ˜UÕ#Ð6€DÐ6؈3;‰;˜Ð. gÑ.Ð.ùò�7s���Á&Bc�����������������óJ���—�|�j������������������t��������j������������������|«������«������S�)zO
    Private glue for Hyperonpy implementation.
    Matches grounded atoms
    )Úmatch_r	���r%���)r™���r���s���  r���Ú!_priv_call_match_on_grounded_atomr���Í���s���€�ð
�:‰:”d×&Ñ& uÓ-Ó.Ð.r���c�����������������ó$���—�|�j������������������|«������S�)zR
    Private glue for Hyperonpy implementation.
    Serializes grounded atoms
    )Ú	serialize)r™���Ú
serializers���  r���Ú%_priv_call_serialize_on_grounded_atomr¡���Ô���s���€�ð
�=‰=˜Ó$Ð$r���c�����������������ó¬���—�t��������j������������������|«������t��������j������������������k(��rt	��������|«������}	�|�|j������������������«�������k(��S�y#�t��������$�r�Y�yw�xY�w)zz
    Private glue for Hyperonpy implementation.
    Tests for equality between a grounded value atom and another atom
    F)r���r ���r���r6���r7���r|���rŒ���)r™���r���rf���s���   r���Ú_priv_compare_value_atomr£���Û���sW���€�ô
�
×јEÓ"¤h×&7Ñ&7Ò7ܘEÓ"ˆð	ؘ$Ÿ/™/Ó+Ñ+Ð+ð�øô�ò�	Ùð	ús���³A�Á	AÁAc�����������������óV���—�t��������j������������������|�j������������������|j������������������«������S�)z!Check if two atoms are equivalent)r���Úatoms_are_equivalentr���)ÚfirstÚseconds���  r���r¥���r¥���é���s���€�ä
×"Ñ" 5§;¡;°·±Ó=Ð=r���c�������������������ó$���—�e�Zd�ZdZdd„Zd„�Zd„�Zy)ÚGroundedObjectzCA GroundedObject holds some content and, optionally, an identifier.Nc�����������������ó ���—�||�_���������||�_��������y)zGInitializes a new GroundedObject with the given content and identifier.N)ÚcontentÚid)r
���r«���r¬���s���   r���r���zGroundedObject.__init__ð���s���€�àˆŒ؈r���c�����������������ó°���—�t��������|�j������������������t��������«������rd|�j������������������›�dS�|�j������������������€t	��������|�j������������������«������S�|�j������������������S�)z]Returns the object's ID if present, or a string representation of
        its content if not.ú")r���r«���r9���r¬���Úreprr���s��� r���r���zGroundedObject.__repr__õ���sG���€�ô
�d—l‘l¤CÔ(ؐt—|‘|n AÐ&Ð&ð�&*§W¡W _ŒtD—L‘LÓ!ÐA¸$¿'¹'ÐAr���c�����������������ó���—�|�S�)z†
        Returns a copy of this GroundedObject instance.

        Note: Currently, this method returns the original instance.
        r@���r���s��� r���r���zGroundedObject.copy���s	���€�ð�ˆr���©N)r;���r<���r=���r>���r���r���r���r@���r���r���r©���r©���í���s���„�ÙMóò
	Bór���r©���c�������������������ó,���—�e�Zd�ZdZed„�«�������Zd„�Zd„�Zy)r‹���af��
    A ValueObject is a specialized form of GroundedObject, which treats its content
    as a value. It allows for equality comparison between the content of two ValueObjects.

    Example:
        obj1 = ValueObject(5)
        obj2 = ValueObject(5)
        obj3 = ValueObject(6)

        print(obj1 == obj2)  # True
        print(obj1 == obj3)  # False
    c�����������������ó���—�|�j�������������������S�)z3Gets the value of the object, which is its content.©r«���r���s��� r���r‰���zValueObject.value��ó���€�ð�|‰|Ðr���c�����������������óX���—�t��������|t��������«������xr�|�j������������������|j������������������k(��S�)zNCompares the equality of this ValueObject with another based on their content.)r���r‹���r«���r���s���  r���r���zValueObject.__eq__��s#���€�ô�˜%¤Ó-ÒO°$·,±,À%Ç-Á-Ñ2OÐOr���c�����������������ó`��—�t��������|�j������������������t��������«������r|j������������������|�j������������������«������S�t��������|�j������������������t��������«������r|j������������������|�j������������������«������S�t��������|�j������������������t��������«������r|j������������������|�j������������������«������S�t��������j������������������S�)z‡
        Serialize standard Python values. This implementation is used to
        pass Python values into the foreign runtime.
        )
r���r«���ÚboolÚserialize_boolÚintÚ
serialize_intÚfloatÚserialize_floatr���Ú
NOT_SUPPORTED)r
���r ���s���  r���rŸ���zValueObject.serialize#��sy���€�ô
�d—l‘l¤DÔ)Ø×,Ñ,¨T¯\©\Ó:Ð:Ü
˜Ÿ™¤cÔ
*Ø×+Ñ+¨D¯L©LÓ9Ð9Ü
˜Ÿ™¤eÔ
,Ø×-Ñ-¨d¯l©lÓ;Ð;ä×-Ñ-Ð-r���N)r;���r<���r=���r>���Úpropertyr‰���r���rŸ���r@���r���r���r‹���r‹�����s&���„�ñð�ñó�ðòPó.r���r‹���c�������������������ó���—�e�Zd�ZdZy)Ú
NoReduceErrorzHCustom exception; raised when a reduction operation cannot be performed.N)r;���r<���r=���r>���r@���r���r���rÁ���rÁ���1��s���„�ÙRØr���rÁ���c�������������������ój���‡�—�e�Zd�ZdZdˆ�fd„	Zed„�«�������Zed„�«�������Zej������������������dœd„Z
d„�Zˆ�xZS�)	ÚOperationObjectaÏ��
    An OperationObject represents an operation as a grounded object, allowing for more
    advanced logic like lazy evaluation, type-checking, and more.

    Inherits:
        GroundedObject: The parent class that provides the basic wrapper around content.

    Attributes:
        unwrap (bool): Determines whether to unwrap the content of GroundedAtoms
                       when passed as arguments to the operation.

    Properties:
        op: Returns the operation function.
        name: Returns the identifier name for this operation object.

    Methods:
        __init__(name, op, unwrap): Initializes an OperationObject instance.
        execute(*args, res_typ): Executes the operation with the provided arguments.
        __eq__(other): Compares the equality of this OperationObject instance with another.

    Example:
        def add(a, b):
            return a + b

        op_obj = OperationObject("addition", add)
        result = op_obj.execute(3, 4)
    c�����������������ó4���•—�t���������‰|���||«�������||�_��������y)a¸��
        Initializes a new OperationObject with a name identifier, operation function,
        and an optional unwrap flag.
        Parameters:
            name (str): The identifier for this operation.
            op (function): The function representing the operation.
            unwrap (bool, optional): Whether to unwrap GroundedAtom content when applying
                                     the operation. Defaults to True.

        N)rD���r���Úunwrap)r
���rS���ÚoprÅ���rF���s���    €r���r���zOperationObject.__init__R��s���ø€�ô�	‰Ñ˜˜TÔ"؈r���c�����������������ó���—�|�j�������������������S�)zReturns the operation function.r´���r���s��� r���rÆ���zOperationObject.op`��rµ���r���c�����������������ó���—�|�j�������������������S�)z6Returns the identifier name for this operation object.)r¬���r���s��� r���rS���zOperationObject.namee��s
���€�ð�w‰wˆr���)r—���c����������������ó<��—�|�j�������������������r#g�}i�}|D�]Å��}t��������|t��������«������r‰|j������������������«�������}t	��������|«������dkD��rkt��������|d���«������dk(��rZ|dd�D�]Q��}	�|j������������������«�������}t	��������|«������dk(��sJ�‚	�	�|d���j������������������«�������j������������������|t��������|d���«������<���ŒS�Œœ	�|j������������������|j������������������«�������j������������������«�������ŒÇ��|�j������������������|i�|¤Ž}	|	€t��������j������������������gS�t��������|	«������rt!��������t��������|	«������|	d¬«������gS�t#��������|	|«������gS��|�j������������������|Ž�}	t��������|	t$��������«������st
��������d	|�j&������������������z���d
z���«������‚|	S�#��t
��������d›�«������‚xY�w#��t��������«�������‚xY�w#��t��������«�������‚xY�w)a¯��
        Executes the operation with the provided arguments.

        Parameters:
            *args: Arguments to pass to the operation function.
            res_typ (AtomType, optional): The expected result type. Defaults to AtomType.UNDEFINED.

        Returns:
            The result of the operation.

        Raises:
            NoReduceError: Raised when `unwrap=True` and a non-GroundedAtom argument is provided.
            RuntimeError: Raised when the result of the operation is not a list.

        Note:
            Depending on the `unwrap` attribute, this method will either unwrap GroundedAtoms
            before passing them to the operation or pass them as is.
        r���ÚKwargsr���Né���zIncorrect kwarg format T)rÅ���zGrounded operation `z` should return list)rÅ���r���r5���rb���Úlenr¯���rŠ���r|���r«���Úget_string_valuerÁ���r$���rÆ���rr���rp���ÚcallableÚ
OperationAtomÚ	ValueAtomÚlistrS���)
r
���r—���Úatomsre���ÚkwargsÚaÚchÚcÚkwargr'���s
���          r���r˜���zOperationObject.executej��s—��€�ð(�;‹;؈D؈Fېܘa¤Ô0ØŸ™Ó)Bܘ2“w ’{¤t¨B¨q©E£{°hÒ'>Ø!# A B£˜AðVØ()¯©Ó(8 Ü'*¨5£z°Q¢Ð 6¡ð6ØEJÈ1ÁX×EXÑEXÓEZ×EbÑEb Ô'7¸¸a¹Ó'AÒ Bð�"(ð�!ð*Ø—K‘K §¡£× 6Ñ 6Õ7ð!�ð0�T—W‘W˜dÐ- fÑ-ˆF؈~ÜŸ
™
|Ð#ܘÔÜ%¤d¨6£l°FÀ4ÔHÐIÐIܘf gÓ.Ð/Ð/àT—W‘W˜e_ˆFܘf¤dÔ+Ü"Ð#9¸D¿I¹IÑ#EÐH^Ñ#^Ó_Ð_؈Møð5VÜ&2Ð5LÈUÈGÐ3TÓ&UÐ Uûð6Ü&3£oÐ 5ûð*ô�(›/Ð)ús$���Á E-Â,F�Â1)FÅ-E=Æ�FÆFc�����������������óX���—�t��������|t��������«������xr�|�j������������������|j������������������k(��S�)a*��
        Compares the equality of this OperationObject with another based on their names.

        Parameters:
            other (OperationObject): Another OperationObject instance to compare.

        Returns:
            True if both OperationObjects have the same name; False otherwise.
        )r���rÃ���rS���r���s���  r���r���zOperationObject.__eq__¥��s#���€�ô�˜%¤Ó1ÒM°d·i±iÀ5Ç:Á:Ñ6MÐMr���)T)
r;���r<���r=���r>���r���r¿���rÆ���rS���ri���rk���r˜���r���rN���rO���s���@r���rÃ���rÃ���5��sL���ø„�ñõ8ð�ñó�ðð�ñó�ðð�'/×&8Ñ&8ô�9öv
Nr���rÃ���c�������������������ó���—�e�Zd�ZdZd„�Zy)ÚMatchableObjecta®��
    Represents an object that can be involved in a matching operation with an Atom.

    This class is meant to be subclassed by objects that define specific matching behavior
    with an Atom. It provides a stub method for the matching operation that raises
    a RuntimeError when called, which must be overridden by subclasses.

    Inherits:
        ValueObject: The parent class that provides basic value-based equality and representation.

    Methods:
        match_(atom): A stub method for matching the object with an Atom.

    Example:
        class MyMatchableObject(MatchableObject):
            def match_(self, atom):
                # Implement the matching logic here
                pass

        my_obj = MyMatchableObject("some_value")
        my_obj.match_(some_atom)  # Should not raise RuntimeError

    Raises:
        RuntimeError: Raised when the match_ method is called without being overridden by a subclass.
    c�����������������ó���—�t��������d«������‚)a…��
        A stub method for matching the object with an Atom.

        This method is intended to be overridden by subclasses to provide specific
        matching behavior with an Atom.

        Parameters:
            atom (Atom): An Atom object to match against.

        Raises:
            RuntimeError: Raised when this method is called without being overridden in a subclass.
        z,MatchableObject::match_() is not implemented)rŠ���)r
���rf���s���  r���rœ���zMatchableObject.match_Ì��s���€�ô�ÐIÓJÐJr���N)r;���r<���r=���r>���rœ���r@���r���r���rÚ���rÚ���±��s
���„�ñó4
Kr���rÚ���c�����������	������ó��—�|�€t���������j������������������S�t��������|�t��������«������r,t	��������t��������d«������g|�D�cg�c]
��}t
��������|«������‘Œ�c}¢­Ž�S�t��������|�t��������«������r!|�d���dk(��rt��������|�dd�«������S�t��������|�«������S�|�S�c�c}w�)a‚��
    Transforms a variety of type representations into a unified Atom-based format.

    This utility function is intended for internal use to handle different ways in which
    type information can be provided. It converts `type_names` into a form that can be
    readily used for type checking or other internal operations.

    Parameters:
        type_names (Union[None, list, str, AtomType]): The type information to be converted.
            - If None, will return AtomType.UNDEFINED.
            - If list, will recursively transform each element.
            - If str, will return a Variable Atom (`V`) if the string starts with '$'; otherwise, returns a Symbol Atom (`S`).
            - If already an AtomType, returns it as is.

    Returns:
        AtomType: The transformed type information in AtomType format.

    Examples:
        _type_sugar(None)                 => AtomType.UNDEFINED
        _type_sugar(["int", "str"])       => E(S("->"), S("int"), S("str"))
        _type_sugar("$var")               => V("var")
        _type_sugar("int")                => S("int")
        _type_sugar(AtomType.SOME_TYPE)   => AtomType.SOME_TYPE
    Nz->r���ú$r���)	ri���rk���r���rÑ���rg���rT���Ú_type_sugarr9���r]���)Ú
type_namesÚns���  r���rÞ���rÞ���Û��s~���€�ð2�ÐÜ×!Ñ!Ð!ܐ*œdÔ#Ü”4“Ð@°JÖ?¨qœK¨NÒ?Ò@Ð@ܐ*œcÔ"Ø$.¨q¡M°SÒ$8Œq˜A˜BÓ ÐK¼aÀ
»mÐKØÐùò�@s���·B
c�����������������óB���—�t��������t��������|�||«������t��������|«������«������S�)zñ
    An OperationAtom wraps an operation with optional type information into a GroundedAtom
    and associates a name with it. Useful for registering custom operations
    that can be executed in an Atom-based computational environment.
    )r”���rÃ���rÞ���)rS���rÆ���rß���rÅ���s���    r���rÏ���rÏ���ü��s���€�ô�
Œ_˜T 2 vÓ
.´¸JÓ0GÓHÐHr���c�����������������ó@���—�t��������t��������|�|«������t��������|«������«������S�)z_Creates a GroundedAtom that wraps a given value, optionally specifying its type and identifier.)r”���r‹���rÞ���©r‰���Ú	type_nameÚatom_ids���   r���rÐ���rÐ�����s���€�äŒ[˜ Ó
(¬+°iÓ*@ÓAÐAr���c�����������������ó@���—�t��������t��������|�|«������t��������|«������«������S�)zn
    Creates a Grounded Atom that wraps a matchable value, optionally specifying its type and identifier.
    )r”���rÚ���rÞ���rã���s���   r���Ú
MatchableAtomrç�����s���€�ô�
Œ_˜U GÓ
,¬k¸)Ó.DÓEÐEr���c�������������������ó¸���—�e�Zd�ZdZddeej������������������df���fd„Zd„�Zd„�Z	d„�Z
i�fd„Zd	„�Zd
„�Z
d„�Zdd
„Zdededefd„Zdefd„Zd„�Zdedeedf���fd„Zd„�Zy)ÚBindingszFInterface for working with atom matching and variable-to-atom binding.NÚbindingsc�����������������óJ���—�|€t��������j������������������«�������|�_��������y||�_��������y)z2Initializes with or without pre-existing bindings.N)r���Úbindings_newÚ	cbindings©r
���rê���s���  r���r���zBindings.__init__��s���€�àÐÜŸ_™_Ó.ˆDNà%ˆDNr���c�����������������ó\���—�|�j������������������� t��������j������������������|�j�������������������«�������yy)zFrees the binding resources.N©rí���r���Ú
bindings_freer���s��� r���r���zBindings.__del__��s#���€�à>‰>Ð%Ü×Ñ˜TŸ^™^Õ,ð�&r���c�����������������óz���—�t��������|t��������«������xr*�t��������j������������������|�j������������������|j������������������«������S�)z>Checks if two bindings objects contain identical associations.)r���ré���r���Úbindings_eqrí���r���s���  r���r���zBindings.__eq__��s.���€�ä˜5¤(Ó+ò�@Ü—‘˜tŸ~™~¨u¯©Ó?ð	Ar���c�����������������ó@���—�t��������j������������������|�j������������������«������S�)z*Renders a text description of the bindings)r���Úbindings_to_strrí���r���s��� r���r���zBindings.__repr__#��s���€�ä×!Ñ! $§.¡.Ó1Ð1r���c�����������������ó"���—�|�j������������������«�������S�)z$Makes a "deep copy" of the bindings.©Úclone©r
���Úmemodicts���  r���Ú__deepcopy__zBindings.__deepcopy__'��ó���€�àz‰z‹|Ðr���c�����������������ó���—�|�S�©zFor context management.r@���r���s��� r���Ú	__enter__zBindings.__enter__+��ó���€�àˆr���c�����������������ój���—�|�j�������������������'t��������j������������������|�j�������������������«�������d|�_���������yy©zFrees resources on exit.Nrð���©r
���Úexc_typeÚexc_valÚexc_tbs���    r���Ú__exit__zBindings.__exit__/��s*���€�à>‰>Ð%Ü×Ñ˜TŸ^™^Ô,Ø!ˆDNð�&r���c�����������������óR���—�t��������t��������j������������������|�j������������������«������«������S�)z#Makes a "deep copy" of the bindings)ré���r���Úbindings_clonerí���r���s��� r���rø���zBindings.clone5��s���€�äœ×)Ñ)¨$¯.©.Ó9Ó:Ð:r���Úreturnc�����������������óh���—�t��������t��������j������������������|�j������������������|j������������������«������«������S�)z;Merges with another Bindings instance, into a Bindings Set.)r+���r���Úbindings_mergerí���r���s���  r���ÚmergezBindings.merge9��s"���€�äœ2×,Ñ,¨T¯^©^¸U¿_¹_ÓMÓNÐNr���Úvarrf���c�����������������ól���—�t��������j������������������|�j������������������|j������������������|j������������������«������S�)z.Adds a binding between a variable and an Atom.)r���Úbindings_add_var_bindingrí���r���)r
���r��rf���s���   r���Úadd_var_bindingzBindings.add_var_binding=��s#���€�ä×*Ñ*¨4¯>©>¸3¿9¹9ÀdÇjÁjÓQÐQr���c�����������������ó@���—�t��������j������������������|�j������������������«������S�)z.Checks if a bindings contains no associations.)r���Úbindings_is_emptyrí���r���s��� r���Úis_emptyzBindings.is_emptyA��s���€�ä×#Ñ# D§N¡NÓ3Ð3r���c�����������������óú���—�t��������j������������������«�������x}t���������_��������|D�]"��}t��������j������������������||j������������������«�������Œ$�t��������j
������������������|�j������������������|«�������t��������j������������������|«�������y)z*Keeps only specific variable associations.N)r���Úatom_vec_newÚCVecAtomÚ
atom_vec_pushr���Úbindings_narrow_varsrí���Ú
atom_vec_free)r
���ÚvarsÚcvarsr��s���    r���Únarrow_varszBindings.narrow_varsE��sU���€�ä Ÿo™oÓ/Ð/ˆ””ÛˆCÜ×Ñ˜U C§I¡IÕ.ð�ä
×Ñ §¡°Ô6Ü
×јÕr���c�����������������óˆ���—�t��������j������������������|�j������������������|j������������������«������}|€dS�t��������j������������������|«������S�)z#Finds the atom for a given variableN)r���Úbindings_resolverí���r���r	���r%���)r
���r��Úraw_atoms���   r���ÚresolvezBindings.resolveM��s7���€�ä×&Ñ& t§~¡~°s·y±yÓAˆØÐ'ˆtÐG¬T×-=Ñ-=¸hÓ-GÐGr���c�����������������óÚ���—�t��������j������������������|�j������������������«������}|D�cg�c]2��}t��������j	������������������|d���«������t��������j	������������������|d���«������f‘Œ4�}}t��������|«������S�c�c}w�)z@Returns an iterator over the variable-atom pairs in the bindingsr���r���)r���Ú
bindings_listrí���r	���r%���Úiter©r
���r&���r(���r'���s���    r���ÚiteratorzBindings.iteratorR��s\���€�ä×јtŸ~™~Ó.ˆØLOÖPÀq”4×#Ñ# A a¡DÓ)¬4×+;Ñ+;¸A¸a¹DÓ+AÒBÐPˆÐPܐF‹|Ðùò�Qs���¤7A(r±���)r���ré���r
��r+���)r;���r<���r=���r>���r���r���Ú	CBindingsr���r���r���r���rû���rÿ���r��rø���r
��r3���r	���r¸���r��r��r��r!��r&��r@���r���r���ré���ré�����s¡���„�ÙPñ&  r§|¡|°TÐ'9Ñ!:ó�&ò-ò
Aò
2ð�%'ó�òò"ò;óOðR <ð�R°tð�RÀó�Rð4˜$ó�4ò ðH˜<ð�H¨E°$¸°*Ñ,=ó�Hó
r���ré���c�������������������óà���—�e�Zd�ZdZddeej������������������edf���fd„Zd„�Z	d„�Z
d„�Zi�fd„Zd	„�Z
d
„�Zd„�Zd„�Zd
„�Zdefd„Zdefd„Zdefd„Zdededefd„Zdededefd„Zded�ef���fd„Zd„�Zy)r+���zsRepresents a set of Bindings frames, potentially expressing all possible
    matches produced by a match operation.NÚinputc�����������������óÂ���—�d|�_���������|€t��������j������������������«�������|�_��������yt	��������|t
��������«������r%t��������j������������������|j������������������«������|�_��������y||�_��������y)z Initializes with optional input.N)Úshadow_listr���Úbindings_set_singleÚc_setr���ré���Úbindings_set_from_bindingsrí���)r
���r)��s���  r���r���zBindingsSet.__init__\��sF���€�àˆÔ؈=Ü×/Ñ/Ó1ˆDJÜ
˜œxÔ
(Ü×6Ñ6°u·±ÓGˆDJàˆDJr���c�����������������ój���—�|�j�������������������'t��������j������������������|�j�������������������«�������d|�_���������yy)zFrees the BindingsSetN©r-��r���Úbindings_set_freer���s��� r���r���zBindingsSet.__del__f��ó*���€�à:‰:Ð!Ü× Ñ  §¡Ô,؈DJð�"r���c�����������������óz���—�t��������|t��������«������xr*�t��������j������������������|�j������������������|j������������������«������S�)z<Checks if other BindingsSet contains identical associations.)r���r+���r���Úbindings_set_eqr-��r���s���  r���r���zBindingsSet.__eq__l��s.���€�ä˜5¤+Ó.ò�<Ü×"Ñ" 4§:¡:¨u¯{©{Ó;ð	=r���c�����������������ó@���—�t��������j������������������|�j������������������«������S�)z+Renders a text description of a BindingsSet)r���Úbindings_set_to_strr-��r���s��� r���r���zBindingsSet.__repr__q��s���€�ä×%Ñ% d§j¡jÓ1Ð1r���c�����������������ó"���—�|�j������������������«�������S�©z$Makes a "deep copy" of a BindingsSetr÷���rù���s���  r���rû���zBindingsSet.__deepcopy__u��rü���r���c�����������������ó���—�|�S�rþ���r@���r���s��� r���rÿ���zBindingsSet.__enter__y��r���r���c�����������������ój���—�|�j�������������������'t��������j������������������|�j�������������������«�������d|�_���������yyr��r0��r��s���    r���r��zBindingsSet.__exit__}��r2��r���c�����������
������ó,��—�|�j�������������������€mt��������j������������������|�j������������������«������}|D�cg�c]9��}|j	������������������«�������D�ci�c]��\��}}|t
��������j
������������������|«������“Œ�c}}‘Œ;�c}}}|�_���������|�j�������������������|���S�c�c}}w�c�c}}}w�)zGets a Bindings frame by index)r+��r���Úbindings_set_unpackr-��Úitemsr	���r%���)r
���Úkeyr'���rê���ÚkÚvs���      r���Ú__getitem__zBindingsSet.__getitem__ƒ��sy���€�à×ÑÐ#Ü×+Ñ+¨D¯J©JÓ7ˆFØfl×mÐmÐZbÀHÇNÁNÓDT× U¹D¸A¸q ¤D×$4Ñ$4°QÓ$7Ñ!7Õ UÔmˆDÔØ×Ñ Ñ$Ð$ùó�!VùÔms���²BÁ
 B	Á*BÂ	Bc������������������ó<���—�t��������t��������j������������������«�������«������S�)zxCreates a new BindingsSet without any Bindings frames.
        Conceptually, this means no valid matches exist.
        )r+���r���Úbindings_set_emptyr@���r���r���ÚemptyzBindingsSet.emptyŠ��s���€�ô�œ2×0Ñ0Ó2Ó3Ð3r���c�����������������óR���—�t��������t��������j������������������|�j������������������«������«������S�r8��)r+���r���Úbindings_set_cloner-��r���s��� r���rø���zBindingsSet.clone��s���€�äœ2×0Ñ0°·±Ó<Ó=Ð=r���r
��c�����������������ó@���—�t��������j������������������|�j������������������«������S�)zYChecks if a BindingsSet contains no Bindings frames, and thus indicates
        no match.)r���Úbindings_set_is_emptyr-��r���s��� r���r��zBindingsSet.is_empty”��s���€�ô�×'Ñ'¨¯
©
Ó3Ð3r���c�����������������ó@���—�t��������j������������������|�j������������������«������S�)z}Checks if a Bindings set contains a frame with no associations, and
        thus allows variables to take any value.
        )r���Úbindings_set_is_singler-��r���s��� r���Ú	is_singlezBindingsSet.is_single™��s���€�ô�×(Ñ(¨¯©Ó4Ð4r���rê���c�����������������óf���—�d|�_���������t��������j������������������|�j������������������|j������������������«�������y)zêAdds a Bindings frame to an existing BindingsSet

        Parameters
        ----------
        bindings:
            The Bindings set to incorporate into set. Ownership of this argument is
            taken by this function.
        N)r+��r���Úbindings_set_pushr-��rí���rî���s���  r���ÚpushzBindingsSet.pushŸ��s&���€�ð� ˆÔÜ
×јTŸZ™Z¨×);Ñ);Õ<r���r��r‰���c�����������������óz���—�d|�_���������t��������j������������������|�j������������������|j������������������|j������������������«������S�)zbAdds a new variable to atom association to every Bindings frame in a
        BindingsSet.
        N)r+��r���Úbindings_set_add_var_bindingr-��r���)r
���r��r‰���s���   r���r��zBindingsSet.add_var_binding«��s-���€�ð� ˆÔÜ×.Ñ.¨t¯z©z¸3¿9¹9ÀeÇkÁkÓRÐRr���rÔ���r-���c�����������������óz���—�d|�_���������t��������j������������������|�j������������������|j������������������|j������������������«������S�)z=Asserts equality between two Variable atoms in a BindingsSet.N)r+��r���Úbindings_set_add_var_equalityr-��r���)r
���rÔ���r-���s���   r���Úadd_var_equalityzBindingsSet.add_var_equality²��s+���€�àˆÔÜ×/Ñ/°·
±
¸A¿G¹GÀQÇWÁWÓMÐMr���c�����������������óò���—�d|�_���������t��������|t��������«������r+t��������j������������������|�j
������������������|j
������������������«�������yt��������|«������}t��������j������������������|�j
������������������|j
������������������«�������y)z=Merges the contents of another BindingsSet or Bindings frame.N)r+��r���r+���r���Úbindings_set_merge_intor-��)r
���r)��Únew_sets���   r���Ú
merge_intozBindingsSet.merge_into·��sN���€�àˆÔܐeœ[Ô)Ü×&Ñ& t§z¡z°5·;±;Õ?ä! %Ó(ˆGÜ×&Ñ& t§z¡z°7·=±=ÕAr���c�����������������ó���—�t��������j������������������|�j������������������«������}|D�cg�c]
��}t��������|«������‘Œ�}}t	��������|«������S�c�c}w�)z,Returns an iterator over all Bindings frames)r���Úbindings_set_listr-��ré���r$��r%��s���    r���r&��zBindingsSet.iteratorÀ��s<���€�ä×"Ñ" 4§:¡:Ó.ˆØ'*Ö+ !”(˜1•+Ð+ˆÐ+ܐF‹|Ðùò�,s���¤Ar±���)r;���r<���r=���r>���r���r���ÚCBindingsSetré���r���r���r���r���rû���rÿ���r��rA��rD��rø���r¸���r��rK��rN��r3���r	���r��rS��rW��r&��r@���r���r���r+���r+���X��sÒ���„�ñ.ñ˜e B§O¡O°X¸tÐ$CÑDó�òò=ò
2ð�%'ó�òòò%ò4ò>ð4˜$ó�4ð
5˜4ó�5ð
=˜Xó�
=ðS <ð�S¸ð�SÀó�SðN $ð�N¨4ð�N°Dó�Nð
B  m°XÐ&=Ñ >ó�Bór���r+���r
��c�����������������ó‚���—�t��������|�t��������«������st��������|�«������}�t��������|�«������dkD��rd|�d���k(��r
d|�d���k(��r|�dd�S�|�S�)NrË���r®���r���r–���r���)r���r9���r¯���rÌ���)r‰���s��� r���rÍ���rÍ���Æ��sG���€�ܐeœSÔ!ܐU“ˆÜ
ˆ5ƒzA‚~˜4 5¨¡8Ò+°$¸%À¹)Ò2CؐQrˆ{ÐØ€Lr���)NT)NN)*r>���Ú	hyperonpyr���r���r���r���Útypingr���Úhyperon.conversionr���r	���r1���rT���r3���r]���r5���rg���ri���rr���r7���r{���rk���r”���rš���r���r¡���r£���r¥���r©���r‹���r8���rÁ���rÃ���rÚ���rÞ���rÏ���rÐ���rç���ré���r+���r9���rÍ���r@���r���r���ú<module>r_�����s1��ðñó�ß�8Ñ�8Ý�Ý�3÷1Iñ�1Iôf
,ô�
,ò)ô:4ô�:ò$+ô	WTô�	WòG÷/ñ�/÷.ñ�.ôG4ô�Gò@Jð.�×%Ñ%ó�9ò
	/ò/ò%òò>÷ñ�ô6'..ô�'.ôR	Iô�	ôzNnô�zNôx(Kkô�(KòTóBIóBóF÷Gñ�G÷Rlñ�lð\˜sô�r���