§
    &`ƒiß  ã                   ól   — d dl Z d dlmZmZ d dlmZmZmZ d dlm	Z	 e	 G d„ de¬¦  «        ¦   «         Z
dS )é    N)ÚABCMetaÚabstractmethod)ÚAnyÚDictÚOptional)ÚDeveloperAPIc                   óD  — e Zd ZdZeedefd„¦   «         ¦   «         Zeededdfd„¦   «         ¦   «         Z	eedde
e         defd„¦   «         ¦   «         Zeedeeef         fd	„¦   «         ¦   «         Zeed
eeef         ddfd„¦   «         ¦   «         Zedefd„¦   «         ZdS )ÚReplayBufferInterfacea“  Abstract base class for all of RLlib's replay buffers.

    Mainly defines the `add()` and `sample()` methods that every buffer class
    must implement to be usable by an Algorithm.
    Buffers may determine on all the implementation details themselves, e.g.
    whether to store single timesteps, episodes, or episode fragments or whether
    to return fixed batch sizes or per-call defined ones.
    Úreturnc                 ó   — dS )z<Returns the number of items currently stored in this buffer.N© ©Úselfs    úw/home/jaya/work/projects/VOICE-AGENT/VIET/agent-env/lib/python3.11/site-packages/ray/rllib/utils/replay_buffers/base.pyÚ__len__zReplayBufferInterface.__len__   ó   € € € ó    ÚbatchNc                 ó   — dS )z²Adds a batch of experiences or other data to this buffer.

        Args:
            batch: Batch or data to add.
            ``**kwargs``: Forward compatibility kwargs.
        Nr   )r   r   Úkwargss      r   ÚaddzReplayBufferInterface.add   r   r   Ú	num_itemsc                 ó   — dS )aD  Samples `num_items` items from this buffer.

        The exact shape of the returned data depends on the buffer's implementation.

        Args:
            num_items: Number of items to sample from this buffer.
            ``**kwargs``: Forward compatibility kwargs.

        Returns:
            A batch of items.
        Nr   )r   r   r   s      r   ÚsamplezReplayBufferInterface.sample"   r   r   c                 ó   — dS )zgReturns all local state in a dict.

        Returns:
            The serializable local state.
        Nr   r   s    r   Ú	get_statezReplayBufferInterface.get_state1   r   r   Ústatec                 ó   — dS )z½Restores all local state to the provided `state`.

        Args:
            state: The new state to set this buffer. Can be obtained by calling
                `self.get_state()`.
        Nr   )r   r   s     r   Ú	set_statezReplayBufferInterface.set_state:   r   r   c                 ó(   — t          j        ¦   «         S )zµReturns the computer's network name.

        Returns:
            The computer's networks name or an empty string, if the network
            name could not be determined.
        )ÚplatformÚnoder   s    r   Úget_hostzReplayBufferInterface.get_hostD   s   € õ Œ}‰ŒÐr   )N)Ú__name__Ú
__module__Ú__qualname__Ú__doc__r   r   Úintr   r   r   r   r   r   Ústrr   r   r#   r   r   r   r
   r
      sm  € € € € € ðð ð ØðK˜ð Kð Kð Kñ „\ñ „^ðKð Øð˜ð ¨4ð ð ð ñ „\ñ „^ðð Øðð  ¨¤ð À3ð ð ð ñ „\ñ „^ðð Øð˜4  S œ>ð ð ð ñ „\ñ „^ðð Øð˜t C¨ Hœ~ð °$ð ð ð ñ „\ñ „^ðð ð˜#ð ð ð ñ „\ðð ð r   r
   )Ú	metaclass)r!   Úabcr   r   Útypingr   r   r   Úray.util.annotationsr   r
   r   r   r   ú<module>r.      s¦   ðØ €€€Ø 'Ð 'Ð 'Ð 'Ð 'Ð 'Ð 'Ð 'Ø &Ð &Ð &Ð &Ð &Ð &Ð &Ð &Ð &Ð &à -Ð -Ð -Ð -Ð -Ð -ð ðCð Cð Cð Cð C gð Cñ Cô Cñ „ðCð Cð Cr   