o
    _~#gN                     @   sp   d dl Zd dlZd dlmZ d dlmZ d dlm  m	Z
 d dlmZmZmZmZ d dlmZ G dd dZdS )    N)using_pyarrow_string_dtype)ChainedAssignmentError)	DataFrameNaTSeries
date_rangec                   @   s  e Zd Zdd Zdd Zdd Zejje	 ddd	d
 Z
ejje	 dd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jdejddd d!ejd"dd#d!ejd$d%d&d!gd'd( Zd)d* Zejd+d,ejd-ed.d/gd0d1 Zd2d3 Zd4d5 Zd6d7 Zd8d9 Zd:d; Zd<d= Z ejdd>d?gd@dA Z!ejdBd-d,gejdCg dDdEdF Z"dGdH Z#dIdJ Z$ejdKdLdMejdNedOd/ejdPedOd/gdQdR Z%ejdKg dSdTdU Z&dVS )WTestDataFrameInterpolatec                 C   s   t tdtdtdg}|jjdksJ | }t |d |d d |d g}t|| | }| }| }t	|| d S )Nz1+1jnanz2+2jcr         ?   )
r   complexfloatdtypekindinterpolatetmassert_series_equalto_frameassert_frame_equal)selfserresexpecteddf r   /var/www/static.ux5.de/https/Moving-Object-Detection-with-OpenCV/env/lib/python3.10/site-packages/pandas/tests/frame/methods/test_interpolate.pytest_interpolate_complex   s   z1TestDataFrameInterpolate.test_interpolate_complexc                 C   s   t tddd}| }t|d< || }||}t|| |jd}|| }||jd}t|| ||d  }	||	 }
|||d  }t|
| d S )Nz
2012-01-01   )periodsr   z
US/Pacificr   )	r   r   copyr   r   r   assert_equaldttz_localize)r   frame_or_seriesorigr   r   r   ser_tzres_tzexpected_tzser_tdres_tdexpected_tdr   r   r   $test_interpolate_datetimelike_values!   s   z=TestDataFrameInterpolate.test_interpolate_datetimelike_valuesc                 C   s   |r|t u rtjjdd}|| |dtjdg}|j}|jdd |g d}t	
|| t||js8J | d dksBJ d S )	Nz'.values-based in-place check is invalidreason   r   Tinplace)r/   r   r   r   )r   pytestmarkxfailapplymarkernpr	   valuesr   r   r!   shares_memorysqueeze)r   r$   using_array_managerrequestr3   objr%   r   r   r   r   test_interpolate_inplace7   s   
z1TestDataFrameInterpolate.test_interpolate_inplacez#interpolate doesn't work for stringr-   c           	      C   s  t ddtjdgdddtjgg dtdd}t g dg d	g dtdd}d
}tjt|d | }W d    n1 s@w   Y  t|| |d j	}|d j
}|rnt||d j	sbJ t||d j	smJ nt||d j	ryJ t||d j	rJ tjt|d |jdd}W d    n1 sw   Y  |d u sJ t|| t|d j	|sJ t|d j	|sJ d S )Nr/   r      	   r/   r      r   abcdABCD      ?       @      @      @)rI   rL         "@rM   'DataFrame.interpolate with object dtypematchrF   rG   Tr0   )r   r6   r	   listr   assert_produces_warningFutureWarningr   r   _valuesr7   r8   )	r   using_copy_on_writer   r   msgresultcvaluesdvaluesr   r   r   r   test_interp_basicH   sB   


z*TestDataFrameInterpolate.test_interp_basicc                 C   s   t ddtjdgdddtjgg dtdd}d}|stnd }tj||d	 |d
 }W d    n1 s8w   Y  |d
}d|j	d< d|j	d< t
|| d S )Nr/   r   r>   r?   r@   rB   rC   rN   rO   rF   rA   rA   rD   )r   rE   )r   r6   r	   rQ   rS   r   rR   	set_indexr   locr   )r   using_infer_stringr   rV   warningrW   r   r   r   r   &test_interp_basic_with_non_range_indext   s    	


