o
    i_                     @   s  d Z ddlZ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	m
Z
mZ ddlmZ ddlmZmZ ddlmZ ddlmZmZmZ ddlmZmZ ed	Zed
Zdd ZdZdZee Z dd Z!dd Z"dd Z#dd Z$dd Z%dd Z&dd Z'dd Z(dd  Z)d!d" Z*d#d$ Z+d%d& Z,d'd( Z-d)d* Z.d+d, Z/d-d. Z0d/d0 Z1d1d2 Z2d3d4 Z3G d5d6 d6eZ4ej5Z6ej7Z8G d7d8 d8eZ9G d9d: d:eZ:G d;d< d<e:Z;G d=d> d>eZ<G d?d@ d@e<Z=G dAdB dBeZ>G dCdD dDeZ?G dEdF dFeZ@G dGdH dHeZAeBdIkreC  dS dS )Jz0
Test np.datetime64 and np.timedelta64 support.
    N)jit	vectorizenjit)numpy_version)typesconfig)TypingError)TestCasetagskip_parfors_unsupported)npdatetime_helpersnumpy_supportztimedelta64[M]ztimedelta64[Y]c                 C   s   t | j}|jS N)r   
from_dtypedtypeunit)valty r   X/home/ubuntu/veenaModal/venv/lib/python3.10/site-packages/numba/tests/test_npdatetime.py
value_unit   s   r   )YM)WDhmsmsusnspsfsasc                 C   s   | | S r   r   xyr   r   r   add_usecase%      r'   c                 C   s   | | S r   r   r$   r   r   r   sub_usecase(   r(   r)   c                 C   s   | | S r   r   r$   r   r   r   mul_usecase+   r(   r*   c                 C      | | S r   r   r$   r   r   r   div_usecase.   r(   r,   c                 C   s   | | S r   r   r$   r   r   r   floordiv_usecase1   r(   r-   c                 C   s   | |kS r   r   r$   r   r   r   
eq_usecase4   r(   r.   c                 C   s   | |kS r   r   r$   r   r   r   
ne_usecase7   r(   r/   c                 C   s   | |k S r   r   r$   r   r   r   
lt_usecase:   r(   r0   c                 C   s   | |kS r   r   r$   r   r   r   
le_usecase=   r(   r1   c                 C   s   | |kS r   r   r$   r   r   r   
gt_usecase@   r(   r2   c                 C   s   | |kS r   r   r$   r   r   r   
ge_usecaseC   r(   r3   c                 C   s   | 
 S r   r   r%   r   r   r   pos_usecaseF      r5   c                 C   s   |  S r   r   r4   r   r   r   neg_usecaseI   r6   r7   c                 C      t | S r   )absr4   r   r   r   abs_usecaseL   r(   r:   c                 C   r8   r   )hashr4   r   r   r   hash_usecaseO   r(   r<   c                 C   
   t | |S r   minr$   r   r   r   min_usecaseR      
r@   c                 C   r=   r   maxr$   r   r   r   max_usecaseU   rA   rD   c                 C   r8   r   )intr4   r   r   r   int_cast_usecaseX   r(   rF   c                    s    fdd}|S )Nc                    s   |   S r   r   r4   constr   r   add_constant\   r(   z'make_add_constant.<locals>.add_constantr   )rH   rI   r   rG   r   make_add_constant[   s   rJ   c                   @   s8   e Zd ZdZdd Zdd Zdd Zdd	 Zd
d ZdS )TestModuleHelpersz?
    Test the various helpers in numba.npdatetime_helpers.
    c                    s   t j tttD ]\}} ||||f  ||||f q	tD ]} |d  d| q&td D ]
} || q= fdd}|t |t d S )N rL   c                    sH   t | D ]\}}| d | D ]} ||  || qqd S r   )	enumerate
assertTrueassertFalsegroupiabfselfr   r   check_units_groupq   s   zDTestModuleHelpers.test_can_cast_timedelta.<locals>.check_units_group)	r   can_cast_timedelta_units	itertoolsproduct
date_units
time_unitsrP   	all_unitsrO   )rX   rT   rU   r   rY   r   rV   r   test_can_cast_timedeltaf   s   z)TestModuleHelpers.test_can_cast_timedeltac                    s   t j td D ]} ||d qtD ]} d|d qtttD ]\}} ||d   ||d  q' fdd}|t |t  ddd  d	d
d  d	dd  d	dd d S )NrM      rL   c                    sR   t | D ]"\}}| d | D ]} ||d||f  ||d  qqd S )Nra   )rN   assertGreaterassertIsrQ   rV   r   r   rY      s   zFTestModuleHelpers.test_timedelta_conversion.<locals>.check_units_groupr   r      r   r      r   i`'  r   l     !3)	r   get_timedelta_conversion_factorr_   assertEqualr[   r\   r^   r]   rc   )rX   r   rT   rU   rY   r   rV   r   test_timedelta_conversion|   s   z+TestModuleHelpers.test_timedelta_conversionc                    s  t j  fdd}tttD ]	\}}||| qtttD ]	\}} || q tttD ]	\}} || q0tttD ]	\}} || q@tD ]#} |||ddf  |d|ddf  d|d qL ddd  ddd  ddd	  d
dd  dd
d  d
dd  dd
d  ddd  ddd  ddd  dd
d  ddd  dd
d  ddd  ddd d S )Nc                    s:    t  | | W d    d S 1 sw   Y  d S r   )assertRaisesRuntimeError)dt_unittd_unitrV   r   r   check_error   s   "zFTestModuleHelpers.test_datetime_timedelta_scaling.<locals>.check_errorra   rL   )rL   ra   ra   r   r   )r   rd   ra   )r   ra   rd   r   r   )r      ra   )r   ra   rn   r   )r   :	 ra   )r   ra   ro   r#   )r#        NZora   )r#   ra   rp   )r   :   )r   rq   i
  )r   rq     )r   rq   i@  )r      Y` rr   )r   rt   rs   )r   !get_datetime_timedelta_conversionr[   r\   r^   r]   r_   rg   )rX   rm   rk   rl   r   r   rV   r   test_datetime_timedelta_scaling   s:   z1TestModuleHelpers.test_datetime_timedelta_scalingc                 C   s   t j}tD ]}| |||| | |d|| | ||d| q| |ddd tttD ]\}}| |||d  q2tttD ]\}}| |||| qFd S )NrL   )	r    combine_datetime_timedelta_unitsr_   rg   r[   r\   r^   r]   rc   )rX   rW   r   rk   rl   r   r   r   %test_combine_datetime_timedelta_units   s   z7TestModuleHelpers.test_combine_datetime_timedelta_unitsc                 C   s   t j}tD ]
}| ||| qd}d}t||D ]\}}| ||| qt||D ]\}}| ||| q-t||D ]\}}| ||| | ||| q@d S )N)r   r   r   r   )	r   r   r   r   r   r    r!   r"   r#   )r   	same_kindr_   rO   r[   r\   rP   )rX   rW   uABrT   rU   r   r   r   test_same_kind   s   z TestModuleHelpers.test_same_kindN)	__name__
__module____qualname____doc__r`   rh   rv   rx   r}   r   r   r   r   rK   a   s    'rK   c                   @   s,   e Zd Zdd Zdd Zdd Zdd Zd	S )
TestMiscCompilingc                    s@    fdd}t dt dt d}|| d}|| d S )Nc                    s@   t | ddt}tddtddf}t| } || | d S )NTnopythonra   r      r   )r   r'   DTTDassertPreciseEqual)sigrW   argsexpectedrX   r   r   _check_explicit_signature   s   zPTestMiscCompiling.test_jit_explicit_signature.<locals>._check_explicit_signaturer   r   z5NPDatetime('us')(NPDatetime('ms'), NPTimedelta('us')))r   
NPDatetimeNPTimedeltarX   r   r   r   r   r   test_jit_explicit_signature   s
   z-TestMiscCompiling.test_jit_explicit_signaturec                    s<    fdd}t dt dt j}|| d}|| d S )Nc                    s0   t | gddt} |tddtd d S )NTr   r         )r   r*   r   r   )r   rW   r   r   r   r      s   zVTestMiscCompiling.test_vectorize_explicit_signature.<locals>._check_explicit_signaturer   z)NPTimedelta('s')(NPTimedelta('s'), int64))r   r   int64r   r   r   r   !test_vectorize_explicit_signature   s
   z3TestMiscCompiling.test_vectorize_explicit_signaturec                    s*    fdd}|t d |t dd d S )Nc                    <   t | }tdd|}tdd}||} ||| d S NTr      r   rJ   r   r   r   rH   pyfuncrW   r%   r   r   r   r   check   
   
