o
    ۾i                     @   s	  d dl Z d dlZd dlZd dlZd dlZd dlmZ d dlm	Z	 d dl
mZmZmZmZmZ d dlmZmZmZmZ d dlmZ d dlmZ dd	 Zd
d Zdd Zdd Zdd Zdd Zdd Zee ej!ej!dd Z"eej#ej!ej!eej$ej!ej!dd Z%eej&ej!ej!eej'ej!ej!dd Z(eej)ej!ej!eej*ej!ej!dd Z+dd Z,d d! Z-eej.ej!ej/eej0ej!ej/eej.ej1ej/eej0ej1ej/d"d# Z2d$d% Z3d&d' Z4d(d) Z5d*d+ Z6d,d- Z7d.d/ Z8d0d1 Z9d2d3 Z:d4d5 Z;d6d7 Z<d8d9 Z=d:d; Z>d<d= Z?d>d? Z@d@dA ZAdBdC ZBdDdE ZCdFdG ZDdHdI ZEdJdK ZFdLdM ZGdNdO ZHdPdQ ZIdRdS ZJdTdU ZKeejLejMejMe; eejNejMejMe< eejOejMejMe7 eejPejMejMe8 eejQejMejMe9 eejRejMejMe: eejSejMeJ eejTejMeK dVdW ZUdXdY ZVeU  eV  dZd[ ZWd\d] ZXd^d_ ZYd`da ZZdbdc Z[ddde Z\ee ej1ej1ddfdgZ]ddhdiZ^ddjdkZ_dldm Z`dndo Zadpdq Zbdrds Zcdtdu Zddvdw Zedxdy Zfdzd{ Zgd|d} Zhd~d Zidd Zjej1ZkeejlekekeW eejmekekeW eejnekekeX eejoekekeX eejpekekeY eejqekekeY eej#ekeke_ eej$ekeke_ eej&ekekeZ eej'ekekeZ eej)ekeke^ eej*ekeke^ eej.ekeke` eej0ekeke` ee.ekeke` eejLekekee eejNekekef eejOekekea eejPekekeb eejQekekec eejRekeked eerekeg eejSekeh eejTekei [keejsddd Zteejsddd Zuedejsdd Zvdd Zwdd Zxdd Zyej1ej!fD ]Zzeezdew eezdex edezey qeej.ejsejseej0ejsejsee.ejsejsdd Z{dd Z|dd Z}dd Z~edZdd Zdd Zdd Zdd Zdd Zdd ZejsZkeejlekeke| eejmekeke| eejnekeke} eejoekeke} eejpekeke~ eejqekeke~ eej&ekeke eej'ekeke eejSeke eejTeke eejLekeke eejNekeke eereke [kedejedejdd Zdd Zeeejdd Zeeej!dd Zeeej1dd Zeeejsdd Zej!ej1ejsfD ]Zkeejeke q eejejMe eej/ej!eej/ej1eej/ejsdd Zeej!ej!dd Zeej!ejdd Zeej1ej1dd Zeej!ej1dd Zeej1ej!dd Zeej1ejseej!ejsdd Zeejsejsdd ZeejejddĄ ZeejejddƄ Zeej/ejeejejddȄ Zeejsddʄ Zeej!eej1eejdd̄ Zdd΄ Zeej1dσe eej!dσe dS )    N)ir)Constant)lower_builtinlower_getattr
lower_castlower_constantimpl_ret_untracked)typingtypeserrorscgutils)overload_methodviewerc                 C   s   | j rdgS g S )z;
    Return the modifier flags for integer arithmetic.
    nsw)signed)rettype r   M/home/ubuntu/.local/lib/python3.10/site-packages/numba/cpython/new_numbers.py_int_arith_flags   s   r   c                 C   \   |\}}|j \}}| ||||j}| ||||j}	|j||	t|jd}