z?TestDataFrameInterpolate.test_interp_basic_with_non_range_indexc                 C   s.   t  }| }||usJ |}t|| d S )N)r   r   r   r   r   r   rW   r   r   r   r   test_interp_empty   s
   z*TestDataFrameInterpolate.test_interp_emptyc                 C   sl   t ddtjdgdddtjgg dd}d}tjt|d |jd	d
 W d    d S 1 s/w   Y  d S )Nr/   r   r>   r?   r@   rD   rE   rF   a  method must be one of \['linear', 'time', 'index', 'values', 'nearest', 'zero', 'slinear', 'quadratic', 'cubic', 'barycentric', 'krogh', 'spline', 'polynomial', 'from_derivatives', 'piecewise_polynomial', 'pchip', 'akima', 'cubicspline'\]. Got 'not_a_method' instead.rO   not_a_methodmethod)r   r6   r	   r2   raises
ValueErrorr   r   r   rV   r   r   r   test_interp_bad_method   s   "z/TestDataFrameInterpolate.test_interp_bad_methodc                 C   s   t ddtjdgdddtjgg dtdd	}|d
  }tg dd
d}t|| d}tjt	|d |d
 jdd}W d    n1 sGw   Y  tg dd
d}t|| d S )NrI   rJ   rL   r/   r>   r?   r@   rB   rC   rD   rH   )name:The 'downcast' keyword in Series.interpolate is deprecatedrO   inferdowncastr/   r   rA   r>   )
r   r6   r	   rQ   r   r   r   r   rR   rS   )r   r   rW   r   rV   r   r   r   test_interp_combo   s    	z*TestDataFrameInterpolate.test_interp_comboc              	   C   s$  t ddtjdgdddtjgg dtdd	}d
}d}d}tjt|d% tjt	|d |j
dd W d    n1 s=w   Y  W d    n1 sLw   Y  tjt|d0 tjt	|d |d j
dd W d    n1 ssw   Y  W d    d S W d    d S 1 sw   Y  d S )NrI   rJ   rL   r/   r>   r?   r@   rB   rC   z'downcast must be either None or 'infer'=The 'downcast' keyword in DataFrame.interpolate is deprecatedrl   rO   int64rn   rD   )r   r6   r	   rQ   r2   rg   rh   r   rR   rS   r   )r   r   rV   msg2msg3r   r   r    test_inerpolate_invalid_downcast   s.   	"z9TestDataFrameInterpolate.test_inerpolate_invalid_downcastc                 C   sp   t ddtjdgtjdddgd}|d}d}tjt|d |jd	d
 W d    d S 1 s1w   Y  d S )Nr/   r   r>   rA   rD   rE   rD   zkInterpolation with NaNs in the index has not been implemented. Try filling those NaNs before interpolating.rO   r7   re   )r   r6   r	   r\   r2   rg   NotImplementedErrorr   ri   r   r   r   test_interp_nan_idx   s   "
"z,TestDataFrameInterpolate.test_interp_nan_idxc                 C   sV  t d tddtjddtjdgg dd}|d	}| }|jd
dd}d|jd< d|jd< t	
|| |jdd}d|jd< d|jd< t	
|| |jdd}d|jd< d|jd< t	j
||dd |jdd}d|jd< d|jd< t	
|| |jdd}d|jd< d|jd< t	
|| |jdd}d|jd< d|jd< t	j
||dd d S )Nscipyr/   r   r>   r      r/   r   rA   r            rD   rF   rF   
polynomialrf   ordergUUU@r[   gu:@)r~   rD   cubicre   gv:@gb+hZ@nearestF)check_dtype	quadraticg^r@g!g@slineargX ;@zerorJ   )r2   importorskipr   r6   r	   r\   r    r   r]   r   r   r   r   r   rW   r   r   r   test_interp_various   s<   













z,TestDataFrameInterpolate.test_interp_variousc                 C   s  t d tddtjddtjdgg dd}|jd	d
}| }d|jd< d|jd< t	|| d}tj
t|d |jd	dd}W d    n1 sLw   Y  t	||tj |jdd
}| }|d |d< t	|| |jdd
}d|jd< d|jd< t	|| d S )Nrz   r/   r   r>   r   r{   r|   r   barycentricre   rA   )r   rD      )r   rD   rr   rO   rm   )rf   ro   kroghrD   pchip      @)r2   r   r   r6   r	   r   r    r]   r   r   rR   rS   astypers   )r   r   rW   r   rV   	expectedkr   r   r   test_interp_alt_scipy   s,   