z7TestMiscCompiling.test_constant_datetime.<locals>.checkz
2001-01-01NaTr   r   rX   r   r   r   r   test_constant_datetime   s   z(TestMiscCompiling.test_constant_datetimec                    s:    fdd}|t dd |t dd |t dd d S )Nc                    r   r   r   r   r   r   r   r     r   z8TestMiscCompiling.test_constant_timedelta.<locals>.checkr   r   r   )r   r   r   r   r   test_constant_timedelta  s   z)TestMiscCompiling.test_constant_timedeltaN)r~   r   r   r   r   r   r   r   r   r   r   r      s
    
r   c                   @   s   e Zd ZeddZdd Zdd Zdd Zd	d
 Zdd Z	dd Z
dd Zdd Zdd Zdd Zdd Zdd Zdd Zdd Zdd  Zd!d" Zd#S )$TestTimedeltaArithmeticTforceobjc                 C      t di | j|S Nr   r   jitargsrX   r   r   r   r   r        zTestTimedeltaArithmetic.jitc                    s(   t  fdd}|tdtdtd |tddtddtdd |tddtddtdd |tdd	tdd
tdd
 |tdtdtd |tddtdd
tdd |tddtddtdd ttf  tddtdd
 W d    d S 1 sw   Y  d S )Nc                    (     | ||   || | d S r   r   rT   rU   r   rV   r   r   r        z/TestTimedeltaArithmetic.test_add.<locals>.checkra   r   r   r   r   iBB r   r   	   r   r   r   )r   r'   r   ri   	TypeErrorr   r   r   rV   r   test_add     
