
    `iG)                         d dl Z d dlZd dlmZ d dlmZ g dZd Zd Zd Z	e
fdZe
fd	Ze
fd
Ze
fdZe
fdZe
fdZe
fdZd Ze
fdZde
fdZddZd Zd Zd ZdS )    N)Mapping)reduce)merge
merge_withvalmapkeymapitemmap	valfilter	keyfilter
itemfilterassocdissocassoc_in	update_inget_inc                     |                     dt                    }|r2t          | j         d|                                d          d          |S )Nfactoryz'() got an unexpected keyword argument 'r   ')popdict	TypeError__name__popitem)fkwargsr   s      /home/jaya/work/projects/VOICE-AGENT/VIET/agent-env/lib/python3.11/site-packages/torch/fx/experimental/unification/unification_tools.py_get_factoryr      s\    jjD))G 
zXX&..BRBRSTBUXXX
 
 	
 N    c                      t          |           dk    r#t          | d         t                    s| d         } t          t          |          } |            }| D ]}|                    |           |S )zMerge a collection of dictionaries

    >>> merge({1: "one"}, {2: "two"})
    {1: 'one', 2: 'two'}

    Later dictionaries have precedence

    >>> merge({1: 2, 3: 4}, {3: 3, 4: 4})
    {1: 2, 3: 3, 4: 4}

    See Also:
        merge_with
       r   )len
isinstancer   r   r   update)dictsr   r   rvds        r   r   r   "   sm     5zzQz%(G<<a5&))G	B  
		!Ir   c                 X   t          |          dk    r#t          |d         t                    s|d         }t          t          |          } |            }|D ]B}|                                D ]+\  }}||vr|g||<   ||                             |           ,Ct          | ||          S )a  Merge dictionaries and apply function to combined values

    A key may occur in more than one dict, and all values mapped from the key
    will be passed to the function as a list, such as func([val1, val2, ...]).

    >>> merge_with(sum, {1: 1, 2: 2}, {1: 10, 2: 20})
    {1: 11, 2: 22}

    >>> merge_with(first, {1: 1, 2: 2}, {2: 20, 3: 30})  # doctest: +SKIP
    {1: 1, 2: 2, 3: 30}

    See Also:
        merge
    r    r   )r!   r"   r   r   r   itemsappendr   )funcr$   r   r   resultr&   kvs           r   r   r   :   s     5zzQz%(G<<a:v..GWYYF $ $GGII 	$ 	$DAqCq		q	  ####		$
 $(((r   c           
           |            }|                     t          |                                t          | |                                                               |S )zApply function to values of dictionary

    >>> bills = {"Alice": [20, 15, 30], "Bob": [10, 35]}
    >>> valmap(sum, bills)  # doctest: +SKIP
    {'Alice': 65, 'Bob': 45}

    See Also:
        keymap
        itemmap
    )r#   zipkeysmapvaluesr*   r&   r   r%   s       r   r   r   W   sJ     
BIIc!&&((Cahhjj1122333Ir   c           	           |            }|                     t          t          | |                                          |                                                     |S )zApply function to keys of dictionary

    >>> bills = {"Alice": [20, 15, 30], "Bob": [10, 35]}
    >>> keymap(str.lower, bills)  # doctest: +SKIP
    {'alice': [20, 15, 30], 'bob': [10, 35]}

    See Also:
        valmap
        itemmap
    )r#   r/   r1   r0   r2   r3   s       r   r   r   g   sJ     
BIIc#dAFFHH%%qxxzz22333Ir   c                      |            }|                     t          | |                                                     |S )zApply function to items of dictionary

    >>> accountids = {"Alice": 10, "Bob": 20}
    >>> itemmap(reversed, accountids)  # doctest: +SKIP
    {10: "Alice", 20: "Bob"}

    See Also:
        keymap
        valmap
    )r#   r1   r(   r3   s       r   r	   r	   w   s8     
BIIc$		""###Ir   c                 n     |            }|                                 D ]\  }} | |          r|||<   |S )zFilter items in dictionary by value

    >>> iseven = lambda x: x % 2 == 0
    >>> d = {1: 2, 2: 3, 3: 4, 4: 5}
    >>> valfilter(iseven, d)
    {1: 2, 3: 4}

    See Also:
        keyfilter
        itemfilter
        valmap
    r(   	predicater&   r   r%   r,   r-   s         r   r
   r
      I     
B		  19Q<< 	BqEIr   c                 n     |            }|                                 D ]\  }} | |          r|||<   |S )zFilter items in dictionary by key

    >>> iseven = lambda x: x % 2 == 0
    >>> d = {1: 2, 2: 3, 3: 4, 4: 5}
    >>> keyfilter(iseven, d)
    {2: 3, 4: 5}

    See Also:
        valfilter
        itemfilter
        keymap
    r7   r8   s         r   r   r      r:   r   c                 r     |            }|                                 D ]} | |          r
|\  }}|||<   |S )a  Filter items in dictionary by item

    >>> def isvalid(item):
    ...     k, v = item
    ...     return k % 2 == 0 and v < 4

    >>> d = {1: 2, 2: 3, 3: 4, 4: 5}
    >>> itemfilter(isvalid, d)
    {2: 3}

    See Also:
        keyfilter
        valfilter
        itemmap
    r7   )r9   r&   r   r%   itemr,   r-   s          r   r   r      sN      
B		  9T?? 	DAqBqEIr   c                 N     |            }|                     |            |||<   |S )zReturn a new dict with new key value pair

    New dict has d[key] set to value. Does not modify the initial dictionary.

    >>> assoc({"x": 1}, "x", 2)
    {'x': 2}
    >>> assoc({"x": 1}, "y", 3)  # doctest: +SKIP
    {'x': 1, 'y': 3}
    )r#   )r&   keyvaluer   d2s        r   r   r      s,     
BIIaLLLBsGIr   c                 6   t          t          |          } |            }t          |          t          |           dz  k     r"|                    |            |D ]	}||v r||= 
n4t	          |           }|                    |           |D ]}| |         ||<   |S )aB  Return a new dict with the given key(s) removed.

    New dict has d[key] deleted for each supplied key.
    Does not modify the initial dictionary.

    >>> dissoc({"x": 1, "y": 2}, "y")
    {'x': 1}
    >>> dissoc({"x": 1, "y": 2}, "y", "x")
    {}
    >>> dissoc({"x": 1}, "y")  # Ignores missing keys
    {'x': 1}
    g333333?)r   r   r!   r#   setdifference_update)r&   r0   r   r   rA   r?   	remainingr,   s           r   r   r      s     66**G	B
4yy3q66C<
		! 	 	CbyysG	 FF	##D))) 	 	AaDBqEEIr   c                 0    t          | |fd|          S )a  Return a new dict with new, potentially nested, key value pair

    >>> purchase = {
    ...     "name": "Alice",
    ...     "order": {"items": ["Apple", "Orange"], "costs": [0.50, 1.25]},
    ...     "credit card": "5555-1234-1234-1234",
    ... }
    >>> assoc_in(purchase, ["order", "costs"], [0.25, 1.00])  # doctest: +SKIP
    {'credit card': '5555-1234-1234-1234',
     'name': 'Alice',
     'order': {'costs': [0.25, 1.00], 'items': ['Apple', 'Orange']}}
    c                     S N )xr@   s    r   <lambda>zassoc_in.<locals>.<lambda>  s     r   )r   )r&   r0   r@   r   s     ` r   r   r      s!     Qooooug>>>r   c                 ^   t          |          }t          |          } |            x}}|                    |            |D ]C}	|| v r(| |         }  |            }