z.TestDataFrameInterpolate.test_interp_alt_scipyc                 C   s   t ddtjdgdddtjgtjdddgdtjddgg dd	}|jdd
}| }d|jd< d|jd< d|jd< |d tj|d< t	|| |jddd}t	|| |jdd
}| }t	|| d S )Nr/   r   r>   rA   r   r   r{   rp   )r   r/   r   rA   r>   axis)rA   r/   )r   r   )r/   rA   r7   r   rf   r   )
r   r6   r	   r   r    r]   r   float64r   r   ra   r   r   r   test_interp_rowwise  s(   	


z,TestDataFrameInterpolate.test_interp_rowwisezaxis_name, axis_numberrowsr   rows_0)idindexindex_0columnsr/   	columns_1c                 C   sZ   dt jdgdt jdgg dd}t|t jd}|j|dd	}|j|dd	}t|| d S )
Nr   r   r/   r{   )r   r   r}   )r   r/   r   r   linearr   )r6   r	   r   r   r   r   r   )r   	axis_nameaxis_numberdatar   rW   r   r   r   r   test_interp_axis_names2  s
    
z/TestDataFrameInterpolate.test_interp_axis_namesc              
   C   s:   t dddtjddtjtjdg	g dd}|jdd	 d S )
Nr         ?rI   r>   r}   @   )	r/   r   rA   r>   rA   r   r/   r   )r   r/   r   )r   r6   r	   r   )r   r   r   r   r   test_rowwise_altC  s   z)TestDataFrameInterpolate.test_rowwise_altcheck_scipyFTrz   )marksc                 C   sv   t tjtjdddgtjddtjdgd}| }| }d|jd	< t|| |r9|jd
dd}t|| d S d S )Nr   g      ?r   g      rw   g      )rA   rE   r   r/   r   )r   r6   r	   r   r    r]   r   r   )r   r   r   rW   r   r   r   r   test_interp_leading_nansM  s   $
z1TestDataFrameInterpolate.test_interp_leading_nansc                 C   s   t ddtjdgg dtjdddgtjtjddgg dd	}d
}tjt|d |dj|d W d    d S 1 s<w   Y  d S )Nr/   r   r>   )abr
   dr   r{   r?   rp   )rD   rE   rF   rG   EvCannot interpolate with all object-dtype columns in the DataFrame. Try setting at least one column to a numeric dtype.rO   objectr   )r   r6   r	   r2   rg   	TypeErrorr   r   )r   r   r   rV   r   r   r   test_interp_raise_on_only_mixed]  s   
"z8TestDataFrameInterpolate.test_interp_raise_on_only_mixedc                 C   sZ   t g dg dddd}d}tjt|d |  W d    d S 1 s&w   Y  d S )N)r/   r   rA   )r>   r   r   rw   r   r   r   rO   )r   r2   rg   r   r   ri   r   r   r   %test_interp_raise_on_all_object_dtypeo  s   
"z>TestDataFrameInterpolate.test_interp_raise_on_all_object_dtypec                 C   s  t dddtjdgi}t dg di}| }| }|rFt  |d jdd}W d    n1 s4w   Y  |d u s?J t|| n+tjt	dd	 |d jdd}W d    n1 s`w   Y  |d u skJ t|| | }d
}|rtjt	t
f|d	 |d jddd}W d    n1 sw   Y  |d u sJ t|| d S tjt	|d	 |d jddd}W d    n1 sw   Y  |d u sJ t||d d S )Nr   rI   rJ   rL   rH   Tr0   zinplace methodrO   rl   rm   )r1   ro   rs   )r   r6   r	   r    r   raises_chained_assignment_errorr   r   rR   rS   r   r   )r   rU   r   r   expected_cowrW   return_valuerV   r   r   r   test_interp_inplacez  s<   
z,TestDataFrameInterpolate.test_interp_inplacec                 C   s^   t g dtjdddgg dd}|jddd	d
}|jdddd
}|d u s'J t|| d S )NrH   rJ   rK   rL   )rA   r   r   r   )r   r   r
   r   r/   F)rf   r   r1   T)r   r6   r	   r   r   r   )r   rW   r   r   r   r   r   test_interp_inplace_row  s   z0TestDataFrameInterpolate.test_interp_inplace_rowc                 C   s  t ddtjdgg dddtjdgg dd	}t tjg dd