"z TestTimedeltaArithmetic.test_addc                    s(   t  fdd}|tdtdtd |tddtddtdd |tddtddtdd |tdd	tdd
tdd
 |tdtdtd |tddtdd
tdd |tddtddtdd ttf  tddtdd
 W d    d S 1 sw   Y  d S )Nc                    s*     | ||   || |  d S r   r   r   rV   r   r   r   -  s   z/TestTimedeltaArithmetic.test_sub.<locals>.checkr   r   ra   r   r   i- r   r      r   r   r   )r   r)   r   ri   r   r   r   r   rV   r   test_sub+  r   z TestTimedeltaArithmetic.test_subc                    s   t  fdd}|tdtdtd |tddtd |tdddtdd |tdddtdd |tdd	td
 |tdd	td |tdddtdd |tddtd
 |tdddtdd |tddtdtdd |tdddtdd d S )Nc                    r   r   r   r   rV   r   r   r   @  r   z/TestTimedeltaArithmetic.test_mul.<locals>.checkr   r   r   r!   r   rn         ?
   ig      nanl               r   )r   r*   r   npuint32floatr   r   rV   r   test_mul>  s   
z TestTimedeltaArithmetic.test_mulc                    sf   t  t fdd}|tddtdtdd |tddtd |tdddtdd |td	ddtd	d |tddd
td	d |td	dd
td	d |tddtd |tdddtdd |td	ddtd	d |tdddtd	d |td	ddtd	d |tddtdtd	d |td	dtdtd	d d S )Nc                    s(     | ||  | || d S r   r   r   divfloordivrX   r   r   r   W  r   z/TestTimedeltaArithmetic.test_div.<locals>.checkr!   r   r   ra   r   r   rn   g      ?   r   r   r   g      @g        r   )r   r,   r-   r   r   r   r   r   r   r   r   test_divT  s    

 z TestTimedeltaArithmetic.test_divc                    s6   t  fdd}|tdtdd |tddtddd |tddtddd	 |tdtd
td |tdtd
td |td
td
td |tdtdtd |tdtdtd |tdtd
td ttf  tddtdd W d    d S 1 sw   Y  d S )Nc                    s     | || d S r   r   r   r   rX   r   r   r   n     z;TestTimedeltaArithmetic.test_homogeneous_div.<locals>.checkrn   r   g@r   r   gQFoZc?g:@r   z+infr   z-infr   natra   r   r   )r   r,   r   r   ri   r   r   r   r   r   r   test_homogeneous_divl  s   
"z,TestTimedeltaArithmetic.test_homogeneous_divc                    s   t  t fdd}|tdtdd |tdtdd |tddtddd |tddtddd |tddtddd |tdd	tddd |tdd
tddd |tdtdd |tdd	tddd |tdtdd tdk r|tdd
tddd |tdd
tddd |tddtddd d S ttf  tdd
tdd W d    n1 sw   Y  ttf tdd
tdd W d    d S 1 sw   Y  d S )Nc                    sr   |}| }t | st | rd}d} | ||  || | | || || | d S NFTr   isnatr   rT   rU   r   expected_valnot_expected_valeqnerX   r   r   r     s   z1TestTimedeltaArithmetic.test_eq_ne.<locals>.checkra   r   FTr   i  r   r   rd   r   Nat)ra      m  r   in  r   r   )r   r.   r/   r   r   ri   r   r   r   r   r   r   
test_eq_ne  s.   

