
    sg                         d dl mZ d dlmZmZmZ d dlmZ d dlm	Z	 ddgZ
 G d de      Z G d d	e	      Z ed
       G d de             Zy)    )IntEnum)DictSizedTuple)functional_datapipe)IterDataPipeSHARDING_PRIORITIESShardingFilterIterDataPipec                       e Zd ZdZdZdZy)r	            N)__name__
__module____qualname__DEFAULTDISTRIBUTEDMULTIPROCESSING     [/var/www/html/venv/lib/python3.12/site-packages/torch/utils/data/datapipes/iter/sharding.pyr	   r	      s    GKOr   c                        e Zd ZdededefdZy)_ShardingIterDataPipenum_of_instancesinstance_idsharding_groupc                     t         N)NotImplementedErrorselfr   r   r   s       r   apply_shardingz$_ShardingIterDataPipe.apply_sharding   s
     "!r   N)r   r   r   intr	   r"   r   r   r   r   r      s#    "" " ,	"r   r   sharding_filterc                   N    e Zd ZdZd	defdZej                  fdZd Z	d Z
d Zy)
r
   ao  
    Wrapper that allows DataPipe to be sharded (functional name: ``sharding_filter``).

    After ``apply_sharding`` is called, each instance of the DataPipe (on different workers) will have every `n`-th element of the
    original DataPipe, where `n` equals to the number of instances.

    Args:
        source_datapipe: Iterable DataPipe that will be sharded
    Nsource_datapipec                 j    || _         || _        i | _        d| _        d| _        | j                          y Nr   r   )r&   sharding_group_filtergroupsr   r   _update_num_of_instances)r!   r&   r)   s      r   __init__z#ShardingFilterIterDataPipe.__init__+   s5    .%:"24 !%%'r   c                 `   ||k\  rt        d| d| d      |t        j                  k(  r<t        | j                        rNt        j                  | j                  vr2t        d      t        j                  | j                  v rt        d      ||f| j                  |<   | j                          y )Nzinstance_id(z*) should be smaller than num_of_instances()z8ShardingFilter cannot mix DEFAULT and non DEFAULT groups)
ValueErrorr	   r   lenr*   RuntimeErrorr+   r    s       r   r"   z)ShardingFilterIterDataPipe.apply_sharding3   s     **{m+UVfUgghi  08884;;$7$?$?t{{$R"N  #**dkk9"N  (8&EN#%%'r   c                    g }t        | j                  j                               D ]<  }| j                  || j                  k(  s|j	                  | j                  |          > |j                          d| _        d| _        |D ]<  \  }}| xj                  | j                  |z  z  c_        | xj                  |z  c_        > y r(   )sortedr*   keysr)   appendreverser   r   )r!   sorted_sharding_groupskeygroup_num_of_instancesgroup_instance_ids        r   r+   z3ShardingFilterIterDataPipe._update_num_of_instancesG   s    !#$++**,- 	@C))1SD<V<V5V&--dkk#.>?	@ 	&&( !9O 	<5"$5 5 58I II!!%;;!	<r   c              #      K   t        | j                        D ]&  \  }}|| j                  z  | j                  k(  s#| ( y wr   )	enumerater&   r   r   )r!   iitems      r   __iter__z#ShardingFilterIterDataPipe.__iter__V   sB      !5!56 	GAt4(((D,<,<<
	s
   8AAc                 (   t        | j                  t              rXt        | j                        | j                  z  | j
                  t        | j                        | j                  z  k  rdz   S dz   S t        t        |       j                   d      )Nr   r   z# instance doesn't have valid length)	
isinstancer&   r   r0   r   r   	TypeErrortyper   )r!   s    r   __len__z"ShardingFilterIterDataPipe.__len__[   s    d**E2t++,0E0EE $$s4+?+?'@4CXCX'XX  
   4:..//RSTTr   r   )r   r   r   __doc__r   r,   r	   r   r"   r+   r?   rD   r   r   r   r
   r
      s4    ( ( =P<W<W((<
	Ur   N)enumr   typingr   r   r   %torch.utils.data.datapipes._decoratorr   #torch.utils.data.datapipes.datapiper   __all__r	   r   r
   r   r   r   <module>rK      sc     % % E <  ' "L " &'DU!6 DU (DUr   