o
    թZhE                     @   s  d dl m Z  d dlZd dlZd dlm  mZ d dlm	Z	m
Z
mZmZmZmZ d dlmZ d dlmZ ejdejdi gejdi gdd	 d
i gejdi gejdi gejdi gdd	 di gdd	 ddd igdd	 di gdd	 ddd igg
dd Zejdejdi gejdi gdd	 d
i gejdi gejdi gejdi gdd	 di gdd	 ddd igdd	 di gdd	 ddd igg
dd Zejdejdi dgejdi dgd d	 d
i d gejdi dgejdi dgejdi dgd!d	 di dgd"d	 ddd idgd#d	 di dgd$d	 ddd idgg
d%d& Zejdejdi dgejdi dgd'd	 d
i d gejdi dgejdi dgejdi dgd(d	 di dgd)d	 ddd idgd*d	 di dgd+d	 ddd idgg
d,d- Zejdejdi gejdi gejdi gejdi gejdi gd.d	 di gd/d	 ddd igd0d	 di gd1d	 ddd igg	d2d3 Zd4d5 Z ejd6di gdi gdi gdi gdi gdi gddd igdi gddd igg	ejd7g d8d9d: Z!d;d< Z"ejd=di d>gdi d>gd
i d gdi d>gdi d>gdi d>gdi d>gddd id>gdi d>gddd id>gg
d?d@ Z#ejdAdi ddgdi ddgd
i d d gdi ddgdi ddgdi ddgdi ddgddd iddgdi ddgddd iddgg
dBdC Z$ejdAdi ddgdi ddgd
i d d gdi ddgdi ddgdi ddgdi ddgddd iddgdi ddgddd iddgg
dDdE Z%ejdFdGd	 dHd	 dId	 dJd	 dKd	 dLd	 dMd	 dNd	 dOd	 dPd	 dQd	 dRd	 dSd	 dTd	 ej&dUd	 e'dVdWgdXdY Z(dZd[ Z)d\d] Z*d^d_ Z+d`da Z,dbdc Z-ejdddedf dgD dhdf diD  djdk Z.ejdFdld	 dmd	 dnd	 dod	 dpd	 dqd	 drd	 dsd	 dtd	 dud	 dvd	 dwd	 dxd	 dyd	 dzd	 ej&d{d	 e'dVdWgd|d} Z/dS )~    datetimeN)	DataFrameDatetimeIndexSeriesconcatisnanotna)offsetszcompare_func, roll_func, kwargsmeansumc                 C      t | t S Nnpisfiniteastypefloatr   x r   a/var/www/html/lang_env/lib/python3.10/site-packages/pandas/tests/window/test_rolling_functions.py<lambda>       r   countmedianminmaxc                 C      t j| ddS N   ddofr   stdr   r   r   r   r   "       r$   c                 C   r   Nr   r!   r#   r   r   r   r   r   #   r%   r"   c                 C   r   r   r   varr   r   r   r   r   $   r%   r(   c                 C   r   r&   r'   r   r   r   r   r   %   r%   c                 C   sn   t | jd|d|di |}t|tsJ tdt| |pdd d }t|jd || |d |  d S )N2   stepr   r    r   )	getattrrolling
isinstancer   rangelentmassert_almost_equaliloc)seriescompare_func	roll_funckwargsr+   resultendr   r   r   test_series   s   &r;   c                 C   r   r   r   r   r   r   r   r   5   r   c                 C   r   r   r#   r   r   r   r   r   <   r%   c                 C   r   r&   r#   r   r   r   r   r   =   r%   c                 C   r   r   r'   r   r   r   r   r   >   r%   c                 C   r   r&   r'   r   r   r   r   r   ?   r%   c                 C   s   t |jd|d|d	i |}t|tsJ tdt||pdd d }tj|jdd d f |j|d |d d f j	|d| ddd d S )
Nr)   r*   r   r    r,   )ZaxisrawFZcheck_namesr   )
r-   r.   r/   r   r0   r1   r2   assert_series_equalr4   apply)r<   framer6   r7   r8   r+   r9   r:   r   r   r   
test_frame/   s   $
rA   z%compare_func, roll_func, kwargs, minp
   c                 C   r   r   r   r   r   r   r   r   R   r   c                 C   r   r   r#   r   r   r   r   r   V   r%   c                 C   r   r&   r#   r   r   r   r   r   W   r%   c                 C   r   r   r'   r   r   r   r   r   X   r%   c                 C   r   r&   r'   r   r   r   r   r   Y   r%   c                 C   s   d}| d d d  d }t|j||d|di |}|jd }|dt   }	| d d d |	|}
