Ë ����†£éf‚h��ã�������������������óâ��—�d�Z�ddlZddlmZmZmZ�ddlmZ�ddlm Z ��G�d„�d«������Z �G�d„�d e «������Zd „�Z�G�d„�de «������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 „�«�������Zy )Ú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__zAtom.__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���ÚiteratezAtom.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���™7c�������������������óª��—�e�Zd�ZdZej������������������ej������������������j������������������«������Zej������������������ej������������������j������������������«������Z ej������������������ej������������������j������������������«������Z ej������������������ej������������������j������������������«������Zej������������������ej������������������j������������������«������Zej������������������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������������������›�dS�|�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 _ŒtD—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ˆ�xZS�) Ú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 „�Zd „�Z d„�Zdd „Zdededefd„Zdefd„Zd„�Zdedeedf���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���€�àÐÜŸ_™_Ó.ˆDNà%ˆDNr���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Ÿ^™^Ô,Ø!ˆDNð�&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„Zd „�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ˆDJÜ ˜œxÔ (Ü×6Ñ6°u·±ÓGˆDJàˆDJr���c�����������������ój���—�|�j�������������������'t��������j������������������|�j�������������������«�������d|�_���������yy)zFrees the BindingsSetN©r-��r���Úbindings_set_freer���s��� r���r���zBindingsSet.__del__f��ó*���€�à:‰:Ð!Ü× Ñ §¡Ô,؈DJð�"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ƒzA‚~˜4 5¨¡8Ò+°$¸%À¹)Ò2CØQrˆ{ÐØ€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ô�:ò$+ô WTô� WòG÷/ñ�/÷.ñ�.ôG4ô�Gò@Jð.�×%Ñ%ó�9ò /ò/ò%òò>÷ñ�ô6'..ô�'.ôR Iô� ôzNnô�zNôx(Kkô�(KòTóBIóBóF÷Gñ�G÷Rlñ�lð\˜sô�r���