o
    Ti                     @   s   d dl Z dd Zdd ZdS )    Nc           	      C   s   g }g }t |dD ],}tj|d|jdd |  }| d }|| ||||d |d d f  qtj|dd}|d d d d d | d | f }|||fS )Nr      )device)dim)rangesizetorchrandpermr   sortappendcat)	reserved_lengthhidden_statesmask	rand_listpart_hidden_stateskB_tmpB	part_mask r   f/home/ubuntu/.local/lib/python3.10/site-packages/deepspeed/runtime/data_pipeline/data_routing/utils.pybsh_decoder_gather	   s   
" 
r   c                 C   s@   t | dD ]}||d d d d f | ||| d d f< q| S )Nr   )r   r   )r   r   r   r   r   r   r   bsh_decoder_scatter   s   *r   )r   r   r   r   r   r   r   <module>   s   