t| ||j|
S N)flags)argscastreturn_typeaddr   r   contextbuildersigr   vavbtatbabresr   r   r   int_add_impl#      
r(   c                 C   r   r   )r   r   r   subr   r   r   r   r   r   int_sub_impl,   r)   r+   c                 C   r   r   )r   r   r   mulr   r   r   r   r   r   int_mul_impl5   r)   r-   c              
   C   s  |j |j ksJ | d}| d}t||}t||}||d|| |j|d|| d}	|j||	dd |||}
|	||}|d|
|||}|d||}|||}||N\}}| ||
| ||| W d	   n1 sw   Y  | |||
|| ||||| W d	   n1 sw   Y  W d	   n1 sw   Y  W d	   n1 sw   Y  ||||fS )
a@  
    Reference Objects/intobject.c
    xdivy = x / y;
    xmody = (long)(x - (unsigned long)xdivy * y);
    /* If the signs of x and y differ, and the remainder is non-0,
     * C89 doesn't define whether xdivy is now the floor or the
     * ceiling of the infinitely precise quotient.  We want the floor,
     * and we have it iff the remainder's sign matches y's.
     */
    if (xmody && ((y ^ xmody) < 0) /* i.e. and signs differ */) {
        xmody += y;
        --xdivy;
        assert(xmody && ((y ^ xmody) >= 0));
    }
    *p_xdivy = xdivy;
    *p_xmody = xmody;
    r      ==Tlikely<!=N)typer   alloca_once_valueand_icmp_signedminvalif_thennot_sdivsremxorif_elsestorer*   r   load)r   r   tyxyZEROONEresdivresmodis_overflowxdivyxmodyy_xor_xmody_ltzxmody_istruecondif_different_signsif_same_signsr   r   r   int_divmod_signed>   s:   

rQ   c                 C   s.   |j rt| ||||S ||||||fS )zD
    Integer divmod(x, y).  The caller must ensure that y != 0.
    )r   rQ   udivurem)r   r   rB   rC   rD   r   r   r   
int_divmodw   s   rT   c              	   C   sf  |\}}|j \}}|j}	t|	tjr|	j}	| ||||	}
| ||||	}tj||
j	dd}tj||
j	dd}|j
t||dde\}}| | j||fs\||| ||| W d    n1 sfw   Y  | t| ||	|
|\}}||| ||| W d    n1 sw   Y  W d    ||fS W d    ||fS 1 sw   Y  ||fS )NquotnameremFr1   )r   r   
isinstancer
   UniTupledtyper   r   alloca_oncer5   r?   is_scalar_zeroerror_modelfp_zero_divisionr@   rT   )r   r   r    r   zerodiv_messager!   r"   r#   r$   rB   r%   r&   rU   rX   if_zeroif_non_zeroqrr   r   r   _int_divmod_impl   s>   


re   c                 C   s0   t | |||d\}}t|||||fS )Nzinteger divmod by zero)re   r   
pack_arrayrA   r   r   r    r   rU   rX   r   r   r   int_divmod_impl   s   
rh   c                 C   s   t | |||d\}}||S )Nzinteger division by zerore   rA   rg   r   r   r   int_floordiv_impl      

rj   c                 C   s   |\}}|j \}}| ||||j}| ||||j}	t||	 | j|d W d    n1 s3w   Y  |||	}
t| ||j|
S )Nzdivision by zero)	r   r   r   r   ra   r^   r_   fdivr   r   r   r   r   int_truediv_impl   s   
rn   c                 C   s   t | |||d\}}||S )Nzinteger modulo by zerori   rg   r   r   r   int_rem_impl   rk   ro   c                 C   s&   t |tjr| jjsd|jd > S dS )Nr0   r.   F)rY   r
   Integerr^   raise_on_fp_zero_divisionbitwidth)r   r   r   r   r   _get_power_zerodiv_return   s
   rs   c                    sR   t |jd tj |jt|  fdd}| ||||}t| ||j|S )z@
    a ^ b, where a is an integer or real, and b an integer
    r   c                    s   d}| } |dk r0d}| }|dk rt  r/| dkr%r!S td| dkr/| dkr/dS nd}|}|dkr@t| t|S |dkrX|d@ rL|| 9 }|dL }| | 9 } |dksD|r^d| S |S )	Nr.   r   T&0 cannot be raised to a negative powerr0   F         ?)OverflowErrorZeroDivisionErrormathpowfloat)r%   r&   rd   invertexp