t	|j
d ||
 d S )N      Bwindowmin_periodsr,      r   )resampler   r-   r.   indexr
   BDaytruncater2   r3   r4   )r5   r6   r7   r8   minpwinZserZseries_result	last_date	prev_dateZtrunc_seriesr   r   r   test_time_rule_seriesM   s   
rR   c                 C   r   r   r   r   r   r   r   r   n   r   c                 C   r   r   r#   r   r   r   r   r   r   r%   c                 C   r   r&   r#   r   r   r   r   r   s   r%   c                 C   r   r   r'   r   r   r   r   r   t   r%   c                 C   r   r&   r'   r   r   r   r   r   u   r%   c                 C   s   d}|d d d  d }t|j||d|d
i |}|jd }	|	dt   }
|d d d |
|	}tj	|
|	|j|| ddd	 d S )NrC   rD   rE   rF   r,   rI   r<   Fr=   r   )rJ   r   r-   r.   rK   r
   rL   rM   r2   r>   Zxsr?   )r<   r@   r6   r7   r8   rN   rO   frmZframe_resultrP   rQ   Ztrunc_framer   r   r   test_time_rule_framei   s   

rU   c                 C   r   r   r#   r   r   r   r   r      r%   c                 C   r   r&   r#   r   r   r   r   r      r%   c                 C   r   r   r'   r   r   r   r   r      r%   c                 C   r   r&   r'   r   r   r   r   r      r%   c                 C   s  t tjdd}tj|d d< tj|dd < t|jddd|di |}t	|j
d | |dd  t|jdd	d|di |}t|j
d
 sOJ t|j
