o
    Y۷i                     @   s
  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mZmZ d dlmZmZmZmZmZmZ d dlmZ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 Z0d d! Z1e
ej2ej%ej3e
ej4ej%ej3e
ej2ej5ej3e
ej4ej5ej3d"d# Z6d$d% Z7d&d' Z8d(d) Z9d*d+ Z:d,d- Z;d.d/ Z<d0d1 Z=d2d3 Z>d4d5 Z?d6d7 Z@d8d9 ZAd:d; ZBd<d= ZCd>d? ZDd@dA ZEdBdC ZFdDdE ZGdFdG ZHdHdI ZIdJdK ZJdLdM ZKdNdO ZLdPdQ ZMdRdS ZNdTdU ZOe
ejPejQejQe? e
ejRejQejQe@ e
ejSejQejQe; e
ejTejQejQe< e
ejUejQejQe= e
ejVejQejQe> e
ejWejQeN e
ejXejQeO dVdW ZYdXdY ZZeY  eZ  dZd[ Z[d\d] Z\d^d_ Z]d`da Z^dbdc Z_ddde Z`e
e$ej5ej5ddfdgZaddhdiZbddjdkZcdldm Zddndo Zedpdq Zfdrds Zgdtdu Zhdvdw Zidxdy Zjdzd{ Zkd|d} Zld~d Zmdd Znej5Zoe
ejpeoeoe[ e
ejqeoeoe[ e
ejreoeoe\ e
ejseoeoe\ e
ejteoeoe] e
ejueoeoe] e
ej'eoeoec e
ej(eoeoec e
ej*eoeoe^ e
ej+eoeoe^ e
ej-eoeoeb e
ej.eoeoeb e
ej2eoeoed e
ej4eoeoed e
e2eoeoed e
ejPeoeoei e
ejReoeoej e
ejSeoeoee e
ejTeoeoef e
ejUeoeoeg e
ejVeoeoeh e
eveoek e
ejWeoel e
ejXeoem [oeejwddd Zxeejwddd Zye
dejwdd Zzdd Z{dd Z|dd Z}ej5ej%fD ]Z~ee~de{ ee~de| e
de~e} qe
ej2ejwejwe
ej4ejwejwe
e2ejwejwdd Zdd Zdd Zdd ZedZdd Zdd Zdd Zdd Zdd Zdd ZejwZoe
ejpeoeoe e
ejqeoeoe e
ejreoeoe e
ejseoeoe e
ejteoeoe e
ejueoeoe e
ej*eoeoe e
ej+eoeoe e
ejWeoe e
ejXeoe e
ejPeoeoe e
ejReoeoe e
eveoe [oe
deje
dejdd Zdd Ze
eejdd Ze
eej%dd Ze
eej5dd Ze
eejwdd Zej%ej5ejwfD ]Zoe
ejeoe q&e
ejejQe eej3ej%eej3ej5eej3ejwdd Zeej%ej%dd Zeej%ejdd Zeej5ej5dd Zeej%ej5dd Zeej5ej%dd Zeej5ejweej%ejwdd Zeejwejwdd ZeejejddĄ ZeejejddƄ Zeej3ejeejejddȄ Zeejwddʄ Zeej%eej5eejdd̄ Zdd΄ Zeej5dσe eej%dσe dS )    N)ir)Constant)lower_builtinlower_getattrlower_getattr_generic
lower_castlower_constantimpl_ret_borrowedimpl_ret_untracked)typingtypesutilserrorscgutilsoptional)	intrinsicoverload_methodviewerc                 C   s   | j rdgS g S )z;
    Return the modifier flags for integer arithmetic.
    nsw)signed)rettype r   O/home/ubuntu/vllm_env/lib/python3.10/site-packages/numba/cpython/old_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.   r0   c                 C   r   r   )r   r   r    mulr   r
   r"   r   r   r   int_mul_impl5   r.   r2   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:   

rV   c                 C   s.   |j rt| ||||S ||||||fS )zD
    Integer divmod(x, y).  The caller must ensure that y != 0.
    )r   rV   udivurem)r#   r$   rG   rH   rI   r   r   r   