is_integertpzerodiv_returnr   r   	int_power   s4   z!int_power_impl.<locals>.int_power)rY   r   r
   rp   r   rs   compile_internalr   )r   r   r    r   r   r'   r   r~   r   int_power_impl   s   
r   c                    s  |j d j}t|tjstt|dkrt|dk }t|}|j}t|tj	t
| ||  |d |j d |}|j} fdd}	|d}
|}|dkrc|d@ rV|	|
|}
|dL }|	||}|dksM|rrnfdd}ndd }|  |t|||
f}
|
S )	zH
    a ^ b, where a is an integer or real, and b a constant integer
    r.   ru   r   c                    s   r  | |S  | |S N)r,   fmul)r%   r&   )r   r   r   r   r,     s   zstatic_power_impl.<locals>.mulc                    s0   | dkr r S t d| dkr| dkrdS | S )Nr   rt   r.   r0   )rx   r%   )r   r   r   invert_impl$  s   z&static_power_impl.<locals>.invert_implc                 S   s   d|  S )Nrv   r   r   r   r   r   r   1  s   )r   valuerY   numbersIntegralNotImplementedErrorabsr   r
   rp   rs   r   r5   r   r	   	signature)r   r   r    r   r}   r|   r   valltyr,   r'   r%   r   r   )r   r   r   r   static_power_impl   s:   


r   c                 C   "   |j dg|R  }t| ||j|S Nr3   r8   r   r   r   r   r    r   r'   r   r   r   int_slt_impl:     r   c                 C   r   Nz<=r   r   r   r   r   int_sle_impl?  r   r   c                 C   r   N>r   r   r   r   r   int_sgt_implD  r   r   c                 C   r   Nz>=r   r   r   r   r   int_sge_implI  r   r   c                 C   r   r   icmp_unsignedr   r   r   r   r   r   int_ult_implN  r   r   c                 C   r   r   r   r   r   r   r   int_ule_implS  r   r   c                 C   r   r   r   r   r   r   r   int_ugt_implX  r   r   c                 C   r   r   r   r   r   r   r   int_uge_impl]  r   r   c                 C   r   Nr/   r   r   r   r   r   int_eq_implb  r   r   c                 C   r   Nr4   r   r   r   r   r   int_ne_implg  r   r   c                        fdd}|S )Nc           
         s`   |\}}| d|t|jd}|  |t|jd}| ||}||||}	t| ||j|	S Nr3   r   r8   r   r5   r   selectr   r   
r   r   r    r   leftrightcmp_zerolt_zeroge_zeror'   opr   r   implm  s   
z%int_signed_unsigned_cmp.<locals>.implr   r   r   r   r   r   int_signed_unsigned_cmpl  s   r   c                    r   )Nc           
         s`   |\}}| d|t|jd}|  t|jd|}| ||}||||}	t| ||j|	S r   r   r   r   r   r   r     s   z%int_unsigned_signed_cmp.<locals>.implr   r   r   r   r   int_unsigned_signed_cmp  s   r   c           	      C   sH   |\}t |jd }|d||}||}||||}t| ||j|S r   )r   r5   r8   negr   r   r   )	r   r   r    r   rC   rE   ltznegatedr'   r   r   r   int_abs_impl  s   