"z"TestTimedeltaArithmetic.test_eq_nec                    s0   t t  fdd}|tdtdd |tdtdd |tdtdd |tddtddd |tddtddd |tddtddd |tddtd	dd |tddtd
dd |tdtdd |tddtddd |tdtdd ttf tddtdd W d    n1 sw   Y  ttf  tddtdd W d    n1 sw   Y  ttf tddtdd W d    n1 sw   Y  ttf  tddtdd W d    d S 1 sw   Y  d S )Nc                    N   |}| }t | st | rd}d}| ||  | || d S NFr   r   geltrX   r   r   r     s   z1TestTimedeltaArithmetic.test_lt_ge.<locals>.checkra   r   TFr   r   =   <   r   r    r   r   r   r   )r   r0   r3   r   ri   r   r   r   r   r   r   
test_lt_ge  s4   

$z"TestTimedeltaArithmetic.test_lt_gec                    sH   t t  fdd}|tdtdd |tdtdd |tdtdd |tddtddd |tddtddd |tddtddd |tddtd	dd |tddtd
dd |tddtddd |tdtdd |tddtddd |tdtdd ttf tddtdd W d    n1 sw   Y  ttf  tddtdd W d    n1 sw   Y  ttf tddtdd W d    n1 sw   Y  ttf  tddtdd W d    d S 1 sw   Y  d S )Nc                    r   r   r   r   gtlerX   r   r   r     s   z1TestTimedeltaArithmetic.test_le_gt.<locals>.checkra   r   TFr   r   r   r   ;   r   r   r   r   r   r   r   )r   r1   r2   r   ri   r   r   r   r   r   r   
test_le_gt  s6   

$z"TestTimedeltaArithmetic.test_le_gtc                    j    t  fdd}|td |td |tdd |tdd |td |tdd d S )Nc                    s     | | 
  d S r   r   rT   posrX   r   r   r     r   z/TestTimedeltaArithmetic.test_pos.<locals>.checkr   r   r   r   )r   r5   r   r   r   r   r   test_pos     
z TestTimedeltaArithmetic.test_posc                    r   )Nc                    s     | |   d S r   r   r   negrX   r   r   r     r   z/TestTimedeltaArithmetic.test_neg.<locals>.checkr   r   r   r   )r   r7   r   r   r   r   r   test_neg  r   z TestTimedeltaArithmetic.test_negc                    r   )Nc                         | t|  d S r   )r   r9   r   rV   r   r   r        z/TestTimedeltaArithmetic.test_abs.<locals>.checkr   r   r   r   )r   r:   r   r   r   rV   r   test_abs  r   z TestTimedeltaArithmetic.test_absc                    s    t  fdd}d}d}t|| tft| tft|  D ]
\}}|||  q#tdkrXt} td W d    n1 sHw   Y  	dt
|j d S d S )Nc                    sp   t dkr,| jjdkrd S jddr  | | t d S  | t|  d S  | t|  d S )Nr   r   timedelta64r   F)	r   r   namer   getr   astyperE   r;   r   rV   r   r   r     s   z0TestTimedeltaArithmetic.test_hash.<locals>.check))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   ))2014)2016)2000)2014-02)2014-03)2014-04)2016-02)
2000-12-31)
2014-01-16)
2014-01-05)
2014-01-07)
2014-01-06)
2014-02-02)
2014-02-27)
2014-02-16)
2014-03-01)2000-01-01T01:02:03.002Z)2000-01-01T01:02:03Zr   r   r   zCan't hash generic timedelta64)r   r<   zipr   lenr   r   ri   
ValueErrorassertInstr	exception)rX   r   TD_CASESDT_CASEScasetypraisesr   rV   r   	test_hash  s   
z!TestTimedeltaArithmetic.test_hashc                    s      fdd}tdtdtdtdftddtddtddtddffD ]}t||D ]	\}}||| q5q-d S )Nc                         | || | d S r   r   rT   rU   rW   rX   usecaser   r   r   H     z4TestTimedeltaArithmetic._test_min_max.<locals>.checkr   ra   r   r   r   )r   r   r[   r\   rX   r  r   casesrT   rU   r   r  r   _test_min_maxF  s   
"z%TestTimedeltaArithmetic._test_min_maxc                 C      |  t d S r   r   r@   r   r   r   r   test_minR     z TestTimedeltaArithmetic.test_minc                 C   r!  r   r   rD   r   r   r   r   test_maxU  r$  z TestTimedeltaArithmetic.test_maxN)r~   r   r   dictr   r   r   r   r   r   r   r   r   r   r   r   r   r  r   r#  r&  r   r   r   r   r     s$    
+'')r   c                   @   s   e Zd ZeddZdd ZdS )TestTimedeltaArithmeticNoPythonTr   c                    s    t  fdd}dD ]\}}|t||d qdD ]}|t|d qjtdd  td	 W d    d S 1 sDw   Y  d S )
Nc                    r   r   )r   rE   r   rV   r   r   r   _  r   z<TestTimedeltaArithmeticNoPython.test_int_cast.<locals>.check))r   r    )r   r    )i0u  r    )i r    )ra   r   ztimedelta64[ns])r   r   r   r   r   r   r  r  r  r  r  r  r  r  r	  r
  r  r  datetime64[ns]z;Only datetime64[ns] can be converted, but got datetime64[y])msgr   )r   rF   r   r   r   ri   r   )rX   r   deltar   timer   rV   r   test_int_cast]  s   