int_divmodw   s   rY   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remFr6   )r   r    
isinstancer   UniTupledtyper   r   alloca_oncer:   rD   is_scalar_zeroerror_modelfp_zero_divisionrE   rY   )r#   r$   r%   r   zerodiv_messager&   r'   r(   r)   rG   r*   r+   rZ   r]   if_zeroif_non_zeroqrr   r   r   _int_divmod_impl   s>   


rj   c                 C   s0   t | |||d\}}t|||||fS )Nzinteger divmod by zero)rj   r   
pack_arrayrF   r#   r$   r%   r   rZ   r]   r   r   r   int_divmod_impl   s   
rm   c                 C   s   t | |||d\}}||S )Nzinteger division by zerorj   rF   rl   r   r   r   int_floordiv_impl      

ro   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   rf   rc   rd   fdivr
   r"   r   r   r   int_truediv_impl   s   
rs   c                 C   s   t | |||d\}}||S )Nzinteger modulo by zerorn   rl   r   r   r   int_rem_impl   rp   rt   c                 C   s&   t |tjr| jjsd|jd > S dS )Nr5   r3   F)r^   r   Integerrc   raise_on_fp_zero_divisionbitwidth)r#   r    r   r   r   _get_power_zerodiv_return   s
   rx   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 )	Nr3   r   T&0 cannot be raised to a negative powerr5   F         ?)OverflowErrorZeroDivisionErrormathpowfloat)r*   r+   ri   invertexp
is_integertpzerodiv_returnr   r   	int_power   s4   z!int_power_impl.<locals>.int_power)r^   r   r   ru   r    rx   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
    r3   rz   r   c                    s   r  | |S  | |S N)r1   fmul)r*   r+   )r$   r   r   r   r1     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   ry   r3   r5   )r}   r*   )r   r   r   invert_impl$  s   z&static_power_impl.<locals>.invert_implc                 S   s   d|  S )Nr{   r   r   r   r   r   r   1  s   )r   valuer^   numbersIntegralNotImplementedErrorabsr    r   ru   rx   r   r:   r   r   	signature)r#   r$   r%   r   r   r   r   valltyr1   r,   r*   r   r   )r$   r   r   r   static_power_impl   s:   


r   c                 C   "   |j dg|R  }t| ||j|S Nr8   r=   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   Nr4   r   r   r   r   r   int_eq_implb  r   r   c                 C   r   Nr9   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 Nr8   r   r=   r   r:   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   r:   r=   negr   r
   r    )	r#   r$   r%   r   rH   rJ   ltznegatedr,   r   r   r   int_abs_impl  s   
r   c                 C      |\}t | ||j|S r   r
   r    )r#   r$   r%   r   rH   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    r<   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    rC   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   rC   r   r:   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)
    r3   r5   r   r4   r   z.zeroz.postestz.posz.negz.exitN)r   r:   r   r=   r   ra   append_basic_blockcbranch
goto_blockrE   branchposition_at_endrF   r
   r    )r#   r$   r%   r   rH   POSNEGrJ   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 j,D ]K} 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(| t0 qd S r   )1r   ru   r   operatorr!   r-   iaddr/   r0   isubr1   r2   imuleqr   ner   lshiftr   ilshiftrshiftr   irshiftr   r   posr   r   r   ipowunsigned_domainltr   ler   gtr   ger   Floatr   r   IntegerLiteralr   signed_domainr   r   r   r   rG   r   r   r   _implement_integer_operators&  sR   

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   Booleanru   r   r   r<   r   iandr   r   iorrC   r   ixorr   r   r  r   r   r   _implement_bitwise_operatorsV  s   r  c                 C      |j | }t| ||j|S r   )faddr
   r    r   r   r   r   real_add_implf     
