o
    ߗiJ                     @   s|  d Z ddlmZ ddlmZmZmZ ddlZddlm	Z
 ddlmZ g d	Zee
eedf Zd
efddZd
efddZd
efddZd
efddZd
efddZd
efddZd
efddZd
efddZd
efddZd0ded
dfddZG d d! d!ZG d"d# d#Ze Zead0ded
efd$d%ZG d&d' d'eZ d(ed
efd)d(Z!d
efd*d+Z"ded
dfd,d-Z#d
efd.d/Z$dS )1zj
This package implements abstractions found in ``torch.cuda``
to facilitate writing device-agnostic code.
    )AbstractContextManager)AnyOptionalUnionN   device   )amp)
is_availablesynchronizecurrent_devicecurrent_streamstream
set_devicedevice_countStreamStreamContextEventreturnc                   C      t jj S )z/Returns a bool indicating if CPU supports AVX2.)torch_C_cpu_is_avx2_supported r   r   P/home/ubuntu/transcripts/venv/lib/python3.10/site-packages/torch/cpu/__init__.pyr          r   c                   C   r   )z1Returns a bool indicating if CPU supports AVX512.)r   r   r   _is_avx512_supportedr   r   r   r   r   %   r   r   c                   C   r   )z6Returns a bool indicating if CPU supports AVX512_BF16.)r   r   r   _is_avx512_bf16_supportedr   r   r   r   r   *   r   r   c                   C   r   )z/Returns a bool indicating if CPU supports VNNI.)r   r   r   _is_avx512_vnni_supportedr   r   r   r   _is_vnni_supported/   s   r!   c                   C   r   )z3Returns a bool indicating if CPU supports AMX_TILE.)r   r   r   _is_amx_tile_supportedr   r   r   r   r"   5   r   r"   c                   C   r   )z3Returns a bool indicating if CPU supports AMX FP16.)r   r   r   _is_amx_fp16_supportedr   r   r   r   r#   :   r   r#   c                   C   r   )zInitializes AMX instructions.)r   r   r   	_init_amxr   r   r   r   r$   ?   r   r$   c                   C   r   )z2Returns a bool indicating if CPU supports Arm SVE.)r   r   r   _is_arm_sve_supportedr   r   r   r   r%   D   r   r%   c                   C      dS )zReturns a bool indicating if CPU is currently available.

    N.B. This function only exists to facilitate device-agnostic code

    Tr   r   r   r   r   r   I   s   r   r   c                 C   r&   )zWaits for all kernels in all streams on the CPU device to complete.

    Args:
        device (torch.device or int, optional): ignored, there's only one CPU device.

    N.B. This function only exists to facilitate device-agnostic code.
    Nr   r   r   r   r   r   R       r   c                   @   s.   e Zd ZdZd
deddfddZddd	ZdS )r   zH
    N.B. This class only exists to facilitate device-agnostic code
    priorityr   Nc                 C      d S Nr   )selfr)   r   r   r   __init__a      zStream.__init__c                 C   r*   r+   r   r,   r   r   r   r   wait_streamd   r.   zStream.wait_stream)r(   r   N)__name__
__module____qualname____doc__intr-   r0   r   r   r   r   r   \   s    r   c                   @   s<   e Zd ZdefddZddddZdddZddd	d
ZdS )r   r   c                 C   r&   )NTr   r,   r   r   r   queryi   r.   zEvent.queryNc                 C   r*   r+   r   r/   r   r   r   recordl   r.   zEvent.recordc                 C   r*   r+   r   r7   r   r   r   r   o   r.   zEvent.synchronizec                 C   r*   r+   r   r/   r   r   r   waitr   r.   z
Event.waitr+   r1   )r2   r3   r4   boolr8   r9   r   r:   r   r   r   r   r   h   s
    
r   c                 C   s   t S )zReturns the currently selected :class:`Stream` for a given device.

    Args:
        device (torch.device or int, optional): Ignored.

    N.B. This function only exists to facilitate device-agnostic code

    )_current_streamr   r   r   r   r   z   s   	r   c                   @   sH   e Zd ZU dZee ed< dd Zdd Zde	de	d	e	d
dfddZ
dS )r   zvContext-manager that selects a given stream.

    N.B. This class only exists to facilitate device-agnostic code

    
cur_streamc                 C   s   || _ t| _d S r+   )r   _default_cpu_streamprev_streamr/   r   r   r   r-      s   
zStreamContext.__init__c                 C   s    | j }|d u r	d S t| _|ad S r+   )r   r<   r?   )r,   r=   r   r   r   	__enter__   s
   zStreamContext.__enter__typevalue	tracebackr   Nc                 C   s   | j }|d u r	d S | jad S r+   )r   r?   r<   )r,   rA   rB   rC   r=   r   r   r   __exit__   s   
zStreamContext.__exit__)r2   r3   r4   r5   r   r   __annotations__r-   r@   r   rD   r   r   r   r   r      s   
 	r   r   c                 C   s   t | S )zWrapper around the Context-manager StreamContext that
    selects a given stream.

    N.B. This function only exists to facilitate device-agnostic code
    )r   )r   r   r   r   r      s   c                   C   r&   )zReturns number of CPU devices (not cores). Always 1.

    N.B. This function only exists to facilitate device-agnostic code
    r	   r   r   r   r   r   r         r   c                 C   r&   )zzSets the current device, in CPU we do nothing.

    N.B. This function only exists to facilitate device-agnostic code
    Nr   r   r   r   r   r      r'   r   c                   C   r&   )zyReturns current device for cpu. Always 'cpu'.

    N.B. This function only exists to facilitate device-agnostic code
    cpur   r   r   r   r   r      rF   r   r+   )%r5   
contextlibr   typingr   r   r   r    r   _devicer
   __all__strr6   	_device_tr;   r   r   r   r!   r"   r#   r$   r%   r   r   r   r   r>   r<   r   r   r   r   r   r   r   r   r   r   <module>   s8   	
	