"z-TestTimedeltaArithmeticNoPython.test_int_castN)r~   r   r   r'  r   r-  r   r   r   r   r(  Y  s    
r(  c                   @   sd   e Zd ZeddZdd Zejdd Zdd Z	d	d
 Z
dd Zdd Zdd Zdd Zdd ZdS )TestDatetimeArithmeticTr   c                 C   r   r   r   r   r   r   r   r   w  r   zTestDatetimeArithmetic.jitc                 c   sF    t   t jddtd d V  W d    d S 1 sw   Y  d S )Nignorez-Implicitly casting between incompatible kinds)messagecategory)warningscatch_warningsfilterwarningsDeprecationWarningr   r   r   r   silence_numpy_warningsz  s   
"z-TestDatetimeArithmetic.silence_numpy_warningsc                    s   t  t fdd}|tdtddtd |tdtddtd |tdtd	d
tdd
 |tdtddtd |tdtddtd |tdtddtd |tdtddtd |tdtddtd |tdd
tdd
tdd
 |tdtddtd |tdtddtd |tdtdd
td |tdtddtd |tdtdd td! d"D ]v}d#D ]q}t|| }tddtdd
td$dtd%dtd&dtd'dtd$d
td%d
td&d
td'd
td$dtd%dtd&dtd'dfD ].} |||| ||f  |||| ||f || || ||f qqq|td(tdtd( |td(d)tddtd(d) |td(d)tdd td(d  |tdtd(d
td(d
 |td*td(d
td(d |td(d)td(d td(d   fD ]I}ttf |td+d*td+d W d,   n	1 sw   Y  ttf |td+d*td+d W d,   n	1 sw   Y  qd,S )-zQ
        Test `datetime64 + timedelta64` and `datetime64 - timedelta64`.
        c                    s     6  | ||| |f  || || |f | | || |f | | | W d    d S 1 s=w   Y  d S r   r6  r   r   addrX   subr   r   r     s   
"z<TestDatetimeArithmetic.test_add_sub_timedelta.<locals>.checkr   r   r   r   r   r   r   r   r  r   r   r  r   r   r  r   r  r   z
2014-02-03r  r  r   r
  z
2012-02-02z
2012-02-29z
2012-02-16r  r   z2000-01-01T03:02:03Zr   r  )6006016048011900190422002300230424006001)rL   -01-12d   r   ir   r   r   
2014-01-01ra   N)	r   r'   r)   r   r   rg   ri   r   r   )rX   r   dt_str	dt_suffixdttdrW   r   r8  r   test_add_sub_timedelta  s`   

	"z-TestDatetimeArithmetic.test_add_sub_timedeltac                 C   s<   g d}g d}dd t ||D }|dd |D 7 }|S )N)r;  r<  r=  196819691973r   200420052100rD  2401)rL   rF  rG  z-02-28z-12-31z-01-05T12:30:56Zz-01-05T12:30:56.008Zc                 S   s   g | ]
\}}t || qS r   r   ).0rT   rU   r   r   r   
<listcomp>  s    z;TestDatetimeArithmetic.datetime_samples.<locals>.<listcomp>c                 S   s   g | ]}t |d qS )r   r   )rV  r   r   r   r   rW    s    )r[   r\   )rX   dt_yearsdt_suffixesdtsr   r   r   datetime_samples  s
   z'TestDatetimeArithmetic.datetime_samplesc                    s6    td fdd	}|tdtdtdd |tdtd	td
d |tdtdtdd |tddtdtdd |tddtdtdd |tdtdtd   1   }t||D ]\}}t	t
|t
|szqk |||| ||f qkW d   dS 1 sw   Y  dS )z1
        Test `datetime64 - datetime64`.
        Nc                    sv      -  | || | | |f  || ||  | |f  | | | W d    d S 1 s4w   Y  d S r   r7  r   rX   r:  r   r   r     s
   