dtjg dddtjg dd
dtjg dd
dd	}d}tjt|d |jd d}W d    n1 sVw   Y  t|| tjt|d |ddg jd d}W d    n1 s}w   Y  t||ddg  d S )Nr/   r   r>   rp   rI   rJ   rL   rH   rC   r   r   rs   )rI   rJ   rA   rL   rr   rO   rn   rE   rG   )	r   r6   r	   arrayr   rR   rS   r   r   )r   r   r   rV   rW   r   r   r   test_interp_ignore_all_good  s.   	z4TestDataFrameInterpolate.test_interp_ignore_all_goodc                 C   s|   d}t d|d}tjd||f}tj||dk < t|||d}|jddd	}|jddd
d}|d u s6J t|| d S )Nr   z
2014-01-01)startr   r   r   )r   r   r   r   timer   T)r   rf   r1   )	r   r6   randomdefault_rngr	   r   r   r   r   )r   r   idxr   r   rW   r   r   r   r   test_interp_time_inplace_axis  s   z6TestDataFrameInterpolate.test_interp_time_inplace_axis)r   r   )r   r/   c                 C   sl   t ddd}t |}tt |dt d|dj|d d}|jd	|d
}|jd	|d
}t	|| d S )Nr   d   i  )
   r/   r   )r   r   r   gGz?)r   r   rf   r   )
r6   linspacesinr   tilearangereindexr   r   r   )r   r   r   xyr   rW   r   r   r   r   test_interp_string_axis  s   
z0TestDataFrameInterpolate.test_interp_string_axis
multiblockrf   )ffillbfillpadc              	   C   s   |r|dv rt | tddddtjdgdddtjdd	gddd
tjtjdgd}|r4tj|d< d|d< |dkr:|nd}t|||d}d| d}	tjt|	d |j	||d}
W d    n1 scw   Y  t
|
| d S )N)r/   r   rI   rJ   rK   rL   g      @r   g       @g      $@rM   g      >@rc   rG   r   r   r   r   z"DataFrame.interpolate with method=z is deprecatedrO   r   )td&mark_array_manager_not_yet_implementedr   r6   r	   getattrr   rR   rS   r   r   )r   r;   r   r   rf   r:   r   method2r   rV   rW   r   r   r   test_interp_fillna_methods  s$   

z3TestDataFrameInterpolate.test_interp_fillna_methodsc                 C   s6   t  }| }|jdd}|d u sJ t|| d S )NTr0   r   r    r   r   r   r   r   r   r   test_interpolate_empty_df  s
   z2TestDataFrameInterpolate.test_interpolate_empty_dfc                 C   sX   t dg di|d}| }|jdd}t dg didd}t|| t|| d S )Nr   r/   NNNrA   r   r   limitr/   r   rJ   NrA   Float64r   )r   any_int_ea_dtyper   r%   rW   r   r   r   r   test_interpolate_ea  s   z,TestDataFrameInterpolate.test_interpolate_ear   r   Float32zfloat32[pyarrow]pyarrowfloat64[pyarrow]c                 C   sX   t dg di|d}| }|jdd}t dg di|d}t|| t|| d S )Nr   r   r   r   r   r   r   )r   r   r   r%   rW   r   r   r   r   test_interpolate_ea_float  s   z2TestDataFrameInterpolate.test_interpolate_ea_float)rs   uint64int32int16int8uint32uint16uint8c                 C   sR   t d tdg di|d d}|jdd}tdg did	d}t|| d S )
Nr   r   r   z	[pyarrow]r   r   r   r   r   )r2   r   r   r   r   r   )r   r   r   rW   r   r   r   r   test_interpolate_arrow  s
   
z/TestDataFrameInterpolate.test_interpolate_arrowN)'__name__
__module____qualname__r   r,   r=   r2   r3   r4   r   rZ   r`   rb   rj   rq   rv   ry   r   r   r   parametrizeparamr   r   r   
skip_if_nor   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r      sx    
)

'
	

!

	
		r   )numpyr6   r2   pandas._configr   pandas.errorsr   pandas.util._test_decoratorsutil_test_decoratorsr   pandasr   r   r   r   pandas._testing_testingr   r   r   r   r   r   <module>   s    