r   c                 C      |\}t | ||j|S r   r   r   )r   r   r    r   rC   r   r   r   uint_abs_impl     r   c           	      C   sR   |j \}}|\}}| ||||j}| ||||j}|||}t| ||j|S r   )r   r   r   shlr   	r   r   r    r   valtyamttyr   amtr'   r   r   r   int_shl_impl     
r   c           	      C   sh   |j \}}|\}}| ||||j}| ||||j}|jjr&|||}n|||}t| ||j|S r   )r   r   r   r   ashrlshrr   r   r   r   r   int_shr_impl  s   
r   c                 C   R   |j \}}|\}}| ||||j}| ||||j}	|||	}
t| ||j|
S r   )r   r   r   r7   r   r   r   r    r   atbtavbvcavcbcr'   r   r   r   int_and_impl  r   r   c                 C   r   r   )r   r   r   or_r   r   r   r   r   int_or_impl  r   r   c                 C   r   r   )r   r   r   r>   r   r   r   r   r   int_xor_impl  r   r   c                 C   s:   |j \}|\}||}| ||||j}t| ||j|S r   )r   r   r   r   r   r   r   r    r   typr   r'   r   r   r   int_negate_impl  s
   
r   c                 C   0   |j \}|\}| ||||j}t| ||j|S r   r   r   r   r   r   r   r   r   int_positive_impl     r   c                 C   sR   |j \}|\}||t|jtd|jj d}| ||||j}t| ||j|S )N1   )	r   r>   r   r5   intwidthr   r   r   r   r   r   r   int_invert_impl  s
   "r   c                 C   s  |\}t |jd}t |jd}t |jd}|d||}|d||}	t||j}
|d}|d}|d}|d	}|d
}|||| || |	||
 |
| W d   n1 sew   Y  || ||	|| W d   n1 sw   Y  || |	||
 |
| W d   n1 sw   Y  || |	||
 |
| W d   n1 sw   Y  || ||
}t| ||j|S )z
    np.sign(int)
    r.   r0   r   r/   r   z.zeroz.postestz.posz.negz.exitN)r   r5   r   r8   r   r\   append_basic_blockcbranch
goto_blockr@   branchposition_at_endrA   r   r   )r   r   r    r   rC   POSNEGrE   r   cmp_pospresultbb_zero
bb_postestbb_posbb_negbb_exitr'   r   r   r   int_sign_impl  s>   






r   c                 C   s:   |j \}|\}| ||||j}||}t| ||j|S r   )r   r   r   r   r   r   r   r   r   bool_negate_impl  
   
r   c                 C   r   r   r   r   r   r   r   bool_unary_positive_impl  r   r   c                  C   s  t j} ttj| | t ttj| | t ttj| | t ttj	| | t ttj
| | t ttj| | t ttj| | t ttj| | t ttj| | t ttj| | t ttj| | t ttj| | t ttj| t ttj| t ttj| | t ttj| | t tt| | t t jD ]J} ttj| | t  ttj!| | t" ttj#| | t$ ttj%| | t& ttjt j'| t ttjt j'| t ttt j'| t tt(| t) qttjt j*t j*t+ ttj#t j*t j*t+ ttj!t j*t j*t+ ttj%t j*t j*t+ t,-t j.t j/D ]K} ttj| | t+ ttj!| | t0 ttj#| | t1 ttj%| | t2 ttjt j'| t ttjt j'| t ttt j'| t tt(| t3 qd S r   )4r
   rp   r   operatorr   r(   iaddr*   r+   isubr,   r-   imuleqr   ner   lshiftr   ilshiftrshiftr   irshiftr   r   posr   rz   r   ipownp_unsigned_domainltr   ler   gtr   ger   Floatr   r   IntegerLiteralr   	itertoolschainpy_signed_domainnp_signed_domainr   r   r   r   rB   r   r   r   _implement_integer_operators&  sV   
r  c                  C   s   t jt jfD ]@} ttj| | t ttj| | t ttj| | t	 ttj
| | t	 ttj| | t ttj| | t ttj| t qd S r   )r
   Booleanrp   r   r   r7   r   iandr   r   iorr>   r   ixorr|   r   r  r   r   r   _implement_bitwise_operatorsW  s   r  c                 C      |j | }t| ||j|S r   )faddr   r   r   r   r   r   real_add_implg     