"z>TestDatetimeArithmetic.test_datetime_difference.<locals>.checkr   2017r   r   r   z2017-01ir   z
2014-02-28z
2015-03-01ir   r   r   z
2000-01-01r   )r   r)   r   r   r6  r[  r[   r\   r   ry   r   r   )rX   r   rZ  rT   rU   r   r\  r   test_datetime_difference  s    

"z/TestDatetimeArithmetic.test_datetime_differencec           	   	      s
   t t t t t tfdd  fdd} tdtdd  tdtdd	  tdtd
d	  tdtd
dd	  tdtd
dd	  td
td
dd  tdtddd	  tddtddd	  tddtddd |tddtdd	  tdtdd	  }|D ]Q}|j	j
dd d d }t|}t||d  }|D ]2}|d| }tt|t|sqψ ||d	 |||td| d	 ||td| |d	 qqd S )Nc                    s2  |}| }t | st |rkd}d}| || |f | || |f || | |f || | |f | || |f | || |f || | |f || | |f    | ||| ||f  || || ||f | ||| ||f || || ||f |r| || |f | || |f || | |f || | |f | || |f | || |f || | |f || | |f | |k| W d    d S 1 sw   Y  d S r   )r   r   rP   r6  r   rO   r   )r   r   r   r   r   r   rX   r   r   check_eq  s:   
$z9TestDatetimeArithmetic.test_comparisons.<locals>.check_eqc                    s   |}| }t | st |rd}d} R t}|| ||| ||f || || ||f | ||| ||f || || ||f |rY | |d | |k | W d    d S 1 slw   Y  d S r   )r   r   r6  r   r0   r   )rT   rU   r   r   r   r   )r_  r   r   r   rX   r   r   check_lt  s   