r  c                 C   r  r   )fsubr
   r    r   r   r   r   real_sub_implk  r  r  c                 C   r  r   )r   r
   r    r   r   r   r   real_mul_implp  r  r  c                 C   sX   t ||d  | j|d W d    n1 sw   Y  |j| }t| ||j|S )Nr3   rq   )r   rf   rc   rd   rr   r
   r    r   r   r   r   real_div_implu  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)r:   modulemanglerr   FunctionTypePointerTyper   get_or_insert_functionis_declarationlinkage	IRBuilderr   r   real_divmod_func_bodyrE   retra   callrF   )r#   r$   rH   rI   floattyr  fnamefntyfn	fnbuilderfxfypmoddivmodquotientr   r   r   real_divmod|  s    
r5  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       r{   r9   r8   Tr6   )r   doubleg      ?r   )r   ra   r:   fremrr   r  rE   fcmp_unorderedfcmp_orderedrD   r   r?   r  r   rF   r   float32float64strget_functionr~   floorr   r   r   ifnotr   )r#   r$   vxwxr1  pdiv	pfloordivr3  r2  rJ   NZEROrK   
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 )NrZ   r[   r]   Fr6   zmodulo by zero)r   ra   r:   rD   rb   rc   rd   rr   r8  rE   r5  rk   rF   )r#   r$   r%   r   locrH   rI   rZ   r]   rf   rg   rh   ri   r   r   r   real_divmod_impl  s2   	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 )NFr6   rU  )r   ra   r:   rD   rb   rc   rd   r8  rE   r5  r
   r    rF   )r#   r$   r%   r   rV  rH   rI   r,   rf   rg   r]   _r   r   r   real_mod_impl  *   
rY  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 )NFr6   rq   )r   ra   r:   rD   rb   rc   rd   rr   rE   r5  r
   r    rF   )r#   r$   r%   r   rV  rH   rI   r,   rf   rg   rZ   rX  r   r   r   real_floordiv_impl+  rZ  r[  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>  r~   r   declare_intrinsicr:   r)  r
   r    )
r#   r$   r%   r   rH   rI   r  impr,   r-  r   r   r   real_power_impl>  s   r_  c                 C   r   r   r:  r
   r    r   r   r   r   real_lt_implJ  r   ra  c                 C   r   r   r`  r   r   r   r   real_le_implO  r   rb  c                 C   r   r   r`  r   r   r   r   real_gt_implT  r   rc  c                 C   r   r   r`  r   r   r   r   real_ge_implY  r   rd  c                 C   r   r   r`  r   r   r   r   real_eq_impl^  r   re  c                 C   r   r   )r9  r
   r    r   r   r   r   real_ne_implc  r   rf  c                 C   s,   |j \}t||}| tj|}|||S r   )r   r   r   r>  r~   fabs)r#   r$   r%   r   rG   r   r   r   r   real_abs_implh  s   
rh  c                 C   s,   ddl m} |||d }t| ||j|S Nr   mathimpl)numba.cpythonrk  negate_realr
   r    )r#   r$   r%   r   rk  r,   r   r   r   real_negate_implo  s   rn  c                 C   r   r   r   r   r   r   r   real_positive_implu  r   ro  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)
    r3   r5   r   r   r8   N)
r   r:   r   ra   r:  rD   rE   rF   r
   r    )r#   r$   r%   r   rH   r   r   rJ   r   is_posis_neggt_zeronot_gt_zeror   not_lt_zeror,   r   r   r   real_sign_impl|  s6   
ru  realc                 C   $   | j |||d}|j}t| |||S Nr   )make_complexrv  r
   r#   r$   r   r   cplxr,   r   r   r   complex_real_impl     r}  imagc                 C   rw  rx  )rz  r  r
   r{  r   r   r   complex_imag_impl  r~  r  zcomplex.conjugatec                 C   sL   ddl m} | ||jd |d }|||j|_| }t| ||j|S ri  )	rl  rk  rz  r   rm  r  	_getvaluer
   r    )r#   r$   r%   r   rk  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_valuer:   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   ry  r   r4   numba_cpowf