r  c                 C   r  r   )fsubr   r   r   r   r   r   real_sub_impll  r  r  c                 C   r  r   )r   r   r   r   r   r   r   real_mul_implq  r  r  c                 C   sX   t ||d  | j|d W d    n1 sw   Y  |j| }t| ||j|S )Nr.   rl   )r   ra   r^   r_   rm   r   r   r   r   r   r   real_div_implv  s
   
r  c                 C   s   |j |j ksJ |j }|j}| d|j g}t|||t|f}t|||}|jrQd|_	t
|d}	|j\}
}}t| |	|
|\}}|	|| |	| t||}|||||f}|||fS )Nz.numba.python.remlinkonce_odrentry)r5   modulemanglerr   FunctionTypePointerTyper   get_or_insert_functionis_declarationlinkage	IRBuilderr   r   real_divmod_func_bodyr@   retr\   callrA   )r   r   rC   rD   floattyr  fnamefntyfn	fnbuilderfxfypmoddivmodquotientr   r   r   real_divmod}  s    
r3  c              
   C   s  t ||j}t ||j}t ||j}|||}|||||}||| ||| |d}	|d}
|d}|d||	}|d||	}|d||	}|j	|ddk\}}|8 |
d||}|| ||||| ||||| W d    n1 sw   Y  W d    n1 sw   Y  | |||
|	}||| W d    n1 sw   Y  W d    n1 sw   Y  ~~||}|d||	}||M tjtjd}|t|j }| tjt||}|||g}|||}|||}t|jd	}|d
||}||||}||| W d    n	1 s3w   Y  t ||$ |||}||| |||||}||| W d    n	1 sfw   Y  ||||fS )N        g       rv   r4   r3   Tr1   )r{   doubleg      ?r   )r   r\   r5   fremrm   r  r@   fcmp_unorderedfcmp_orderedr?   r   r:   r  r   rA   r
   float32float64strget_functionry   floorr	   r   r   ifnotr   )r   r   vxwxr/  pdiv	pfloordivr1  r0  rE   NZEROrF   
mod_istruewx_ltzmod_ltzif_nonzero_modif_zero_modwx_ltz_ne_mod_ltz
div_istruerealtypemaprealtypefloorfnfloordivfloordivdifffloordivincrHALFpredr   r   r   r%    sl   .


	

r%  c              	   C   s4  |\}}t j||jdd}t j||jdd}|jt ||ddc\}	}
|	( | j|d|sG|||}|||}|	|| |	|| W d    n1 sQw   Y  |
 t
| |||\}}|	|| |	|| W d    n1 sxw   Y  W d    n1 sw   Y  t |||||fS )NrU   rV   rX   Fr1   zmodulo by zero)r   r\   r5   r?   r]   r^   r_   rm   r6  r@   r3  rf   rA   )r   r   r    r   locrC   rD   rU   rX   ra   rb   rc   rd   r   r   r   real_divmod_impl  s2   	rU  c              	   C   s   |\}}t ||j}|jt ||ddQ\}}	| | j|d|s0|||}
||
| W d    n1 s:w   Y  |	 t	| |||\}}
||
| W d    n1 s[w   Y  W d    n1 sjw   Y  t
| ||j||S )NFr1   rS  )r   r\   r5   r?   r]   r^   r_   r6  r@   r3  r   r   rA   )r   r   r    r   rT  rC   rD   r'   ra   rb   rX   _r   r   r   real_mod_impl  *   
rW  c              	   C   s   |\}}t ||j}|jt ||ddQ\}}	| | j|d|s0|||}
||
| W d    n1 s:w   Y  |	 t	| |||\}
}||
| W d    n1 s[w   Y  W d    n1 sjw   Y  t
| ||j||S )NFr1   rl   )r   r\   r5   r?   r]   r^   r_   rm   r@   r3  r   r   rA   )r   r   r    r   rT  rC   rD   r'   ra   rb   rU   rV  r   r   r   real_floordiv_impl,  rX  rY  c           
      C   s^   |\}}|j }| jr| tj|}|||}n|d|jg}	||	||f}t| ||j	|S )Nzllvm.pow)
