a
    Pf                     @   s>   d dl Zd dlZd dlmZmZ d dlmZ G dd dZ	dS )    N)	DataFrameSeriesc                   @   s   e Zd Zdd Zdd Zdd Zdd Zej	d	d
dgdd Z
ej	d	d
dgej	dg deg dgej	ddg dg dg dgfdg dg dg dgfgdd Zej	dg ddd Zdd Zd d! Zd"d# Zd$d% Zd&S )'TestDataFrameClipc                 C   sL   |    }| }|j||d}|j|k r4J |j|jk sHJ d S )Nupperlower)mediancopyclipvaluesanyall)selffloat_framer   originaldouble r   ]/var/www/ai-form-bot/venv/lib/python3.9/site-packages/pandas/tests/frame/methods/test_clip.py	test_clip   s
    zTestDataFrameClip.test_clipc                 C   sF   |    }| }|j||dd}|d u s0J |j|k rBJ d S )NT)r   r   inplace)r   r	   r
   r   r   )r   r   r   Z
frame_copyZreturn_valuer   r   r   test_inplace_clip   s
    z#TestDataFrameClip.test_inplace_clipc                 C   s   t tjdd}dD ]\}}|||}t||t|| }}|j|k}|j|k}| | @ }|j| |k	 szJ |j| |k	 sJ |j| |j| k	 sJ qd S )N     r   ))   )r   r   )
r   nprandomdefault_rngstandard_normalr
   minmaxr   r   )r   dflbub
clipped_dflb_maskub_maskmaskr   r   r   test_dataframe_clip   s    

z%TestDataFrameClip.test_dataframe_clipc                 C   s   t g ddtjdgd}|dd}t g ddtjdgd}t|| t g d	g d
gg dd}|j}|jddj}t|| d S )Nr   r            ?      @)ABr   r   )r   r   r          @)r   r   g333333@)r+      gffffff@)ZfoobarZbazcolumnsr+   r   )r   r   nanr
   tmassert_frame_equalZdtypesassert_series_equalr   r"   resultexpectedr   r   r   test_clip_mixed_numeric.   s    z)TestDataFrameClip.test_clip_mixed_numericr   TFc                 C   s   t tjdd}ttjdd}|d }| }|j||d|d}|rV|}tdD ]}|j	d d |f |k}|j	d d |f |k}	| |	 @ }
|j
||f }tj||| dd |j|ksJ |j
|	|f }tj|||	 dd |j|ksJ t|j
|
|f |j
|
|f  q^d S )	Nr   r   r   r   r   )axisr   F)Zcheck_names)r   r   r   r   r   r   r	   r
   rangeZiloclocr7   r9   name)r   r   r"   r#   r$   r   r%   ir&   r'   r(   r;   r   r   r   test_clip_against_series;   s$    z*TestDataFrameClip.test_clip_against_seriesr   )r   r+   r1   zaxis,resr   )r0   r0   r-         @      @      @)      @rH   rH   r   )r0   r-   rE   )rF   rG   rH   c           	      C   sv   t g dg dg dg}t|g dg dd}|j|g d||d}t||j|jd}|rb|}tj||d	d
 d S )N)r,   r0   r-   rD   )rH   g       @g      "@)onetwothree)abc)r4   index)         )r   r   r>   r   T)Zcheck_exact)r   arrayr   r
   r4   rO   r7   r8   )	r   r   r   r>   resZarrr   r;   r<   r   r   r   test_clip_against_list_likeX   s    z-TestDataFrameClip.test_clip_against_list_liker>   )r   r   Nc           	      C   s   t tjdd}t tjdd}|d }|j|||d}||k}||k}| | @ }t|| ||  t|| ||  t|| ||  d S )Nr   r   r   )r>   )r   r   r   r   r   r
   r7   r8   )	r   r>   r"   r#   r$   r%   r&   r'   r(   r   r   r   test_clip_against_framep   s    z)TestDataFrameClip.test_clip_against_framec           
      C   s   t tjddg dd}t tjddg dd}t |jd g dd}|jd|d	}|jd||j d	}|j|d
d	}|j||j d
d	}|j||d	}|j||j ||j d	}	t	|| t	|| t	||	 d S )Nr   )r   r1   )r.   r/   CDr3   )rX   r.   r/   rW   r   )r/   rX   rW   r.   r   )r   r   r+   )
r   r   r   r   r   r   r
   r4   r7   r8   )
r   Zdf1Zdf2Zdf3Zresult_upperZexpected_upperZresult_lowerZexpected_lowerZresult_lower_upperZexpected_lower_upperr   r   r   #test_clip_against_unordered_columns   s$    z5TestDataFrameClip.test_clip_against_unordered_columnsc                 C   s  t |tj| t |jtjtjd| tg dg dg dd}d}t jt|d& |jdd	tjgd
d}W d   n1 s0    Y  tg dg dg dd}t || |jdd	tjgdd}tg dg dg dd}t || g dg dd}t|}tddtjddg}t jt|d |j|d
d}W d   n1 sZ0    Y  tg dg dd}t || dS )z&Should process np.nan argument as Noner   r*   )r1   rP   rQ   )rR      	   )col_0col_1Zcol_2z<Downcasting behavior in Series and DataFrame methods 'where')matchr1   rP   r   )r   r>   N)r1   rP   r+   r   )r1   r1   r1   )rP   rP   rQ   )r[   r   r   rP   )irQ   rZ   )r\   r]   r   rQ   r+   )r[   r_   r   rQ   rP   )r   rb   rQ   rZ   r+   )	r7   r8   r
   r   r6   r   Zassert_produces_warningFutureWarningr   )r   r   r"   msgr;   r<   datatr   r   r   test_clip_with_na_args   s,    4.z(TestDataFrameClip.test_clip_with_na_argsc                 C   s<   t dg di}|jdd}t dg di}t|| d S )NrL   r*         ?)r   )rh   r0   r-   r   r
   r7   r8   r:   r   r   r   #test_clip_int_data_with_float_bound   s    z5TestDataFrameClip.test_clip_int_data_with_float_boundc                 C   sZ   t ddg}t ddg}|dg}t|| t ddg}|jdgd}t|| d S )Nr   rP   r+   r5   ri   )r   r"   r<   r;   r   r   r   test_clip_with_list_bound   s    z+TestDataFrameClip.test_clip_with_list_boundN)__name__
__module____qualname__r   r   r)   r=   pytestmarkZparametrizerC   r   ZasarrayrU   rV   rY   rg   rj   rk   r   r   r   r   r      s*   
	

"r   )
numpyr   ro   Zpandasr   r   Zpandas._testingZ_testingr7   r   r   r   r   r   <module>   s   