U
    9%e
                     @  s  d dl mZ d dlZd dlZddlmZmZ ddlmZm	Z	 dd Z
e	e
d2d	d
ddZe	e
d3d	d
ddZe	e
d4d	d
ddZe	e
d5d	d
ddZe	e
d6d	d
ddZe	e
d7d	d
ddZe	e
d8d	d
ddZe	e
d9d	d
ddZe	e
d:d	d
ddZe	e
d;d	d
ddZe	e
d<d	d
d d!Ze	e
d=d	d
d"d#Ze	e
d>d	d
d$d%Ze	e
d?d	d
d&d'Ze	d@d)d*Ze	dAd+d,Ze	dBd	d-d.d/Ze	dCd	d-d0d1ZdS )D    )annotationsN   )_dtypes_impl_util)	ArrayLike
normalizerc                   s   t   fdd}|S )z>NumPy fft casts inputs to 64 bit and *returns 64-bit results*.c                   s8   |   rt jnt j}t| |}  | f||S N)Z
is_complexr   Zdefault_dtypesZcomplex_dtypeZfloat_dtyper   Zcast_if_needed)ZtensorargskwdsZtarget_dtypefunc O/var/www/html/Darija-Ai-API/env/lib/python3.8/site-packages/torch/_numpy/fft.pywrapped   s    zupcast.<locals>.wrapped)	functoolswraps)r   r   r   r   r   upcast   s    	r   r   )ac                 C  s   t jj| |||dS N)dimnorm)torchfftr   nZaxisr   r   r   r   r      s    r   c                 C  s   t jj| |||dS r   )r   r   ifftr   r   r   r   r   !   s    r   c                 C  s   t jj| |||dS r   )r   r   rfftr   r   r   r   r   '   s    r   c                 C  s   t jj| |||dS r   )r   r   irfftr   r   r   r   r   -   s    r   c                 C  s   t jj| |||dS r   )r   r   fftnr   saxesr   r   r   r   r   3   s    r   c                 C  s   t jj| |||dS r   )r   r   ifftnr    r   r   r   r#   9   s    r#   c                 C  s   t jj| |||dS r   )r   r   rfftnr    r   r   r   r$   ?   s    r$   c                 C  s   t jj| |||dS r   )r   r   irfftnr    r   r   r   r%   E   s    r%   r   c                 C  s   t jj| |||dS r   )r   r   fft2r    r   r   r   r(   K   s    r(   c                 C  s   t jj| |||dS r   )r   r   ifft2r    r   r   r   r)   Q   s    r)   c                 C  s   t jj| |||dS r   )r   r   rfft2r    r   r   r   r*   W   s    r*   c                 C  s   t jj| |||dS r   )r   r   irfft2r    r   r   r   r+   ]   s    r+   c                 C  s   t jj| |||dS r   )r   r   hfftr   r   r   r   r,   c   s    r,   c                 C  s   t jj| |||dS r   )r   r   ihfftr   r   r   r   r-   i   s    r-         ?c                 C  s   t j| |S r   )r   r   fftfreqr   dr   r   r   r/   o   s    r/   c                 C  s   t j| |S r   )r   r   rfftfreqr0   r   r   r   r2   t   s    r2   )xc                 C  s   t j| |S r   )r   r   fftshiftr3   r"   r   r   r   r4   y   s    r4   c                 C  s   t j| |S r   )r   r   	ifftshiftr5   r   r   r   r6   ~   s    r6   )Nr   N)Nr   N)Nr   N)Nr   N)NNN)NNN)NNN)NNN)Nr&   N)Nr&   N)Nr&   N)Nr&   N)Nr   N)Nr   N)r.   )r.   )N)N)
__future__r   r   r    r   r   Z_normalizationsr   r   r   r   r   r   r   r   r#   r$   r%   r(   r)   r*   r+   r,   r-   r/   r2   r4   r6   r   r   r   r   <module>   sn   