|
                    |            n |            x} }
|
x||<   }|	}D|| v r || |                   ||<   n ||          ||<   |S )a  Update value in a (potentially) nested dictionary

    inputs:
    d - dictionary on which to operate
    keys - list or tuple giving the location of the value to be changed in d
    func - function to operate on that value

    If keys == [k0,..,kX] and d[k0]..[kX] == v, update_in returns a copy of the
    original dictionary with v replaced by func(v), but does not mutate the
    original dictionary.

    If k0 is not a key in d, update_in creates nested dictionaries to the depth
    specified by the keys, with the innermost value set to func(default).

    >>> inc = lambda x: x + 1
    >>> update_in({"a": 0}, ["a"], inc)
    {'a': 1}

    >>> transaction = {
    ...     "name": "Alice",
    ...     "purchase": {"items": ["Apple", "Orange"], "costs": [0.50, 1.25]},
    ...     "credit card": "5555-1234-1234-1234",
    ... }
    >>> update_in(transaction, ["purchase", "costs"], sum)  # doctest: +SKIP
    {'credit card': '5555-1234-1234-1234',
     'name': 'Alice',
     'purchase': {'costs': 1.75, 'items': ['Apple', 'Orange']}}

    >>> # updating a value when k0 is not in d
    >>> update_in({}, [1, 2, 3], str, default="bar")
    {1: {2: {3: 'bar'}}}
    >>> update_in({1: "foo"}, [2, 3, 4], inc, 0)
    {1: 'foo', 2: {3: {4: 1}}}
    )iternextr#   )r&   r0   r*   defaultr   ksr,   r%   innerr?   dtemps              r   r   r     s    F 