"z9TestDatetimeArithmetic.test_comparisons.<locals>.check_ltr   r]  Fz2014-01TrI  r   z
2014-01-02r  z2014-01-01T00:01:00Zr   z2014-01-01T00:01Zr   z2014-01-01T00:01:01Zr   r   [ra   r   r   zM8[%s])r   r.   r/   r0   r1   r2   r3   r   r[  r   r  splitr_   indexr   r   ry   r   r   r   )	rX   r`  rZ  rT   a_unitrS   unitsr   rU   r   )r_  r   r   r   r   r   r   rX   r   test_comparisons  sN   





%





z'TestDatetimeArithmetic.test_comparisonsc                    s      fdd}tddtddtddtddftddtddtddtddffD ]}t||D ]	\}}||| q9q1d S )	Nc                    r  r   r   r  r  r   r   r   Q  r  z3TestDatetimeArithmetic._test_min_max.<locals>.checkr   r    ra   r   r   r   )r   r   r[   r\   r  r   r  r   r   O  s   
""z$TestDatetimeArithmetic._test_min_maxc                 C   r!  r   r"  r   r   r   r   r#  [  r$  zTestDatetimeArithmetic.test_minc                 C   r!  r   r%  r   r   r   r   r&  ^  r$  zTestDatetimeArithmetic.test_maxN)r~   r   r   r'  r   r   
contextlibcontextmanagerr6  rN  r[  r^  rf  r   r#  r&  r   r   r   r   r.  s  s    

	A	fr.  c                   @   s   e Zd ZeddZdS )TestDatetimeArithmeticNoPythonTr   N)r~   r   r   r'  r   r   r   r   r   ri  a  s    ri  c                   @   s@   e Zd ZdZddifddZdd Zddifdd	Zd
d ZdS )TestMetadataScalingFactorzf
    Tests than non-1 scaling factors are not supported in datetime64
    and timedelta64 dtypes.
    r   Tc                 C   s0   t di |t}| |tddtd d S )Nr   10Y2010r   )r   r.   rO   r   rX   r   r   r   r   r   test_datetimel  s   z'TestMetadataScalingFactor.test_datetimec                 C   >   |    | jddid W d    d S 1 sw   Y  d S Nr   T)r   )assertTypingErrorrn  r   r   r   r   test_datetime_npmp     
"z+TestMetadataScalingFactor.test_datetime_npmc                 C   s2   t di |t}| |tddtdd d S )Nr   rk     r   r   )r   r.   rO   r   rm  r   r   r   test_timedeltat  s    z(TestMetadataScalingFactor.test_timedeltac                 C   ro  rp  )rq  ru  r   r   r   r   test_timedelta_npmx  rs  z,TestMetadataScalingFactor.test_timedelta_npmN)r~   r   r   r   rn  rr  ru  rv  r   r   r   r   rj  f  s    rj  c                   @      e Zd Zdd ZdS )TestDatetimeDeltaOpsc                 C   s   dd }|}t |}tdttdtftdttdtftdttdtftdttdtftdtdftdttdtjftdttdtjfg}|D ]\}}| t|||||| qYdS )zC
        Test the division of a timedelta by numeric types
        c                 S   r+   r   r   r  r   r   r   arr_div  r(   z.TestDatetimeDeltaOps.test_div.<locals>.arr_divr   ra   N)	r   r   onesTIMEDELTA_MTIMEDELTA_Yr   float64rO   array_equal)rX   ry  py_funccfunc
test_casesrT   rU   r   r   r   r   ~  s   	 zTestDatetimeDeltaOps.test_divN)r~   r   r   r   r   r   r   r   rx  }      rx  c                   @   s   e Zd Zdd Zdd Zedd Zdd Zed	d
 Zdd Z	dd Z
dd Zdd Zdd Zdd Zdd Zdd Zdd Zdd Zdd  Zed!d" Zed#d$ Zed%d& Zed'd( Zd)d* Zd+S ),TestDatetimeArrayOpsc              	      s"   fdd}t jt dt dt dt dgdd}t jt dt dt dt dgd	d}|}t|d
|}|t df|t df|t df|t dfg} t ju ry|t d|ft d|ft d|ft d|fg |D ]\}	}
| t ||	|
||	|
 q{dS )zY
        Test the addition/subtraction of a datetime array with a timedelta type
        c                    
    | |S r   r   r  	operationr   r   impl  rA   z6TestDatetimeArrayOps._test_td_add_or_sub.<locals>.impl
2011-01-01
1971-02-02
2021-03-03
2004-12-07r)  r   zdatetime64[D]parallel  i*N)	r   array
datetime64r   r   r9  extendrO   r~  )rX   r  r  r  arr_onearr_twor  r  r  rT   rU   r   r  r   _test_td_add_or_sub  sD   
 z(TestDatetimeArrayOps._test_td_add_or_subc                 C      |  tjd d S r   r  r   r9  r   r   r   r   test_add_td     z TestDatetimeArrayOps.test_add_tdc                 C   r  NTr  r   r   r   r   test_add_td_parallel     z)TestDatetimeArrayOps.test_add_td_parallelc                 C   r  r   r  r   subtractr   r   r   r   test_sub_td  r  z TestDatetimeArrayOps.test_sub_tdc                 C   r  r  r  r   r   r   r   test_sub_td_parallel  r  z)TestDatetimeArrayOps.test_sub_td_parallelc                    s   t  fdd} j}td| d}| ttf| |tjt	dgddt
dd	 W d
   d
S 1 s:w   Y  d
S )z
        Tests that attempting to add/sub a datetime64 and timedelta64
        with types that cannot be cast raises a reasonable exception.
        c                    r  r   r   r  r  r   r   r       
z<TestDatetimeArrayOps._test_add_sub_td_no_match.<locals>.implzufunc 'z<' is not supported between datetime64[ns] and timedelta64[M]r  r)  r  r  r   N)r   r~   reescapeassertRaisesRegexr   r   r   r  r  r   )rX   r  r  fnamer   r   r  r   _test_add_sub_td_no_match  s   
"z.TestDatetimeArrayOps._test_add_sub_td_no_matchc                 C      |  tj d S r   )r  r   r9  r   r   r   r   test_add_td_no_match     z)TestDatetimeArrayOps.test_add_td_no_matchc                 C   r  r   )r  r   r  r   r   r   r   test_sub_td_no_match  r  z)TestDatetimeArrayOps.test_sub_td_no_matchc                 C   s  t tddtddtddtddgt tddtddtddtd	dtd
dgt tddtddtddtd	dtd
dgt tddtddtddtd	dtd
dtddgt tddtddtddtddtd	dtd
dgt tddtddgt tddtddtddgt tddtddtddtddgt tddtddtddtddgt tddtddtddtddtddgt tddtddtddtddtddgt tddgt tddtddtddgg}|S )Nr   r    ra   r   r   r  r  z
1900-01-01r  r  r   r   r   )r   r  r   r   )rX   r  r   r   r   _get_testcases  s   Qz#TestDatetimeArrayOps._get_testcasesc                    s   |r t ju rdd }ndd }n fdd}|}t|d|}|  }|D ]+}||}	||}
t |	s:t |
rK| t |	 | t |
 q&| |	|
 q&d S )Nc                 S      |   S r   r>   arrr   r   r   r  :  r(   z0TestDatetimeArrayOps._test_min_max.<locals>.implc                 S   r  r   rB   r  r   r   r   r  =  r(   c                    s    | S r   r   r  r  r   r   r  @  r(   r  )r   r?   r   r  r   rO   rg   )rX   r  r  methodr  r  r  r  r  py_resc_resr   r  r   r   7  s    


z"TestDatetimeArrayOps._test_min_maxc                 C      |  tdd d S r   )r   r?   r   r   r   r   test_min_funcP  r  z"TestDatetimeArrayOps.test_min_funcc                 C      |  tjdd d S r   r   r   r?   r   r   r   r   test_np_min_funcS  r   z%TestDatetimeArrayOps.test_np_min_funcc                 C      |  tjdd d S r   r  r   r   r   r   test_min_methodV  r   z$TestDatetimeArrayOps.test_min_methodc                 C   r  r   )r   rC   r   r   r   r   test_max_funcY  r  z"TestDatetimeArrayOps.test_max_funcc                 C   r  r   r   r   rC   r   r   r   r   test_np_max_func\  r   z%TestDatetimeArrayOps.test_np_max_funcc                 C   r  r   r  r   r   r   r   test_max_method_  r   z$TestDatetimeArrayOps.test_max_methodc                 C   r  NTFr  r   r   r   r   test_min_func_parallelb     z+TestDatetimeArrayOps.test_min_func_parallelc                 C   r  r  r  r   r   r   r   test_min_method_parallelf  r  z-TestDatetimeArrayOps.test_min_method_parallelc                 C   r  r  r  r   r   r   r   test_max_func_parallelj  r  z+TestDatetimeArrayOps.test_max_func_parallelc                 C   r  r  r  r   r   r   r   test_max_method_paralleln  r  z-TestDatetimeArrayOps.test_max_method_parallelc                    s   ddl m}m}m} |||g}dd |D } fdd}  }t||D ]>\}}	|D ]7}
t|
}
tdt	d|
j
d D ]$}tjd|
j
|}|
| }|dkrZ|\}|||	|
| |||	|
| q=q+q%d S )	Nra   )searchsortedsearchsorted_leftsearchsorted_rightc                 S   s   g | ]}t |qS r   )r   )rV  fnr   r   r   rW  w  s    zCTestDatetimeArrayOps.test_searchsorted_datetime.<locals>.<listcomp>c                    s$   | ||}|||}  || d S r   r   )r   r  rT   vr   gotr   r   r   r   y  s   

z>TestDatetimeArrayOps.test_searchsorted_datetime.<locals>.checkr   r   )test_np_functionsr  r  r  r  r  r   sortranger?   sizerandomrandint)rX   r  r  r  pyfunc_list
cfunc_listr   r  r   r  r  nidxvsr  r   r   r   test_searchsorted_datetimer  s$   

z/TestDatetimeArrayOps.test_searchsorted_datetimeN)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    s8    &

T



r  c                   @   rw  )TestDatetimeTypeOpsc                    s   t dd }t dd }t dd }tdd}td	d}|| } fd
d}|||g}|||g}	t||	D ]	\}
}||
| q8d S )Nc                 S   s
   t | tS r   )
isinstancecomplexr   r   r   r   
is_complex  r  z@TestDatetimeTypeOps.test_isinstance_datetime.<locals>.is_complexc                 S      t | tjS r   )r  r   r  r   r   r   r   is_datetime     zATestDatetimeTypeOps.test_isinstance_datetime.<locals>.is_datetimec                 S   r  r   )r  r   r   r   r   r   r   is_timedelta  r  zBTestDatetimeTypeOps.test_isinstance_datetime.<locals>.is_timedeltara   r    r   c                    sb     | j dt|j d | |}| |} || W d    d S 1 s*w   Y  d S )N())subTestr~   typer  rg   )jit_funcr%   r  expectr   r   r   r     s
    
"z;TestDatetimeTypeOps.test_isinstance_datetime.<locals>.check)r   r   r  r[   r\   )rX   r  r  r  dt_adt_btd_cr   fnsr   r  argr   r   r   test_isinstance_datetime  s*   


z,TestDatetimeTypeOps.test_isinstance_datetimeN)r~   r   r   r  r   r   r   r   r    r  r  __main__)Dr   rg  r[   r  unittestr2  numpyr   numbar   r   r   numba.np.numpy_supportr   
numba.corer   r   numba.core.errorsr   numba.tests.supportr	   r
   r   numba.npr   r   r   r{  r|  r   r]   r^   r_   r'   r)   r*   r,   r-   r.   r/   r0   r1   r2   r3   r5   r7   r:   r<   r@   rD   rF   rJ   rK   r   r   r  r   r   r   r(  r.  ri  rj  rx  r  r  r~   mainr   r   r   r   <module>   sr    

v6  J o y
$