r  implement_powi_as_math_callr<  ry   rz   declare_intrinsicr5   r'  r   r   )
r   r   r    r   rC   rD   r  impr'   r+  r   r   r   real_power_impl?  s   r]  c                 C   r   r   r8  r   r   r   r   r   r   real_lt_implK  r   r_  c                 C   r   r   r^  r   r   r   r   real_le_implP  r   r`  c                 C   r   r   r^  r   r   r   r   real_gt_implU  r   ra  c                 C   r   r   r^  r   r   r   r   real_ge_implZ  r   rb  c                 C   r   r   r^  r   r   r   r   real_eq_impl_  r   rc  c                 C   r   r   )r7  r   r   r   r   r   r   real_ne_impld  r   rd  c                 C   s,   |j \}t||}| tj|}|||S r   )r   r	   r   r<  ry   fabs)r   r   r    r   rB   r   r   r   r   real_abs_impli  s   
rf  c                 C   s,   ddl m} |||d }t| ||j|S Nr   mathimpl)numba.cpythonri  negate_realr   r   )r   r   r    r   ri  r'   r   r   r   real_negate_implp  s   rl  c                 C   r   r   r   r   r   r   r   real_positive_implv  r   rm  c                 C   s~  |\}t |jd}t |jd}t |jd}t||j}|d||}	|d||}
||	{\}}| ||| W d   n1 sEw   Y  |O ||
:\}}| ||| W d   n1 shw   Y  | ||| W d   n1 sw   Y  W d   n1 sw   Y  W d   n1 sw   Y  W d   n1 sw   Y  ||}t| ||j	|S )z
    np.sign(float)
    r.   r0   r   r   r3   N)
r   r5   r   r\   r8  r?   r@   rA   r   r   )r   r   r    r   rC   r   r   rE   r   is_posis_neggt_zeronot_gt_zeror   not_lt_zeror'   r   r   r   real_sign_impl}  s6   
rs  realc                 C   $   | j |||d}|j}t| |||S Nr   )make_complexrt  r   r   r   r   r   cplxr'   r   r   r   complex_real_impl     r{  imagc                 C   ru  rv  )rx  r}  r   ry  r   r   r   complex_imag_impl  r|  r~  zcomplex.conjugatec                 C   sL   ddl m} | ||jd |d }|||j|_| }t| ||j|S rg  )	rj  ri  rx  r   rk  r}  	_getvaluer   r   )r   r   r    r   ri  zr'   r   r   r   complex_conjugate_impl  s
   r  c                 C   s   t | |||S r   )r   )r   r   r   r   r   r   r   real_real_impl  s   r  c                 C   s   t |j}t| |||S r   )r   get_null_valuer5   r   )r   r   r   r   r'   r   r   r   real_imag_impl  s   r  c                 C   s   t | ||j|d S Nr   r   r   r   r    r   r   r   r   real_conjugate_impl  s   r  c              	   C   s  |\}}|j d }|j}| j|||d}| j|||d}	| ||}
|j}| }|	 }|
 }| |d}| |d}|d|	j|}|d|	j|}|	||}|
|m\}}|! t| ||||f}| j|||d}|j|
_|j|
_W d    n1 sw   Y  |. tjdtjdi| }tt |jgd }t|||}|||||f W d    n1 sw   Y  W d    n1 sw   Y  ||}t| ||j|S )Nr   rw  r   r/   numba_cpowf
numba_cpow   )r   underlying_floatmake_helperr  _getpointerget_constantr8  rt  r}  r7   r?   complex_mul_implr
   	complex64
complex128r   r  VoidTyper5   r   r!  r'  rA   r   r   )r   r   r    r   cacbrB   ftyr%   r&   cr  papbpcTWOrE   b_real_is_twob_imag_is_zerob_is_twothen	otherwiser'   cres	func_namer*  cpowr   r   r   complex_power_impl  sH   


