U
    ,:%e&  ã                   @   sà   d Z ddlmZmZ ddlZejjedœdd„ƒZejjedœdd	„ƒZ	ejjed
œdd„ƒZ
ejjedœdd„ƒZejjeeef dœdd„ƒZejjee dœdd„ƒZejjee dœdd„ƒZejjedœdd„ƒZdS )z¦Module to change the configuration of libsox, which is used by I/O functions like
:py:mod:`~torchaudio.backend.sox_io_backend` and :py:mod:`~torchaudio.sox_effects`.
é    )ÚDictÚListN©Úseedc                 C   s   t jj | ¡ dS )z’Set libsox's PRNG

    Args:
        seed (int): seed value. valid range is int32.

    See Also:
        http://sox.sourceforge.net/sox.html
    N)Ú
torchaudioÚlibÚ_torchaudio_soxÚset_seedr   © r
   úY/var/www/html/Darija-Ai-API/env/lib/python3.8/site-packages/torchaudio/utils/sox_utils.pyr	   
   s    
r	   ©Ú	verbosityc                 C   s   t jj | ¡ dS )aD  Set libsox's verbosity

    Args:
        verbosity (int): Set verbosity level of libsox.

            * ``1`` failure messages
            * ``2`` warnings
            * ``3`` details of processing
            * ``4``-``6`` increasing levels of debug messages

    See Also:
        http://sox.sourceforge.net/sox.html
    N)r   r   r   Úset_verbosityr   r
   r
   r   r      s    r   ©Úbuffer_sizec                 C   s   t jj | ¡ dS )zÊSet buffer size for sox effect chain

    Args:
        buffer_size (int): Set the size in bytes of the buffers used for processing audio.

    See Also:
        http://sox.sourceforge.net/sox.html
    N)r   r   r   Úset_buffer_sizer   r
   r
   r   r   )   s    
r   ©Zuse_threadsc                 C   s   t jj | ¡ dS )a>  Set multithread option for sox effect chain

    Args:
        use_threads (bool): When ``True``, enables ``libsox``'s parallel effects channels processing.
            To use mutlithread, the underlying ``libsox`` has to be compiled with OpenMP support.

    See Also:
        http://sox.sourceforge.net/sox.html
    N)r   r   r   Úset_use_threadsr   r
   r
   r   r   6   s    r   )Úreturnc                   C   s   t tjj ¡ ƒS )zxList the available sox effect names

    Returns:
        Dict[str, str]: Mapping from ``effect name`` to ``usage``
    )Údictr   r   r   Úlist_effectsr
   r
   r
   r   r   D   s    r   c                   C   s   t jj ¡ S )zoList the supported audio formats for read

    Returns:
        List[str]: List of supported audio formats
    )r   r   r   Úlist_read_formatsr
   r
   r
   r   r   N   s    r   c                   C   s   t jj ¡ S )zpList the supported audio formats for write

    Returns:
        List[str]: List of supported audio formats
    )r   r   r   Úlist_write_formatsr
   r
   r
   r   r   X   s    r   c                   C   s   t jj ¡ S )zxGet buffer size for sox effect chain

    Returns:
        int: size in bytes of buffers used for processing audio.
    )r   r   r   Úget_buffer_sizer
   r
   r
   r   r   b   s    r   )Ú__doc__Útypingr   r   r   Ú
_extensionZfail_if_no_soxÚintr	   r   r   Úboolr   Ústrr   r   r   r   r
   r
   r
   r   Ú<module>   s$   			