numba_cpow   )r   underlying_floatmake_helperr  _getpointerget_constantr:  rv  r  r<   rD   complex_mul_implr   	complex64
complex128r   r!  VoidTyper:   r   r#  r)  rF   r
   r    )r#   r$   r%   r   cacbrG   ftyr*   r+   cr  papbpcTWOrJ   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   ry  )r   rz  rv  r  r  r  r
   r    r#   r$   r%   r   cxcyrG   rH   rI   r  r*   r+   r  dr,   r   r   r   complex_add_impl     
r  c                 C   r  r  )r   rz  rv  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   ry  )
r   rz  rv  r  r   r  r  r  r
   r    )r#   r$   r%   r   r  r  rG   rH   rI   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)rv  r  r}   r   complexNAN)r*   r+   arealaimagbrealbimagratiodenomr   r   r   complex_divE  s.   

z%complex_div_impl.<locals>.complex_divr   r
   r    )r#   r$   r%   r   r  r,   r   r   r   complex_div_implD  s   r  c           	      C   sn   ddl m} |j\}|\}| j|||d}| ||}|||j|_|||j|_| }t| ||j	|S )Nr   rj  ry  )
rl  rk  r   rz  rm  rv  r  r  r
   r    )	r#   r$   r%   r   rk  r   r   cmplxr,   r   r   r   complex_negate_impld  s   r  c                 C   r   r   r   r#   r$   r%   r   r   r   r   r   complex_positive_implp  r   r  c                 C   r   |\}}|j d }| j|||d}| j|||d}|d|j|j}	|d|j|j}
||	|
}t| ||j|S )Nr   ry  r4   )r   rz  r:  rv  r  r<   r
   r    )r#   r$   r%   r   r  r  r   rH   rI   reals_are_eqimags_are_eqr,   r   r   r   complex_eq_implu     
r  c                 C   r  )Nr   ry  r9   )r   rz  r9  rv  r  r   r
   r    )r#   r$   r%   r   r  r  r   rH   rI   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   )r~   hypotrv  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 )Nr9   r   )r   r   r:   r  r   r   r   int_as_bool     r  c                 C   r  )Nr9   r6  )r9  r   r:   r  r   r   r   float_as_bool  r  r  c                 C   s^   |j \}|\}| |||}|j|j}}t|jd}	|d||	}
|d||	}||
|S )Nr6  r9   )r   rz  rv  r  r   r:   r9  r   )r#   r$   r%   r   r   r   r  rv  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   )rw   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  rw   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  rz  rv  r  r  )r#   r$   r  r  r   rv  r  r  r   r   r   non_complex_to_complex  s   r  c           	      C   sX   |j }|j }| j|||d}| ||}| ||j|||_| ||j|||_| S rx  )r  rz  r   rv  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_boolean5  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_any9  s   r  c                 C   s"   |  ||j|j}| ||j|S r   )r  r  r  r  r  r   r   r   literal_int_to_boolean?  s   r  c                 C   s4   |j }| |||j}| |||j}t||fS r   )r  r  rv  r  r   literal_struct)r#   r$   rG   pyvalr  rv  r  r   r   r   constant_complexL  s   r  c                 C   s&   t |tjr
t|}| |}||S r   )r^   npbool_boolr  )r#   r$   rG   r  r   r   r   r   constant_integerS  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   m  s   
zscalar_view.<locals>.implN)
r^   r   r  ru   abstract	DTypeSpecrw   r`   r   TypingError)r  r  r   r   r   r   scalar_viewd  s   r  viewr   )r~   r   numpyr  r   llvmliter   llvmlite.irr   numba.core.imputilsr   r   r   r   r   r	   r
   
numba.corer   r   r   r   r   r   numba.core.extendingr   r   numba.cpython.unsafe.numbersr   r   r-   r0   r2   rV   rY   rj   divmodru   rm   rP  	ifloordivro   truedivitruedivrs   r3  imodrt   rx   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   r   r   booleanr   r  r  r	  r
  r   r  r  r  r  r  r  r  r5  r'  rW  rY  r[  r_  ra  rb  rc  rd  re  rf  rh  rn  ro  ru  rG   r!   r   r/   r   r1   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

	+=							*0l







) 



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

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