a
    h%                     @   s   d dl Z d dlZd dlmZ d dlmZmZmZ d dlm	Z	m
Z
mZ d dlmZmZmZmZ d dlmZ g dZedd	G d
d dZG dd de jZG dd de jZdS )    N)	dataclass)AnyOptionalUnion)MetadataMetadataIndexStorageMeta)LoadPlanLoadPlannerSavePlanSavePlanner)Future)WriteResultStorageWriterStorageReaderT)frozenc                   @   s&   e Zd ZU eed< eed< eed< dS )r   indexZsize_in_bytesZstorage_dataN)__name__
__module____qualname__r   __annotations__intr    r   r   R/var/www/auris/lib/python3.9/site-packages/torch/distributed/checkpoint/storage.pyr      s   
r   c                   @   s   e Zd ZdZejdeeej	df ddddZ
ejeddddZejeed	d
dZejee ee dddZejeeeee  dddZejeeee  ddddZeejeeej	f edddZee dddZdS )r   a8  
    Interface used by ``save_state_dict`` to write to storage.

    One StorageWriter instance acts as both the coordinator and the follower
    in a distributed checkpoint. As part of initialization, each instance
    is told its role.

    A subclass should expect the following sequence of calls.

    0) (all ranks) set checkpoint_id if users pass a valid checkpoint_id.
    1) (all ranks) set_up_storage_writer()
    2) (all ranks) prepare_local_plan()
    3) (coordinator) prepare_global_plan()
    4) (all ranks) write_data()
    5) (coordinator) finish()
    Ncheckpoint_idreturnc                 C   s   dS )a  
        Calls to indicates a brand new checkpoint write is going to happen.
        A checkpoint_id may be present if users set the checkpoint_id for
        this checkpoint write. The meaning of the checkpiont_id is
        storage-dependent. It can be a path to a folder/file or a key for
        a key-value storage.

        Args:
            checkpoint_id (Union[str, os.PathLike, None]):
                The ID of this checkpoint instance. The meaning of the checkpoint_id
                depends on the storage. It can be a path to a folder or to a file.
                It can also be a key if the storage is a key-value store.
                (Default: ``None``)
        Nr   selfr   r   r   r   reset-   s    zStorageWriter.reset)is_coordinatorr   c                 C   s   dS )z
        Initialize this instance.

        Args:
            is_coordinator (bool): Whether this instance is responsible for coordinating
              the checkpoint.
        Nr   )r   r    r   r   r   set_up_storage_writer?   s    z#StorageWriter.set_up_storage_writerplanr   c                 C   s   dS )a  
        Perform storage-specific local planning.

        While this method can produce a completely different plan, the recommended
        way is to store storage specific data in SavePlan::storage_data.

        Args:
            plan (SavePlan): The local plan from the ``SavePlanner`` in use.

        Returns:
            A transformed ``SavePlan`` after storage local planning
        Nr   r   r#   r   r   r   prepare_local_planI   s    z StorageWriter.prepare_local_planplansr   c                 C   s   dS )a  
        Perform centralized planning of storage.

        This method is only called on the coordinator instance.

        While this method can produce a completely different plan, the preferred
        way is to store storage specific data in SavePlan::storage_data.

        Args:
            plans: A list of ``SavePlan`` instances, one for each rank.

        Returns:
            A list of transformed ``SavePlan`` after storage global planning
        Nr   r   r'   r   r   r   prepare_global_planX   s    z!StorageWriter.prepare_global_planr#   plannerr   c                 C   s   dS )a  
        Write all items from ``plan`` using ``planner`` to resolve the data.

        A subclass should call ``SavePlanner::resolve_data`` on each item
        from the plan to get access to the underlying object to write.

        Subclasses should lazily call `resolve_data` as it can allocate memory.
        In case of tensors, make following assumptions:

        - They might be on any device, including not matching the one on ``WriteItem::tensor_data``
        - They might be views or not contiguous. Only the projection needs to be saved.

        Args:
            plan (SavePlan): The save plan to execute.
            planner (SavePlanner): Planner object to be used to resolve items to data.

        Returns:
            A future that completes to a list of WriteResult
        Nr   r   r#   r+   r   r   r   
write_datai   s    zStorageWriter.write_data)metadataresultsr   c                 C   s   dS )a  
        Write the metadata and marks the current checkpoint as successful.

        The actual format/schema used for serializing `metadata` is an
        implementation detail. The only requirement is that it's recoverable
        in to the same object graph.

        Args:
            metadata (Metadata): metadata for the new checkpoint
            results: A list of WriteResults from all ranks.

        Returns:
            None
        Nr   )r   r.   r/   r   r   r   finish   s    zStorageWriter.finishc                 C   s   dS z
        Check if the given checkpoint_id is supported by the storage. This allow
        us to enable automatic storage selection.
        Nr   clsr   r   r   r   validate_checkpoint_id   s    z$StorageWriter.validate_checkpoint_idr   c                 C   s   dS )a=  
        Return the storage-specific metadata. This is used to store additional information
        in a checkpoint that can be useful for providing request-level observability. StorageMeta
        is passed to the ``SavePlanner`` during save calls. Returns None by default.

        TODO: provide an example
        Nr   r   r   r   r   storage_meta   s    zStorageWriter.storage_meta)N)r   r   r   __doc__abcabstractmethodr   strosPathLiker   boolr!   r   r%   listr)   r   r   r   r-   r   r0   classmethodr4   r   r   r7   r   r   r   r   r      s&    	