r  c                 C      |\}}|j d }| j|||d}| j|||d}| ||}	|j}
|j}|j}|j}||
||	_||||	_|	 }t| ||j|S Nr   rw  )r   rx  rt  r}  r  r  r   r   r   r   r    r   cxcyrB   rC   rD   r  r%   r&   r  dr'   r   r   r   complex_add_impl     
r  c                 C   r  r  )r   rx  rt  r}  r  r  r   r   r  r   r   r   complex_sub_impl  r  r  c                 C   s   |\}}|j d }| j|||d}| j|||d}| ||}	|j}
|j}|j}|j}||
|}|||}||
|}|||}||||	_||||	_|	 }t| ||j	|S )z'
    (a+bi)(c+di)=(ac-bd)+i(ad+bc)
    r   rw  )
r   rx  rt  r}  r   r  r  r  r   r   )r   r   r    r   r  r  rB   rC   rD   r  r%   r&   r  r  acbdadbcr'   r   r   r   r  ,  s"   
r  nanc                 C   (   dd }|  ||||}t| ||j|S )Nc                 S   s   | j }| j}|j }|j}|s|stdt|t|kr>|s#tttS || }|||  }t|||  | |||  | S |sEtttS || }|| | }t| j | | j | | j| | j  | S )Nzcomplex division by zero)rt  r}  rx   r   complexNAN)r%   r&   arealaimagbrealbimagratiodenomr   r   r   complex_divF  s.   

z%complex_div_impl.<locals>.complex_divr   r   r   )r   r   r    r   r  r'   r   r   r   complex_div_implE  s   r  c           	      C   sn   ddl m} |j\}|\}| j|||d}| ||}|||j|_|||j|_| }t| ||j	|S )Nr   rh  rw  )
rj  ri  r   rx  rk  rt  r}  r  r   r   )	r   r   r    r   ri  r   r   cmplxr'   r   r   r   complex_negate_imple  s   r  c                 C   r   r   r   r   r   r    r   r   r   r   r   complex_positive_implq  r   r  c                 C   r   |\}}|j d }| j|||d}| j|||d}|d|j|j}	|d|j|j}
||	|
}t| ||j|S )Nr   rw  r/   )r   rx  r8  rt  r}  r7   r   r   )r   r   r    r   r  r  r   rC   rD   reals_are_eqimags_are_eqr'   r   r   r   complex_eq_implv     
r  c                 C   r  )Nr   rw  r4   )r   rx  r7  rt  r}  r   r   r   )r   r   r    r   r  r  r   rC   rD   reals_are_neimags_are_ner'   r   r   r   complex_ne_impl  r  r  c                 C   r  )z)
    abs(z) := hypot(z.real, z.imag)
    c                 S   s   t | j| jS r   )ry   hypotrt  r}  )r  r   r   r   complex_abs  s   z%complex_abs_impl.<locals>.complex_absr  )r   r   r    r   r  r'   r   r   r   complex_abs_impl  s   r  znumber.itemc                 C   s   |d S )z;
    The no-op .item() method on booleans and numbers.
    r   r   r  r   r   r   number_item_impl  s   r  c                 C   s:   |j \}|\}| ||||j}||}t| ||j|S r   )r   r   r   r;   r   )r   r   r    r   r   r   istruer'   r   r   r   number_not_impl  r   r  c                 C   s
   |\}|S r   r   r  r   r   r   bool_as_bool  s   r  c                 C      |\}| d|t|jdS )Nr4   r   )r   r   r5   r  r   r   r   int_as_bool     r  c                 C   r  )Nr4   r4  )r7  r   r5   r  r   r   r   float_as_bool  r  r  c                 C   s^   |j \}|\}| |||}|j|j}}t|jd}	|d||	}