dBRABIIaLLL 	 	66!AGIIELLOOOO		!A  a5Avv4!::a4==aIr   Fc                 ~    	 t          t          j        | |          S # t          t          t
          f$ r |r |cY S w xY w)a  Returns coll[i0][i1]...[iX] where [i0, i1, ..., iX]==keys.

    If coll[i0][i1]...[iX] cannot be found, returns ``default``, unless
    ``no_default`` is specified, then it raises KeyError or IndexError.

    ``get_in`` is a generalization of ``operator.getitem`` for nested data
    structures such as dictionaries and lists.

    >>> transaction = {
    ...     "name": "Alice",
    ...     "purchase": {"items": ["Apple", "Orange"], "costs": [0.50, 1.25]},
    ...     "credit card": "5555-1234-1234-1234",
    ... }
    >>> get_in(["purchase", "items", 0], transaction)
    'Apple'
    >>> get_in(["name"], transaction)
    'Alice'
    >>> get_in(["purchase", "total"], transaction)
    >>> get_in(["purchase", "items", "apple"], transaction)
    >>> get_in(["purchase", "items", 10], transaction)
    >>> get_in(["purchase", "total"], transaction, 0)
    0
    >>> get_in(["y"], {}, no_default=True)
    Traceback (most recent call last):
        ...
    KeyError: 'y'

    See Also:
        itertoolz.get
        operator.getitem
    )r   operatorgetitemKeyError
IndexErrorr   )r0   collrO   
no_defaults       r   r   r   ?  sS    @h&d333j),    	s    <<c                      t           t                    r3t                     dk    r d           fdS  rt          j          S d S t          j                   S )Nr    r   c                     |          fS rH   rI   )rJ   indexs    r   rK   zgetter.<locals>.<lambda>k  s    ah[ r   c                     dS )NrI   rI   )rJ   s    r   rK   zgetter.<locals>.<lambda>o  s    R r   )r"   listr!   rT   
itemgetter)r\   s   `r   getterr`   g  sk    % 	*u::??!HE((((( 	 &..<"5)))r   c                     t          |           st          |           } t          j        d           }|D ]} | | |                   |           i }|                                D ]\  }}|j        ||<   |S )a  Group a collection by a key function

    >>> names = ["Alice", "Bob", "Charlie", "Dan", "Edith", "Frank"]
    >>> groupby(len, names)  # doctest: +SKIP
    {3: ['Bob', 'Dan'], 5: ['Alice', 'Edith', 'Frank'], 7: ['Charlie']}

    >>> iseven = lambda x: x % 2 == 0
    >>> groupby(iseven, [1, 2, 3, 4, 5, 6, 7, 8])  # doctest: +SKIP
    {False: [1, 3, 5, 7], True: [2, 4, 6, 8]}

    Non-callable keys imply grouping on a member.

    >>> groupby(
    ...     "gender",
    ...     [
    ...         {"name": "Alice", "gender": "F"},
    ...         {"name": "Bob", "gender": "M"},
    ...         {"name": "Charlie", "gender": "M"},
    ...     ],
    ... )  # doctest:+SKIP
    {'F': [{'gender': 'F', 'name': 'Alice'}],
     'M': [{'gender': 'M', 'name': 'Bob'},
           {'gender': 'M', 'name': 'Charlie'}]}

    Not to be confused with ``itertools.groupby``

    See Also:
        countby
    c                      g j         S rH   )r)   rI   r   r   rK   zgroupby.<locals>.<lambda>  s    	 r   )callabler`   collectionsdefaultdictr(   __self__)r?   seqr&   r=   r%   r,   r-   s          r   groupbyrh   t  s    < C== Skk 1 122A  ##d))T	B		  1
1Ir   c                 :    t          t          |                     S )zBThe first element in a sequence

    >>> first("ABC")
    'A'
    )rN   rM   )rg   s    r   firstrj     s     S		??r   )NF)rd   rT   collections.abcr   	functoolsr   __all__r   r   r   r   r   r   r	   r
   r   r   r   r   r   r   r   r`   rh   rj   rI   r   r   <module>rn      s        # # # # # #        "    0) ) ): !      !      "      %)    ( %)    ( &*    0 "&       : &* ? ? ? ?  &*4 8 8 8 8v% % % %P
* 
* 
*& & &R    r   