r   c                   @   s   e Zd ZdZejdeeej	df ddddZ
ejedddZejeedd	d
dZejeedddZejee ee dddZejeeed dddZeejeeej	f edddZdS )r   aV  
    Interface used by ``load_state_dict`` to read from storage.

    One StorageReader instance acts as both the coordinator and the follower
    in a distributed checkpoint. As part of initialization, each instance
    is told its role.

    A subclass should expected the following sequence of calls by ``load_state_dict``:

    0) (all ranks) set checkpoint_id if users pass a valid checkpoint_id.
    1) (all ranks) read_metadata()
    2) (all ranks) set_up_storage_reader()
    3) (all ranks) prepare_local_plan()
    4) (coordinator) prepare_global_plan()
    5) (all ranks) read_data()
    Nr   c                 C   s   dS )a  
        Calls to indicates a brand new checkpoint read is going to happen.
        A checkpoint_id may be present if users set the checkpoint_id for
        this checkpoint read. The meaning of the checkpiont_id is
        storage-dependent. It can be a path to a folder/file or a key for
        a key-value storage.

        Args:
            checkpoint_id (Union[str, os.PathLike, None]):
                The ID of this checkpoint instance. The meaning of the checkpoint_id
                depends on the storage. It can be a path to a folder or to a file.
                It can also be a key if the storage is more like a key-value store.
                (Default: ``None``)
        Nr   r   r   r   r   r      s    zStorageReader.resetr5   c                 C   s   dS )z
        Read the checkpoint metadata.

        Returns:
            The metadata object associated with the checkpoint being loaded.

        Nr   r6   r   r   r   read_metadata   s    zStorageReader.read_metadata)r.   r    r   c                 C   s   dS )z
        Initialize this instance.

        Args:
            metadata (Metadata): The metadata schema to use.
            is_coordinator (bool): Whether this instance is responsible for coordinating
              the checkpoint.
        Nr   )r   r.   r    r   r   r   set_up_storage_reader   s    z#StorageReader.set_up_storage_readerr"   c                 C   s   dS )a  
        Perform storage-specific local planning.

        While this method can produce a completely different plan, the recommended
        way is to store storage specific data in LoadPlan::storage_data.

        Args:
            plan (LoadPlan): The local plan from the ``LoadPlan`` in use.

        Returns:
            A transformed ``LoadPlan`` after storage local planning
        Nr   r$   r   r   r   r%      s    z StorageReader.prepare_local_planr&   c                 C   s   dS )a  
        Perform centralized planning of storage loading.

        This method is only called on the coordinator instance.

        While this method can produce a completely different plan, the preferred
        way is to store storage specific data in LoadPlan::storage_data.

        Args:
            plans: A list of ``LoadPlan`` instances, one for each rank.

        Returns:
            A list of transformed ``LoadPlan`` after storage global planning
        Nr   r(   r   r   r   r)      s    z!StorageReader.prepare_global_planr*   c                 C   s   dS )a  
        Read all items from ``plan`` using ``planner`` to resolve the data.

        A subclass should call ``LoadPlanner::load_bytes`` to deserialize a BytesIO
        object into the right place.

        A subclass should call ``LoadPlanner::resolve_tensor`` to get access to the
        tensors that in should load data into.

        It's the StorageLayer responsibility to properly schedule any cross device copies
        required.

        Args:
            plan (LoadPlan): The local plan to execute on
            planner (LoadPlanner): The planner object to use to resolve items.

        Returns:
            A future that completes once all reads are finished.
        Nr   r,   r   r   r   	read_data   s    zStorageReader.read_datac                 C   s   dS r1   r   r2   r   r   r   r4     s    z$StorageReader.validate_checkpoint_id)N)r   r   r   r8   r9   r:   r   r;   r<   r=   r   r   rA   r>   rB   r	   r%   r?   r)   r
   r   rC   r@   r4   r   r   r   r   r      s     	
r   )r9   r<   Zdataclassesr   typingr   r   r   Z%torch.distributed.checkpoint.metadatar   r   r   Z$torch.distributed.checkpoint.plannerr	   r
   r   r   Ztorch.futuresr   __all__r   ABCr   r   r   r   r   r   <module>   s    