|d||	}||
|S )Nr4  r4   )r   rx  rt  r}  r   r5   r7  r   )r   r   r    r   r   r   r  rt  r}  zeroreal_istrueimag_istruer   r   r   complex_as_bool  s   r  c                 C   s$   |  ||j|j}| |||j|S r   )get_constant_genericliteral_typeliteral_valuer   r   r   fromtytotyr   litr   r   r   literal_int_to_number  s   r  c                 C   sX   |j |j kr|S |j |j k r||| |S |jr#||| |S ||| |S r   )rr   truncget_value_typer   sextzextr   r   r  r  r   r   r   r   integer_to_integer  s   r  c                 C   s   | || |S r   )inttoptrr  r  r   r   r   integer_to_voidptr  s   r  c                 C   s.   |  |}|j|jk r|||S |||S r   )r  rr   fpextfptruncr   r   r  r  r   r   r   r   r   float_to_float	  s   
r  c                 C   s(   |  |}|jr|||S |||S r   )r  r   sitofpuitofpr  r   r   r   integer_to_float     
r  c                 C   s(   |  |}|jr|||S |||S r   )r  r   fptosifptouir  r   r   r   float_to_integer  r  r  c                 C   s@   |  ||||j}| |jd}| ||}||_||_| S r  )r   r  r  rx  rt  r}  r  )r   r   r  r  r   rt  r}  r  r   r   r   non_complex_to_complex!  s   r  c           	      C   sX   |j }|j }| j|||d}| ||}| ||j|||_| ||j|||_| S rv  )r  rx  r   rt  r}  r  )	r   r   r  r  r   srctydsttysrcdstr   r   r   complex_to_complex,  s   r  c                 C   s   |  |||S r   )is_truer  r   r   r   any_to_boolean7  s   r  c                 C   s$   | |td}| ||tj|S )N    )r  r   IntTyper   r
   int32)r   r   r  r  r   asintr   r   r   boolean_to_any;  s   r   c                 C   s"   |  ||j|j}| ||j|S r   )r  r  r  r  r  r   r   r   literal_int_to_booleanA  s   r  c                 C   s4   |j }| |||j}| |||j}t||fS r   )r  r  rt  r}  r   literal_struct)r   r   rB   pyvalr  rt  r}  r   r   r   constant_complexN  s   r  c                 C   s&   t |tjr
t|}| |}||S r   )rY   npbool_boolr  )r   r   rB   r  r   r   r   r   constant_integerU  s   
r  c                 C   sL   t | tjtjfr"t |tjjr$| j|jjkrt	ddd }|S dS dS )z) Typing for the np scalar 'view' method. zOChanging the dtype of a 0d array is only supported if the itemsize is unchangedc                 S   s
   t | |S r   r   )scalarviewtyr   r   r   r   o  s   
zscalar_view.<locals>.implN)
rY   r
   r  rp   abstract	DTypeSpecrr   r[   r   TypingError)r	  r
  r   r   r   r   scalar_viewf  s   r  viewr   )ry   r   r  numpyr  r   llvmliter   llvmlite.irr   numba.core.imputilsr   r   r   r   r   
numba.corer	   r
   r   r   numba.core.extendingr   numba.cpython.unsafe.numbersr   r   r(   r+   r-   rQ   rT   re   divmodrp   rh   rN  	ifloordivrj   truedivitruedivrn   r1  imodro   rs   r   rz   r  r   r  r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   py_boolr   r  r  r  r  r   r   r  r  r  r  r  r  r3  r%  rU  rW  rY  r]  r_  r`  ra  rb  rc  rd  rf  rl  rm  rs  rB   r   r   r*   r   r,   r   r   Complexr{  r~  r  r  r  r  clsr  r  r  r  r{   r  r  r  r  r  r  r  r  Numberr  r  r  r  r  r  r  r;   r  r  voidptrr  r  r  r  r  r  Anyr  r   BooleanLiteralr  r  r  r  r   r   r   r   <module>   s   			9

	+=							*1l







) 










		




	