d rXJ t|j
d raJ t|j
d sjJ t tjdd}t|jddd|di |}t|j
d sJ t|j
d sJ |dkrt|jddd|di |}t|jddd|di |}t	|| d S d S )NrD   r)   rB      rH   r,            rI   i         r   r   r    r   )r   r   randomdefault_rngstandard_normalnanr-   r.   r2   r3   r4   r   r	   )r6   r7   r8   objr9   obj2Zresult0Zresult1r   r   r   	test_nans   s&   rf   c                  C   sr   t tjdd} tj| d d< tj| dd < | jddd }t	|j
d t| dd t  d S )NrD   r)   rB   rV   rW   rX   r,   )r   r   r`   ra   rb   rc   r.   r   r2   r3   r4   r   r   r   r   )rd   r9   r   r   r   test_nans_count   s   "rg   zroll_func, kwargsrN   )r   c   d   c                 C   s   t | jt| d ||d|di |}t | jt| ||d|di |}t|}t|t| | }t|| ||  d S )Nr    rH   r+   r   )r-   r.   r1   r   r2   r>   r3   )r5   rN   r7   r8   r+   r9   expectednan_maskr   r   r   test_min_periods   s   rm   c                 C   sj   | j t| d d|d }| j t| d|d }t|}t|t| | }t|| ||  d S )Nr    r   rj   )r.   r1   r   r   r2   r>   r3   )r5   r+   r9   rk   rl   r   r   r   test_min_periods_count   s   rn   zroll_func, kwargs, minprZ   c                 C   s   t tjdd}tj|d d< tj|dd < t|jd|dd| di |}tt|t tjgd gjd|d	| di |j	dd  j
dd
}t|| d S )NrD   r)   rB   rV   rY   T)rH   center	   rX   )Zdropr   )r   r   r`   ra   rb   rc   r-   r.   r   r4   Zreset_indexr2   r>   )r7   r8   rN   rd   r9   rk   r   r   r   test_center   s"   "rq   z#roll_func, kwargs, minp, fill_valuec                 C      dd t dD }t| t| j| jd|d|d	i |d| j}t| jd|dd|d	i |}|d ur@||}t	|| d S )
Nc                 S      g | ]}d |dqS r   dr   .0r   r   r   r   
<listcomp>      z.test_center_reindex_series.<locals>.<listcomp>   rC   rF   TrG   rH   ro   r   )
r0   r-   reindexlistrK   r.   shiftfillnar2   r>   )r5   r7   r8   rN   
fill_valuesZ	series_xpZ	series_rsr   r   r   test_center_reindex_series  $   
r   c                 C   rr   )
Nc                 S   rs   rt   r   rv   r   r   r   rx   8  ry   z-test_center_reindex_frame.<locals>.<listcomp>rz   rC   rF   r{   Tr|   r   )
r0   r-   r}   r~   rK   r.   r   r   r2   assert_frame_equal)r@   r7   r8   rN   r   r   Zframe_xpZframe_rsr   r   r   test_center_reindex_frame'  r   r   fc                 C      | j dddj| ddS NrB   r]   rF   F)pairwiser.   Zcovr   r   r   r   r   M  ry   c                 C   r   r   r.   Zcorrr   r   r   r   r   N  ry   c                 C      | j ddd S NrB   r]   rF   r.   r   r   r   r   r   r   O      c                 C   r   r   r.   r   r   r   r   r   r   P  r   c                 C   r   r   r.   r   r   r   r   r   r   Q  r   c                 C   r   r   r.   r   r   r   r   r   r   R  r   c                 C   r   r   r.   r$   r   r   r   r   r   S  r   c                 C   r   r   r.   r(   r   r   r   r   r   T  r   c                 C   r   r   r.   Zskewr   r   r   r   r   U  r   c                 C   r   r   r.   Zkurtr   r   r   r   r   V  r   c                 C   s   | j dddjddS )NrB   r]   rF         ?)qr.   Zquantiler   r   r   r   r   W  s    c                 C   r   r   r.   r   r   r   r   r   r   X  r   c                 C      | j dddjtddS NrB   r]   rF   FrS   r.   r?   r   r   r   r   r   r   Y  ry   c                 C   r   NrB   r]   rF   TrS   r   r   r   r   r   r   Z  ry   c                 C      | j dddd S NZboxcarrB   r]   )Zwin_typerG   rH   r   r   r   r   r   r   \  r   Zscipy)Zmarksc                 C   s   t td}t tj|jd}tddgddgddgdd	ggd
dgd}ttj|j|jd}| |}t|| | |}t	|| d S )Nr_   rK   r    r]   r^   rD   rp   r,   r   ArE   columns)rK   r   )
r   r0   r   rc   rK   r   r   r2   r>   r   )r   r   
s_expecteddfZdf_expecteds_resultZ	df_resultr   r   r   +test_rolling_functions_window_non_shrinkageJ  s   (r   c                 C   s   dd t ddD }|tddddd tt dd|d	}|d
d }| }tg dtdd t ddD ddd	dd|  }|d j	d| d }t
|| dS )z%Replicate result expected in GH #6297c                 S      g | ]}t d d|qS   r    r   rw   ir   r   r   rx   q  ry   z+test_rolling_max_gh6297.<locals>.<listcomp>r       r   r^   r      r   c                 S      t | S r   r   r   r   r   r   r   v      z)test_rolling_max_gh6297.<locals>.<lambda>)      ?       @g      @      @g      @c                 S      g | ]	}t d d|dqS r   r    r   r   r   r   r   r   rx   |      DfreqNrG   r+   )r0   appendr   r   map
sort_indexr   rJ   r   r.   r2   r>   )r+   indicesr5   rk   r   r   r   r   test_rolling_max_gh6297o  s   r   c                 C   s  dd t ddD }|tdddd |tdddd ttt ddd	g |d
}|dd }| }tg dtdd t ddD ddd
d d |  }|d	 j
d| d	 }t|| tg dtdd t ddD ddd
d d |  }|d j
d| d	 }t|| d}tdddd|gtdd t ddD ddd
d d |  }|d j
d| d	 }t|| d S )Nc                 S   r   r   r   r   r   r   r   rx     ry   z-test_rolling_max_resample.<locals>.<listcomp>r    r   r   r]   rD   rB   rY   r   c                 S   r   r   r   r   r   r   r   r     r   z+test_rolling_max_resample.<locals>.<lambda>)        r   r         @g      4@c                 S   r   r   r   r   r   r   r   rx     r   r   r   r   )r   r   r   r   g      $@c                 S   r   r   r   r   r   r   r   rx     r   g&@r   r   r   r   c                 S   r   r   r   r   r   r   r   rx     r   )r0   r   r   r   r~   r   r   r   rJ   r   r.   r2   r>   r   r   )r+   r   r5   rk   r   vr   r   r   test_rolling_max_resample  s>   r   c                 C   s   dd t ddD }|tdddd |tdddd ttt ddd	g |d
}|dd }| }tg dtdd t ddD ddd
d d |  }|d	 j
d| d}t||	  d S )Nc                 S   r   r   r   r   r   r   r   rx     ry   z-test_rolling_min_resample.<locals>.<listcomp>r    r   r   r]   rD   rB   rY   r   c                 S   r   r   r   r   r   r   r   r     r   z+test_rolling_min_resample.<locals>.<lambda>)r   r   r   r   r   c                 S   r   r   r   r   r   r   r   rx     r   r   r   r   )r0   r   r   r   r~   r   r   r   rJ   r   r.   r2   r>   )r+   r   r5   rk   rr   r   r   test_rolling_min_resample  s   r   c                  C   s   dd t ddD } | tdddd | tdddd ttt ddd	g | d
}|dd }| }tg dtdd t ddD ddd
}|d	 j
dd	 }t|| d S )Nc                 S   r   r   r   r   r   r   r   rx     ry   z0test_rolling_median_resample.<locals>.<listcomp>r    r   r   r]   rD   rB   rY   r   c                 S   r   r   r   r   r   r   r   r     r   z.test_rolling_median_resample.<locals>.<lambda>)r   r   r   r   rB   c                 S   r   r   r   r   r   r   r   rx     r   r   r   rG   )r0   r   r   r   r~   r   r   r   rJ   r   r.   r2   r>   )r   r5   rk   r   r   r   r   test_rolling_median_resample  s   r   c                  C   sP   d} t tjd| jddd  t tjd| jddd  d S )Ni N  rD   F)rG   ro   )r   r   r`   ra   rb   r.   r   )nr   r   r    test_rolling_median_memory_error  s   
r   	data_typec                 C   s   g | ]
}t d | qS )r   r   dtype)rw   widthr   r   r   rx     s    rx   )r_      c                 C   s(   g | ]}d D ]}t | | qqS )Zuir   )rw   r   signr   r   r   rx     s   ( )r    rD   r_   r   c                 C   sp   t tjd| djdd }|jd tdksJ t tjd| djdd }|jd tdks6J d S )NrY   r   r]   r   r   Zf8)r   r   Zaranger.   r   Zdtypesr   r   )r   r9   r   r   r   "test_rolling_min_max_numeric_types  s   r   c                 C   r   )NrB   r   rF   )r.   r   r   r   r   r   r     r   c                 C   r   r   r   r   r   r   r   r     ry   c                 C   r   r   r   r   r   r   r   r     ry   c                 C   r   r   r   r   r   r   r   r     r   c                 C   r   r   r   r   r   r   r   r     r   c                 C   r   r   r   r   r   r   r   r     r   c                 C   r   r   r   r   r   r   r   r     r   c                 C   r   r   r   r   r   r   r   r     r   c                 C   r   r   r   r   r   r   r   r     r   c                 C   r   r   r   r   r   r   r   r     r   c                 C   r   r   r   r   r   r   r   r     r   c                 C   s   | j ddddS )NrB   r]   rF   r   r   r   r   r   r   r     r   c                 C   r   r   r   r   r   r   r   r     r   c                 C   r   r   r   r   r   r   r   r     ry   c                 C   r   r   r   r   r   r   r   r     ry   c                 C   r   r   r   r   r   r   r   r     r   c           
      C   s|   t tjd}|}t }|}tdgd}|d d|d< |}| |}t|| | |}t|| | |}	t|	| d S )Nr   ar   float64)r   r   r   r   r   r2   r>   r   )
r   r   r   Zdf1Zdf1_expectedZdf2Zdf2_expectedr   Z
df1_resultZ
df2_resultr   r   r   !test_moment_functions_zero_length  s   r   )0r   numpyr   ZpytestZpandas.util._test_decoratorsutilZ_test_decoratorstdZpandasr   r   r   r   r   r	   Zpandas._testingZ_testingr2   Zpandas.tseriesr
   markZparametrizer   Znansumr   r   r   r;   rA   rR   rU   rf   rg   rm   rn   rq   r   r   paramZ
skip_if_nor   r   r   r   r   r   r   r   r   r   r   r   <module>   s    











































%
