U
    -e                     @   s  d 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	 ddl
ZddlZddlmZ ddlmZ ddlZddlmZ ddlmZ dd	lmZ dd
lmZ ddlmZmZ ddlmZ ddlm Z  ddl!m"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- ddl.m/Z/m0Z0 ddl1m2Z2m3Z3m4Z4m5Z5m6Z6m7Z7m8Z8m9Z9m:Z: ddl;m<Z< ddl=m>Z> ddl?m@Z@mAZAmBZBmCZCmDZDmEZEmFZFmGZGmHZHmIZImJZJmKZKmLZLmMZMmNZNmOZOmPZPmQZQmRZRmSZS dd ZTejUVdejWWdeXddY gdd ZZdd  Z[d!d" Z\d#d$ Z]ejUVd%ej^d&fej_d'fej_d&fgejUVd(ej`ejagd)d* ZbejUVd+ej^d,d-d.fej^dd-d/fej^d0d-d1fej^dd'd/fej_d,d-d2fej_dd-d3fej_d4d-d5fej_d,d6d7fej_d,d8d2fg	ejUVd(ej`ejagd9d: ZcejUVd;dd4d0gejUVd(ej`ejagd<d= Zdd>d? ZeejUVd@efd8ej_ggdAfefd8ej_ggdAfefd8ej^ggdBfejfd8ej_ggegdCdDfgejUVdEd-d&gdFdG Zhe9dHdI ZiejUVddJdKgdLdMggejfdJdKgdLdMggdNdCejfdJdKgdLdMggdOdCdPdQgdRdSggejfdPdQgdRdSggdTdCgdUdV ZjejUVdWdXdYdZd[d\d]gejUVd^ejkejlgejkfejlejlfd_ejlfgd`da Zmdbdc Znddde Zodfdg Zpdhdi Zqdjdk Zrdldm Zsdndo Ztejudpdqdrdsgdtdudv Zvdwdx Zwdydz Zxd{d| Zyd}d~ Zzdd Z{dd Z|dd Z}dd Z~dd ZejUjVdedeegdddgddd Zdd Zdd Zdd Zdd ZejUVdejlejkfejldd_fejUVdddd Zdd Zdd ZG dd dZG dd dZdd ZejUVdd-d&gdd ZejUVd(ej`ejaejejejejejejgdd Zdd Zdd ZejUVdddddgdd ZejUVdd8dedddedfddejdddedfddejdddedfd8deefdddedfd8dedddedfddedddedfddedddedăfddedddedǃfddedddedʃfddeddded̃fddeddded΃fgddЄ Zdefd8dgdd,fefd8dgefd8dgdd,fdefddgedfdefddged,fejfd8dgejkdCejfd8dgejkdCedfejfd8dgejldCejfd8dgejldCedfdefddgedfdۜZejUjVdee ee dejUVdd-d&gdd߄ ZdedfdedfdedfejfddgejkdCedfejfddgejldCedfdZejUjVdee ee ddd Zdd ZejUVdejfejaejgdd ZejUVdejfejaejgdd ZejUVdejaejgdd Zdd Zdd Zdd ZejUVddd8dggdd ZejUVd d-dpdqdrdsgdd ZejUVddddddd	d
ddg	dd ZejUVdddejfddejfddejfddejfddejfddejfddejfddejfddejfdd ejfd!dejfd"d#ejfd$d%ejfd&d'ejfd(d)ejfd*d+ejfgd,d- ZejUVd.ddd/d0d1d2gd3d4 ZejUjVdd8ddgd5d6d7gd&d-d&gd8d9d:gd5d8id6did7diggdd;d<d=d>gdejUVd.ddd/d?gd@dA ZejUjVdd8d6d&dBgdd;d<d=gddCdD ZejUjVdEeededdd5d6gd7dFgggdGdHdIdJgddKdL ZdMdN ZdOdP ZejUjVdQd5d8gdRfdSd5d6ggdTfgdUdVgddWdX ZG dYdZ dZeZd[d\ Zd]d^ Zd_d` ZejUVdadbdcddgdedf Zdgdh Zdidj ZejUVdkdd8dd8dej_gdd8dd8dd8ggdldm Ze:ejUVdndodpgdqdr ZejUVdsdtdudvdwgejUVdxd-d&gdydz ZdS ({  z$Tests for input validation functions    N)product)
itemgetter)NamedTemporaryFile)importorskip)config_context)BaseEstimator)
make_blobs)RandomForestRegressor)NotFittedErrorPositiveSpectrumWarning)ARDRegression)EstimatorWithFit)KNeighborsClassifier)_sparse_random_matrix)SVR)_safe_indexingas_float_arraycheck_arraycheck_symmetric	check_X_y
deprecated)MockDataFrame_MockEstimatorOnOffPrediction)	SkipTest
TempMemmap_convert_containerassert_allcloseassert_allclose_dense_sparseassert_array_equalassert_no_warningsignore_warnings'skip_if_array_api_compat_not_configured)_NotAnArray)parse_version)FLOAT_DTYPES_allclose_dense_sparse_check_feature_names_in_check_fit_params_check_psd_eigenvalues_check_response_method_check_sample_weight_check_y_deprecate_positional_args_get_feature_names
_is_fitted_num_features_num_samplesassert_all_finitecheck_consistent_lengthcheck_is_fittedcheck_memorycheck_non_negativecheck_scalarhas_fit_parameterc                  C   s  t jdt jd} | t jdt jd } t| dd}|jt jks@t| t j	} t| dd}t| dd| k	slt|jt j
ks|ttt jt jt jt jt jt jg}|D ]&}| |} t| }|jt jkstq| t} t| dd}|jt j
kstt jdt jd} t| dd| kstt | } t t| dds4ttt d tddd	d
 g}|D ]0}t|dd}t j|d< t | r^tq^d S )N)   
   dtyper9   FcopyT)r8         皙?)Zdensityr   r   )nponesint32aranger   r;   float32AssertionErrorastypeint64float64boolint8int16uint8uint16uint32objectZasfortranarrayZ	isfortransp
csc_matrixtoarrayr   nanisnanany)XZX2Ztested_dtypesr;   ZmatricesMN r[   d/var/www/html/Darija-Ai-Train/env/lib/python3.8/site-packages/sklearn/utils/tests/test_validation.pytest_as_float_arrayM   s6    



r]   rX   r9   r>   r9   r>   c                 C   s.   t j| d< t j| d< t| dd}t||  d S )N)r?   r   )      	allow-nanforce_all_finite)rB   rU   r   r   )rX   ZX_convertedr[   r[   r\   test_as_float_array_nanw   s    

rd   c                  C   sD   t ddd} tt| t jr&tttt| t jr@td S )N   r8      )	rB   rE   reshape
isinstancer   matrixrG   rR   rS   rX   r[   r[   r\   test_np_matrix   s    rk   c               	   C   s   dd } t ddh}tj|dtjd}d|d d < ttj| fD ]6}||}d|d d < t| |  d|d d < q>W 5 Q R X d S )	Nc                 S   s   t | ddS )NFr<   )r   )xr[   r[   r\   <lambda>       ztest_memmap.<locals>.<lambda>zsklearn-test)prefix)r9   r9   )shaper;   r   r`   )r   rB   ZmemmaprF   r   asarrayr   Zravel)ZasflttmprY   frX   r[   r[   r\   test_memmap   s    rt   c                  C   s   t d} | | jfD ]V}dD ]L}t|d|d}|jd s<tt|d|d}|jd sXt|r||k	stqqt| } | jd d d | _| jjd rtd S )	N)r9   r?   )TFC)orderr=   C_CONTIGUOUSFF_CONTIGUOUS)	rB   rC   Tr   flagsrG   rR   
csr_matrixdata)rX   Ar=   Br[   r[   r\   test_ordering   s    

r   zvalue, force_all_finiteFra   retypec                 C   s@   |t dddt}| |d< t||dd}t|| d S )Nrf   r>   rA   T)rc   accept_sparse)rB   rE   rg   rH   floatr   r   )valuerc   r   rX   	X_checkedr[   r[   r\   'test_check_array_force_all_finite_valid   s    r   z.value, input_name, force_all_finite, match_msg TzInput contains infinityzInput X contains infinitysample_weightz%Input sample_weight contains infinityInput contains NaNzInput X contains NaNyzInput y contains NaNz	allow-infz0force_all_finite should be a bool or "allow-nan"r`   c              	   C   sT   |t dddt j}| |d< tjt|d t|||dd W 5 Q R X d S )Nrf   r>   rA   matchT)
input_namerc   r   )	rB   rE   rg   rH   rJ   pytestraises
ValueErrorr   )r   r   rc   Z	match_msgr   rX   r[   r[   r\   (test_check_array_force_all_finiteinvalid   s    r   r   c              	   C   s   |t dddt j}t j|d< t }d|jj d}t	j
td|  dd}t||| d	d
 W 5 Q R X | dkr||jjd kstn||jjd kst| dkrt	j
td|  dd }t |t |jd  W 5 Q R X ||jjd kstd S )Nrf   r>   rA   
aX   does not accept missing values encoded as NaN natively. For supervised learning, you might want to consider sklearn.ensemble.HistGradientBoostingClassifier and Regressor which accept missing values encoded as NaNs natively. Alternatively, it is possible to preprocess the data, for instance by using an imputer transformer in a pipeline or drop samples with missing values. See https://scikit-learn.org/stable/modules/impute.html You can find a list of all estimators that handle NaN values at the following page: https://scikit-learn.org/stable/modules/impute.html#estimators-that-handle-nan-valueszInput z contains NaNr   T)	estimatorr   r   rX   r   )rB   rE   rg   rH   rJ   rU   r   	__class____name__r   r   r   r   r   argsrG   fitrC   rp   )r   r   r~   r   Zextended_msgctxr[   r[   r\   0test_check_array_links_to_imputer_doc_only_for_X   s&    
$r   c               	   C   sz   t jddt jggtdj} t| d dd}| |ks4tt| d dd}| |ksNttjt	dd t| d d	d W 5 Q R X d S )
Nabr:   ra   r;   rc   Fr   r   T)
rB   arrayrU   rQ   r{   r   rG   r   r   r   )rX   r   r[   r[   r\   (test_check_array_force_all_finite_object  s    r   z
X, err_msgInput contains NaN.z5Input contains infinity or a value too large for.*intr:   z#cannot convert float NaN to integerrc   c              	   C   s,   t jt|d t| t|d W 5 Q R X d S )Nr   r   )r   r   r   r   int)rX   err_msgrc   r[   r[   r\   7test_check_array_force_all_finite_object_unsafe_casting  s    r   c               	   C   s  ddgddgg} t | }tt t| W 5 Q R X tdddgdd}|jdksXttjtdd	 tdddgd
d W 5 Q R X tjtdd	 tdd
d W 5 Q R X t	
dddd}tt t| W 5 Q R X t|d
d t	
dddd}|d}|t}|t}||||g}t	jttt	jd ttg}	ddd g}
d
dg}t||	|
|D ] \} }}}t| |||d}|d k	r|j|kstn|j| jkst|dkr|jd st|jd rtn*|dkr|jd st|jd rt|r| |k	s`tnH| j|jkr`|jd | jd kr`|jd | jd kr`| |ks`tq`t |}| }| }|t}|t}|||||g}ddgddgg}dd |	D }t||||D ]\} }}}t| |||d}|d k	r|j|kstn|j| jkst| j|kr6| j|jksJtn|j|d ksJt|r`| |k	stn*| j|jkr| j|jkr| |kstqtddgddgg}t|t	jsttt t|  W 5 Q R X t| d
d t|}t|}t|t	jstd S )Nr`   r>   r8   rf   r   F	ensure_2dz'Expected 2D array, got 1D array insteadr   Tz+Expected 2D array, got scalar array insteadr9      allow_ndru   rx   )r;   rv   r=   rw   ry   csrcoodokc                 S   s   g | ]}|t k	r|qS r[   )rQ   ).0dtr[   r[   r\   
<listcomp>p  s      z$test_check_array.<locals>.<listcomp>r;   r   r=   )rR   r}   r   r   	TypeErrorr   ndimrG   r   rB   rE   rg   r=   rH   r   r   rD   rF   rK   rQ   r   r;   r|   rS   ZtocooZtodokformatrh   Zndarraytolistr"   )rX   X_csrZX_arrayZX_ndimZX_CZX_FZX_intZX_floatZXsdtypesZordersZcopysr;   rv   r=   r   ZX_cscZX_cooZX_dokZaccept_sparsesZnon_object_dtypesr   ZX_denseZ
X_no_arrayresultr[   r[   r\   test_check_array*  s    











   
r   1234US   1   2   3   4ZV1c              	   C   s.   d}t jt|d t| dd W 5 Q R X dS )zmTest that check_array errors when it receives an array of bytes/string
    while a numeric dtype is required.z>dtype='numeric' is not compatible with arrays of bytes/stringsr   numericr:   Nr   r   r   r   )rX   Zexpected_msgr[   r[   r\   test_check_array_numeric_error  s    r   pd_dtypeZInt8ZInt16ZUInt8ZUInt16Float32Float64zdtype, expected_dtyper   c              	   C   s   t d}| dkr t jddd}tdddtjtjgtjtjdd	d
gdddd	dggj}|j|| dddgd}|d d|d< t|d|d}t	|| |j
|kstt|d|d}t	|| |j
|kstd}t jt|d t|dd W 5 Q R X d S )Npandas>   r   r   z1.2Z
minversionr`   r>   r8   r   rf   r_   r?   r   r   c)r;   columnsr   ra   )rc   r;   Fr   r   Trb   )r   r   rB   r   rU   r{   	DataFramerH   r   r   r;   rG   r   r   )r   r;   Zexpected_dtypepdZX_nprX   r   msgr[   r[   r\   "test_check_array_pandas_na_support  s"    
.

r   c               	   C   s   t d} | jdd| jgdd}d}t jt|d t|dd	d
 W 5 Q R X t|d	d	d
}t|ddtj	g |j
tjks|tt|d	d	tjd}t|ddtj	g |j
tjkstdS )z4Check check_array is correct with pd.NA in a series.r   r`   r>   Int64r:   r   r   TF)rc   r   )rc   r   r;   N)r   r   SeriesZNAr   r   r   r   rB   rU   r;   rJ   rG   rF   )r   X_int64r   ZX_outr[   r[   r\   *test_check_array_panadas_na_support_series  s     
   r   c                  C   s  t d} tjdddgdddgdd	d
ggtjd}| |}t|jtjksPtt|t	djtjksht|
dtji}t|jtjtjtjf t|jtjkstt|t	djtjkst|
dtji}t|jtjkstt|t	djtjkst|
dtji}t|jtjkstt|t	djtjks8t|
tj}t|jtjksZtt|t	djtjkstt| d| dddgi}t|jtjkstt|t	djtjkstd S )Nr   r`   r>   r8   rf   r?   r_      r   	   r:   r   Zcat_col)r   r   rB   r   rF   r   r   r;   rG   r$   rH   float16r   r   rM   rJ   ZCategoricalrI   )r   rX   X_dfZcat_dfr[   r[   r\   %test_check_array_pandas_dtype_casting  s*    
(
r   c                  C   sj   t ddgddgddgddgg} t| }t|}|j| jksBtt|t jd}|jt t jksftd S )Ng?gffffff?g333333?g      ?g?r@   r:   )rB   r   r   r   r;   rG   rF   )arrZmock_dfZchecked_arrr[   r[   r\   "test_check_array_on_mock_dataframe	  s    "r   c                  C   sL   dddgdddgddd	gg} t | jjd
ks0tt | ddjjd
ksHtd S )Nr`   r>   r8   rf   r?   r_   r   r   r   iFr   )r   r;   kindrG   rj   r[   r[   r\    test_check_array_dtype_stability  s    r   c            
      C   sj  dddgdddgddd	gg} t j| t jd
}t j| t jd
}t|}t|}tj|t jd
}||g}|||g}|D ]&}tt	|t j
dd}	|	jt j
ksvtqv|D ]t}tt	|t j
t jgdd}	|	jt jkst|	|ksttt	|t j
t jgddgdd}	|	jt jks
t|	|k	stqtt	|t j
t jgddgdd}	|	jt jksHt|	|k	sVt|	jdksftd S )Nr`   r>   r8   rf   r?   r_   r   r   r   r:   T)r;   r   r   r   r   F)rB   rq   rF   rI   rR   r}   rS   rD   r   r   rJ   r;   rG   r   )
Z
X_int_listZ	X_float32r   ZX_csr_float32ZX_csc_float32ZX_csc_int32Zinteger_dataZfloat32_datarX   r   r[   r[   r\   test_check_array_dtype_warning  sX    


     
 

r   c               	   C   s   ddgddgg} t | }t }d}tjt|d t|dd W 5 Q R X d	}tjt|d t||d W 5 Q R X d
}tjt|d t|g d W 5 Q R X tjt|d t|dd W 5 Q R X tjtdd t||gd W 5 Q R X d S )Nr`   r>   r8   rf   zlA sparse matrix was passed, but dense data is required. Use X.toarray\(\) to convert to a dense numpy array.r   Fr   zjParameter 'accept_sparse' should be a string, boolean or list of strings. You provided 'accept_sparse=.*'.z]When providing 'accept_sparse' as a tuple or list, it must contain at least one string value.r[   r   )rR   r}   r   r   r   r   r   r   )rX   r   Zinvalid_typer   r[   r[   r\   -test_check_array_accept_sparse_type_exceptionE  s&    
r   c                  C   sP   ddgddgg} t | }t|dd t|dd t|dgd t|dd d S )	Nr`   r>   r8   rf   Tr   r   )r   )rR   r}   r   )rX   r   r[   r[   r\   +test_check_array_accept_sparse_no_exceptiond  s    
r   r   cscr   bsr)paramsc                 c   sH   t jdd| jd}dD ]&}t||rt||t||d q|V  d S )N   r9   )r   )indicesZindptrrowcolrI   )rR   randparamhasattrsetattrgetattrrH   )requestrX   attrr[   r[   r\   X_64bitn  s
    
r   c                 C   s   t | ddd d S )NT)accept_large_sparser   )r   )r   r[   r[   r\   1test_check_array_accept_large_sparse_no_exceptionw  s    r   c              	   C   s0   d}t jt|d t| ddd W 5 Q R X d S )NzbOnly sparse matrices with 32-bit integer indices are accepted. Got int64 indices. Please do reportr   TF)r   r   r   )r   r   r[   r[   r\   4test_check_array_accept_large_sparse_raise_exception|  s    r   c               	   C   s  d} t jt| d tg g W 5 Q R X d} t jt| d tg dd W 5 Q R X d} t jt| d tddd W 5 Q R X td}td	}d
} t jt| d t||dd W 5 Q R X t jt| d t||ddd W 5 Q R X td}td}d} t jt| d t||dd W 5 Q R X t jt| d t||ddd W 5 Q R X td	dd}td}d} t jt| d t|| W 5 Q R X td}td}t||dd\}}t
|| t
|| d S )NzC0 feature\(s\) \(shape=\(1, 0\)\) while a minimum of 1 is required.r   z@0 sample\(s\) \(shape=\(0,\)\) while a minimum of 1 is required.Fr   zDSingleton array array\(42\) cannot be considered a valid collection.*   )r`   r9   r`   zC1 sample\(s\) \(shape=\(1, 10\)\) while a minimum of 2 is required.r>   )ensure_min_samples)r   r   r^   zD2 feature\(s\) \(shape=\(10, 2\)\) while a minimum of 3 is required.r8   )ensure_min_featuresT)r   r   r   r9   zD0 feature\(s\) \(shape=\(10, 0\)\) while a minimum of 1 is required.)r9   r      r   r   )r   r   r   r   r   rB   rC   r   emptyrg   r   )r   rX   r   r   Z	y_checkedr[   r[   r\   2test_check_array_min_samples_and_features_messages  sB    







r   c               	   C   s  t dddgdddgg} tjtdd t|  W 5 Q R X dddgdddgg} tjtdd t|  W 5 Q R X d	} tjtdd t|  W 5 Q R X t dddgt dddgg} tjtdd t|  W 5 Q R X t dddgt dddgf} tjtdd t|  W 5 Q R X tt dddgdddgg} tjtdd t|  W 5 Q R X td
dgd
d
gg} tjtdd t|  W 5 Q R X t ddddddg}tjtdd t	| W 5 Q R X d S )N      ?       @      @      @      @      @       @      @      @      @      @      @zComplex data not supportedr   ))r   r   r   )r   r   r   r   )
rB   r   r   r   r   r   r   rR   
coo_matrixr+   )rX   r   r[   r[   r\   #test_check_array_complex_data_error  s0      r  c                  C   s^   t tdrtt tdstt tds*tt t ds:tG dd d} t | dsZtdd S )Nr   c                   @   s   e Zd ZeddddZdS )z@test_has_fit_parameter.<locals>.TestClassWithDeprecatedFitMethodz7Deprecated for the purpose of testing has_fit_parameterNc                 S   s   d S Nr[   )selfrX   r   r   r[   r[   r\   r     s    zDtest_has_fit_parameter.<locals>.TestClassWithDeprecatedFitMethod.fit)N)r   
__module____qualname__r   r   r[   r[   r[   r\    TestClassWithDeprecatedFitMethod  s   r  z=has_fit_parameter fails for class with deprecated fit method.)r7   r   rG   r	   r   )r  r[   r[   r\   test_has_fit_parameter  s     r  c               
   C   s$  t ddgddgg} t d}t ddgddgg}|t|t|t|t|t|t	|d}t
t t| W 5 Q R X | D ]\}}t
t t| W 5 Q R X t
t t|dd W 5 Q R X t|dd}t|r|j|kstt| |  qt||  qd S )	Nr   r`   r>   )Zdenser   r   r   r   Zlilr   T)Zraise_exceptionF)Zraise_warning)rB   r   rC   rR   
dok_matrixr}   rS   r   
lil_matrix
bsr_matrixr   r   r   r   itemswarnsUserWarningissparser   rG   r   rT   )Zarr_symZarr_badZarr_asymZtest_arraysZ
arr_formatr   outputr[   r[   r\   test_check_symmetric  s.    
r  c               	   C   sB   G dd dt } tt t|   W 5 Q R X t|    d S )Nc                   @   s   e Zd Zdd Zdd ZdS )z6test_check_is_fitted_with_is_fitted.<locals>.Estimatorc                 [   s
   d| _ | S )NT)r.   )r  kwargsr[   r[   r\   r     s    z:test_check_is_fitted_with_is_fitted.<locals>.Estimator.fitc                 S   s   t | do| jS )Nr.   )r   r.   r  r[   r[   r\   __sklearn_is_fitted__#  s    zLtest_check_is_fitted_with_is_fitted.<locals>.Estimator.__sklearn_is_fitted__N)r   r  r  r   r  r[   r[   r[   r\   	Estimator  s   r  )r   r   r   r
   r3   r   )r  r[   r[   r\   #test_check_is_fitted_with_is_fitted  s    r  c               	   C   sF  t t tt W 5 Q R X t t td W 5 Q R X t } t }z@t t t|  W 5 Q R X t t t| W 5 Q R X W n  tk
r   dstdY nX d}d}t jt|d t| |d W 5 Q R X d}d	}t jt	|d t||d W 5 Q R X | j
t   |j
t   t| d ks0tt|d ksBtd S )
Nr   Fz&check_is_fitted failed with ValueErrorz!Random message %(name)s, %(name)sz+Random message ARDRegression, ARDRegressionr   )r   z"Another message %(name)s, %(name)szAnother message SVR, SVR)r   r   r   r3   r   r   r
   r   rG   AttributeErrorr   r   )ardZsvrr   r   r[   r[   r\   test_check_is_fitted+  s2    r  c               	   C   s  G dd d} d}|  }t |ddgdr,ttjt|d t|ddgd W 5 Q R X t |ddgtdrlttjt|d t|ddgtd W 5 Q R X t |ddgtdrttjt|d t|ddgtd W 5 Q R X d	|_t |ddgdrttjt|d t|ddgd W 5 Q R X t |ddgtdr6ttjt|d t|ddgtd W 5 Q R X t |ddgtdsztt|ddgtd d
|_	t |ddgdstt|ddgd t |ddgtdstt|ddgtd t |ddgtdstt|ddgtd d S )Nc                   @   s   e Zd Zdd ZdS )z4test_check_is_fitted_attributes.<locals>.MyEstimatorc                 S   s   | S r  r[   r  rX   r   r[   r[   r\   r   Q  s    z8test_check_is_fitted_attributes.<locals>.MyEstimator.fitN)r   r  r  r   r[   r[   r[   r\   MyEstimatorP  s   r  z
not fitteda_b_)
attributesr   )r  Z
all_or_anyr   r   )
r.   rG   r   r   r
   r3   allrW   r  r  )r  r   estr[   r[   r\   test_check_is_fitted_attributesO  s8    r   wrapZsinglelisttuple)Zidsc              	   C   sz   t  }tjtdd t|| dg W 5 Q R X |jt   t|| dg tjtdd t|| dg W 5 Q R X d S )Nzis not fitted yetr   Zcoef_Z	coef_bad_)r   r   r   r
   r3   r   r   )r!  r  r[   r[   r\   $test_check_is_fitted_with_attributest  s    r$  c                	   C   s.  t dgdgdgdgdg t ddgddgggddgddg t dgdtdgtd	 tjtd
d t ddgdg W 5 Q R X tjtdd t ddgd W 5 Q R X tjtdd t ddgt	  W 5 Q R X tt t ddgtd W 5 Q R X tjtdd t ddgt
  W 5 Q R X d S )Nr`   r>   r8   rf   r?   r   r   )r>   r`   r>   zinconsistent numbers of samplesr   zgot <\w+ 'int'>zgot <\w+ 'object'>Expected sequence or array-like)r2   rB   r   rR   r}   r   r   r   r   rQ   r	   r[   r[   r[   r\   test_check_consistent_length  s    "r'  c                  C   sl   zJdd l } tdddgdddgdd	d
gg}| j|dddgd}t| W n tk
rf   tdY nX d S )Nr   r`   r>   r8   rf   r?   r_   r   r   r   r   r   r   r   zPandas not found)r   rB   r   r   r2   ImportErrorr   )r   rX   r   r[   r[   r\   "test_check_dataframe_fit_attribute  s    "r*  c               	   C   sp   t dt jg} tt t|  W 5 Q R X tjdd t|  tjdd tt t|  W 5 Q R X d S )Nr   T)Zassume_finiteF)	rB   r   infr   r   r   r1   sklearnZ
set_configrj   r[   r[   r\   test_suppress_validation  s    r-  c                  C   sx   t d} t| dddgdd}t|tdddg | ddd	gd
}t|d dd}t|tjddd	gtd d S )Nr   r`   r>   r8   Fr   r   r   r   category)r;   r   r:   )r   r   r   r   rB   r   rH   rQ   )r   ressr[   r[   r\   test_check_array_series  s    r1  r;   
bool_dtype)rK   booleanc                 C   s   |dkrt ddd}nt d}|jdddgdd	d
g|jdddg|dddddgd}t|| d}|jtjksrttjdddgdd	dgdd
dggt	d}t
|| d S )Nr3  r   1.0r   r`   r>   r8   r   r@   g @TFr:   )r   r   rK   r   r   rK   r(        ?               @      @)r   r   r   r   r;   rB   rJ   rG   r   r   r   )r;   r2  r   dfr   Zexpected_arrayr[   r[   r\   'test_check_dataframe_mixed_float_dtypes  s"    	 r:  c                  C   s   t d} | ddddgi}t|dd}|jtjks8tt|dgdgdgg | jdddgddd	gd
ddgd}t|dd}|jtjkstt|ddgddgdd	gg dS )z7Check that dataframe with bool return a boolean arrays.r   rK   TFNr:   r`   r>   r8   )rK   r   r   r(  r   r   )	r   r   r   r;   rB   Zbool_rG   r   rI   r   r9  r   r[   r[   r\   #test_check_dataframe_with_only_bool  s    r<  c                  C   s`   t ddd} | d| jdddgddi}t|d	d}|jtjksFtt|dgdgdgg d	S )
zFCheck that dataframe with boolean return a float array with dtype=Noner   r4  r   rK   TFr3  r:   N)	r   r   r   r   r;   rB   rJ   rG   r   r;  r[   r[   r\   &test_check_dataframe_with_only_boolean  s
    r=  c                   @   s   e Zd Zdd ZdS )DummyMemoryc                 C   s   |S r  r[   )r  funcr[   r[   r\   cache  s    zDummyMemory.cacheN)r   r  r  r@  r[   r[   r[   r\   r>    s   r>  c                   @   s   e Zd ZdS )WrongDummyMemoryN)r   r  r  r[   r[   r[   r\   rA    s   rA  c               	   C   s   t d} | jdkstt d } | jd ks,tt }t |} | |ksFtd}tjt|d t d W 5 Q R X t }d|}tjt|d t | W 5 Q R X d S )NZcache_directoryzf'memory' should be None, a string or have the same interface as joblib.Memory. Got memory='1' instead.r   r`   zg'memory' should be None, a string or have the same interface as joblib.Memory. Got memory='{}' instead.)	r4   locationrG   r>  r   r   r   rA  r   )Zmemorydummyr   r[   r[   r\   test_check_memory  s$    rD  r=   c              	   C   sZ   t d}t|dd:}t|| d}t |||  ks:t|jd | ksLtW 5 Q R X d S )N)rf   rf   r)Z	mmap_moder<   Z	WRITEABLE)rB   rC   r   r   Zmay_share_memoryrG   r|   )r=   rX   ZX_memmapr   r[   r[   r\   test_check_array_memmap   s
    
rF  c              	   C   s   t ddddgddddgddddgddddgg}| |}t|d | ddgddgg}t|d d|d< | |}tjtdd t|d W 5 Q R X d S )Nr`   r   r   rz   rA   z	Negative r   )rB   r   r5   r   r   r   )r   r   rX   r[   r[   r\   test_check_non_negative)  s    2

rG  c               	   C   sh   t d} d }d}tjt|d t| | W 5 Q R X d}tjt|d t| |t d W 5 Q R X d S )Nr>   r>   z;estimator requires y to be passed, but the target y is Noner   zGRandomForestRegressor requires y to be passed, but the target y is None)r   )rB   rC   r   r   r   r   r	   )rX   r   r   r[   r[   r\    test_check_X_y_informative_errorC  s    
rI  c               	   C   s^   G dd d} |  }t |t|ks(tG dd d}tjtdd t |  W 5 Q R X d S )Nc                   @   s   e Zd Zdd Zdd ZdS )zJtest_retrieve_samples_from_non_standard_shape.<locals>.TestNonNumericShapec                 S   s
   d| _ d S N)znot numericrp   r  r[   r[   r\   __init__Q  s    zStest_retrieve_samples_from_non_standard_shape.<locals>.TestNonNumericShape.__init__c                 S   s   t dddgS )Nr`   r>   r8   )lenr  r[   r[   r\   __len__T  s    zRtest_retrieve_samples_from_non_standard_shape.<locals>.TestNonNumericShape.__len__N)r   r  r  rL  rN  r[   r[   r[   r\   TestNonNumericShapeP  s   rO  c                   @   s   e Zd Zdd ZdS )zJtest_retrieve_samples_from_non_standard_shape.<locals>.TestNoLenWeirdShapec                 S   s
   d| _ d S rJ  rK  r  r[   r[   r\   rL  \  s    zStest_retrieve_samples_from_non_standard_shape.<locals>.TestNoLenWeirdShape.__init__N)r   r  r  rL  r[   r[   r[   r\   TestNoLenWeirdShape[  s   rP  r&  r   )r0   rM  rG   r   r   r   )rO  rX   rP  r[   r[   r\   -test_retrieve_samples_from_non_standard_shapeO  s    rQ  rl   r8   g      @r?   c              	   C   sD   t  & t d t| dtjdddd}W 5 Q R X || ks@tdS )zPTest that check_scalar returns no error/warning if valid inputs are
    providederrorZ	test_namer>   r?   Zbothtarget_typemin_valmax_valinclude_boundariesN)warningscatch_warningssimplefilterr6   numbersRealrG   )rl   Zscalarr[   r[   r\   test_check_scalar_validc  s    

r]  zJx, target_name, target_type, min_val, max_val, include_boundaries, err_msgZ
test_name1rf   Zneitherz1test_name1 must be an instance of float, not int.z6test_name1 must be an instance of float, not NoneType.z4test_name1 must be an instance of int, not NoneType.z9test_name1 must be an instance of {float, bool}, not int.Z
test_name2ztest_name2 == 1, must be > 2.Z
test_name3ztest_name3 == 5, must be < 4.Z
test_name4rightztest_name4 == 2, must be > 2.Z
test_name5leftztest_name5 == 4, must be < 4.Z
test_name6zbad parameter valuezyUnknown value for `include_boundaries`: 'bad parameter value'. Possible values are: ('left', 'right', 'both', 'neither').Z
test_name7zT`include_boundaries`='left' without specifying explicitly `min_val` is inconsistent.Z
test_name8zU`include_boundaries`='right' without specifying explicitly `max_val` is inconsistent.c              	   C   sZ   t t}t| |||||d W 5 Q R X t|jt|ks@tt|jt|ksVtdS )zLTest that check_scalar returns the right error if a wrong input is
    givenrS  N)r   r   	Exceptionr6   strr   rG   type)rl   Ztarget_namerT  rU  rV  rW  r   Zraised_errorr[   r[   r\   test_check_scalar_invalidt  s    vrc  r%  )r?   y        -C6
?zJThere are imaginary parts in eigenvalues \(1e\-05 of the maximum real part)r?   g-C6
gưz?There are negative eigenvalues \(1e\-06 of the maximum positiveg|۽z?There are negative eigenvalues \(1e\-10 of the maximum positive)r?   g-=z=the largest eigenvalue is more than 1e\+12 times the smallest)ZnominalZnominal_np_arrayZinsignificant_imagzinsignificant negzinsignificant neg float32zinsignificant neg float64zinsignificant posz(lambdas, expected_lambdas, w_type, w_msgenable_warningsc              	   C   sr   |sd }|d kr>t   t dt t| |d}W 5 Q R X n&tj||d t| |d}W 5 Q R X t|| d S )NrR  )rd  r   )rX  rY  rZ  r   r(   r   r  r   )lambdasZexpected_lambdasZw_typeZw_msgrd  Zlambdas_fixedr[   r[   r\    test_check_psd_eigenvalues_valid  s    
  rf  )r?   y              @z/There are significant imaginary parts in eigenv)rz   z,All eigenvalues are negative \(maximum is -1)r?   rz   z*There are significant negative eigenvaluesga2U0*3?ggh㈵>g|)Zsignificant_imagzall negativezsignificant negzsignificant neg float32zsignificant neg float64zlambdas, err_type, err_msgc              	   C   s&   t j||d t|  W 5 Q R X d S )Nr   )r   r   r(   )re  Zerr_typer   r[   r[   r\   "test_check_psd_eigenvalues_invalidQ  s    	rh  c               	   C   s  t dd d d } | jd r"tt| t dd} | jd sBttd t dd} t| t d tdt dd} t| dt d  tjtd	d
 tt dt dd W 5 Q R X d}tjt|d
 tt dt dd W 5 Q R X t d}t jdt j	d} t| |} | j
t j	ks(tt jdtd}td ||j
d} | j
t jksXtt d}t t|} d| d< d}tjt|d
 t| |dd W 5 Q R X d S )Nr9   r>   rw   )r?   r`   rj   )r?   r>   r?   r7  z)Sample weights must be 1D array or scalarr   )r>   rf   rH  z/sample_weight.shape == \(4,\), expected \(2,\)!rf   r:   irz   z1Negative values in data passed to `sample_weight`T)Zonly_non_negative)rB   rC   r|   rG   r*   r   r   r   r   rF   r;   r   rJ   r0   )r   r   rX   r   r[   r[   r\   test_check_sample_weight^  s4    ""


ri  rT   c                 C   s6   t ddd}| || | }}t||s2td S )Nr   r8   rB   rE   rg   r%   rG   rT   baserl   r   r[   r[   r\   !test_allclose_dense_sparse_equals  s    rm  c                 C   s:   t ddd}| || |d  }}t||r6td S )Nr   r8   r`   rj  rk  r[   r[   r\   %test_allclose_dense_sparse_not_equals  s    rn  c              	   C   sJ   t ddd}| |d }d}tjt|d t|| W 5 Q R X d S )Nr   r8   r`   zFCan only compare two sparse matrices, not a sparse matrix and an arrayr   )rB   rE   rg   r   r   r   r%   )rT   rl   r   r   r[   r[   r\    test_allclose_dense_sparse_raise  s
    ro  c               	   C   s   t ddddd} tjtdd | ddd W 5 Q R X tjtd	d | dddd
 W 5 Q R X t ddddddd}tjtdd |dd W 5 Q R X t ddddd}tjtdd |dd W 5 Q R X d S )Nr`   r   dc                S   s   d S r  r[   r   r   r   rq  r[   r[   r\   f1  s    z=test_deprecate_positional_args_warns_for_function.<locals>.f1Pass c=3 as keyword argsr   r>   r8   Pass c=3, d=4 as keyword argsrf   )r   r   rq  c                S   s   d S r  r[   rr  r[   r[   r\   f2  s    z=test_deprecate_positional_args_warns_for_function.<locals>.f2zPass b=2 as keyword argsc                S   s   d S r  r[   rr  r[   r[   r\   f3  s    z=test_deprecate_positional_args_warns_for_function.<locals>.f3)r`   r,   r   r  FutureWarning)rs  rv  rw  r[   r[   r\   1test_deprecate_positional_args_warns_for_function  s    rz  c               	   C   s:   t dddd } tjtdd | dd W 5 Q R X d S )	N1.1)versionc                S   s   d S r  r[   )r   r   r[   r[   r\   rs    s    zEtest_deprecate_positional_args_warns_for_function_version.<locals>.f1z,From version 1.1 passing these as positionalr   r`   r>   rx  )rs  r[   r[   r\   9test_deprecate_positional_args_warns_for_function_version  s    
 r}  c               	   C   s   G dd d} t jtdd | ddd W 5 Q R X t jtdd | dddd	 W 5 Q R X G d
d d}t jtdd |ddd W 5 Q R X t jtdd |dddd	 W 5 Q R X d S )Nc                   @   s    e Zd ZedddddZdS )z:test_deprecate_positional_args_warns_for_class.<locals>.A1r`   rp  c                S   s   d S r  r[   r  r   r   r   rq  r[   r[   r\   rL    s    zCtest_deprecate_positional_args_warns_for_class.<locals>.A1.__init__Nr   r  r  r,   rL  r[   r[   r[   r\   A1  s   r  rt  r   r`   r>   r8   ru  rf   c                   @   s"   e Zd ZeddddddZdS )z:test_deprecate_positional_args_warns_for_class.<locals>.A2r`   rp  c                S   s   d S r  r[   r~  r[   r[   r\   rL    s    zCtest_deprecate_positional_args_warns_for_class.<locals>.A2.__init__N)r`   r`   r  r[   r[   r[   r\   A2  s   r  )r   r  ry  )r  r  r[   r[   r\   .test_deprecate_positional_args_warns_for_class  s    r  r   c              	   C   s   t jdd}ddddgt ddddgtddddgjtddddgddd d}t||| }| d k	rn| ntt	|j
d }dD ]}|| || kstq|d	 t|d	 |kstt|d
 t|d
 | t|d t|d | d S )Nrf   r>   r`   r8   Zxxx)r"  r   
sparse-col
sparse-row
scalar-int
scalar-strNoner   )r  r  r  r  r"  r   r  )rB   randomZrandnr   rR   rS   r{   r'   r"  rangerp   rG   r   r   r   )r   rX   Z
fit_paramsr   Zindices_keyr[   r[   r\   test_check_fit_params  s&    
	 r  	sp_formatc                 C   sd   t d}tdd}|jj|}t|| d}| dkr:d} t|sHt	|j
| ksVt	t|| d S )Nr   r9   r8   r   Tr   )r   r   r   r   sparseZfrom_spmatrixr   rR   r  rG   r   r   )r  r   Zsp_matZsdfr   r[   r[   r\   "test_check_sparse_pandas_sp_format  s    

r  zntype1, ntype2)
longdoubler   )r   rF   )rF   double)rM   rD   )rD   long)byterO   )ushortrP   )rP   uint64)rN   rL   c              	   C   s   t d}||jjdddg| dd|jjdddg|ddd}t|jtdk rd}t jt|d t	|d	d
gd W 5 Q R X nt	|d	d
gd dS )zcheck that we raise an error with dataframe having
    sparse extension arrays with unsupported mixed dtype
    and pandas version below 1.1. pandas versions 1.1 and
    above fixed this issue so no error will be raised.r   r   r`   r;   Z
fill_valueZcol1Zcol2r{  z3Pandas DataFrame with mixed sparse extension arraysr   r   r   r   N)
r   r   r   arraysSparseArrayr#   __version__r   r   r   )ntype1ntype2r   r9  r   r[   r[   r\    test_check_pandas_sparse_invalid  s    
r  z ntype1, ntype2, expected_subtyper  r  r   ZhalfrF   rJ   rL   r  shortrM   ZintcrD   Zintpr  r   rI   Zlonglongint_ZubyterN   rO   r  ZuintcrP   Zuintr  ZuintpZ	ulonglongc                 C   sh   t d}||jjdddg| dd|jjdddg|ddd}t|ddgd}t|j|sdt	d S )	Nr   r   r`   r  r  r   r   r   )
r   r   r   r  r  r   rB   
issubdtyper;   rG   )r  r  Zexpected_subtyper   r9  r   r[   r[   r\   test_check_pandas_sparse_valid1  s    
r  constructor_namer   Z	dataframeZ
sparse_csrZ
sparse_cscc                 C   s2   dddgdddgg}t || }t|dks.tdS )z$Check _num_features for array-likes.r`   r>   r8   rf   r?   r_   N)r   r/   rG   )r  rX   r[   r[   r\   test_num_featuresT  s    
r  r   r   r   r5  g333333@g      @ra  rK   r   dictseriesc              	   C   s   t | |} |dkrd}n|dkr&d}n|}d| }t| drH|d7 }n.t| d tr`|d	7 }nt| d trv|d
7 }tjtt	|d t
|  W 5 Q R X d S )Nr   znumpy.ndarrayr  zpandas.core.series.Series5Unable to find the number of features from X of type rp   z with shape (3,)r   z" where the samples are of type strz# where the samples are of type dictr   )r   r   rh   ra  r  r   r   r   reescaper/   )rX   r  Zexpected_type_namemessager[   r[   r\   &test_num_features_errors_1d_containers_  s     



r  r8  c              	   C   s6   dt | j }tjt|d t|  W 5 Q R X d S )Nr  r   )rb  r  r   r   r   r/   )rX   r   r[   r[   r\    test_num_features_errors_scalars  s    r  namesrq  zlist-intr  defaultZ
MultiIndexc              	   C   sb   t d}|jddgddgddgg| d}t  tdt t|} W 5 Q R X | d	ks^td	S )
zGet feature names with pandas dataframes without warning.

    Column names with consistent dtypes will not warn, such as int or MultiIndex.
    r   r`   r>   rf   r?   r_   r(  rR  N)	r   r   r   rX  rY  rZ  ry  r-   rG   )r  r   rX   r[   r[   r\   2test_get_feature_names_pandas_with_ints_no_warning  s    

 
r  c                  C   sP   t d} dd tdD }| jdddgddd	gg|d
}t|}t|| dS )z)Get feature names with pandas dataframes.r   c                 S   s   g | ]}d | qS )Zcol_r[   )r   r   r[   r[   r\   r     s     z1test_get_feature_names_pandas.<locals>.<listcomp>r8   r`   r>   rf   r?   r_   r(  N)r   r   r  r   r-   r   )r   r   rX   Zfeature_namesr[   r[   r\   test_get_feature_names_pandas  s
    
r  c                  C   s2   t dddgdddgg} t| }|dks.tdS )z/Get feature names return None for numpy arrays.r`   r>   r8   rf   r?   r_   N)rB   r   r-   rG   )rX   r  r[   r[   r\   test_get_feature_names_numpy  s    r  znames, dtypesz['int', 'str']pizzaz['list', 'str']zint-strzlist-strc              	   C   sb   t d}|jddgddgddgg| d}td| d	}t jt|d
 t|} W 5 Q R X dS )zAGet feature names errors when the feature names have mixed dtypesr   r`   r>   rf   r?   r_   r(  z]Feature names are only supported if all input features have string names, but your input has a.   as feature name / column name types. If you want feature names to be stored and validated, you must convert them all to strings, by using X.columns = X.columns.astype(str) for example. Otherwise you can remove feature / column names from your input data, or convert them all to a non-string data type.r   N)r   r   r   r  r  r   r   r-   )r  r   r   rX   r   r[   r[   r\   %test_get_feature_names_invalid_dtypes  s    

 
r  c                   @   s(   e Zd ZdddZdd Zd	ddZdS )
PassthroughTransformerNc                 C   s   | j |dd | S )NT)reset)Z_validate_datar  r[   r[   r\   r     s    zPassthroughTransformer.fitc                 C   s   |S r  r[   )r  rX   r[   r[   r\   	transform  s    z PassthroughTransformer.transformc                 C   s
   t | |S r  )r&   )r  Zinput_featuresr[   r[   r\   get_feature_names_out  s    z,PassthroughTransformer.get_feature_names_out)N)N)r   r  r  r   r  r  r[   r[   r[   r\   r    s   
r  c               	   C   s   t dddgg} t | }| }t|dddg ddg}tjtdd	 || W 5 Q R X |`	tjtd
d	 |  W 5 Q R X dS )z4Check behavior of check_feature_names_in for arrays.r6  r5  r7  Zx0x1x2x10z*input_features should have length equal tor   z Unable to generate feature namesN)
rB   r   r  r   r  r   r   r   r   Zn_features_in_)rX   r  r  Zincorrect_len_namesr[   r[   r\   test_check_feature_names_in  s    r  c               	   C   s|   t d} dddg}| jdddgg|d}t |}| }t|dddg t jtd	d
 |dddg W 5 Q R X dS )z?Check behavior of check_feature_names_in for pandas dataframes.r   r   r   r   r6  r5  r7  r(  zinput_features is not equal tor   r  r  Zx3N)	r   r   r   r  r   r  r   r   r   )r   r  r9  r  r[   r[   r\   "test_check_feature_names_in_pandas  s    

r  c               	   C   s.   d} t jt| d tt d W 5 Q R X dS )z@Check the error message when passing an unknown response method.zKRandomForestRegressor has none of the following attributes: unknown_method.r   Zunknown_methodN)r   r   r  r)   r	   )r   r[   r[   r\   )test_check_response_method_unknown_method  s    r  response_methoddecision_functionpredict_probapredictc              	   C   s6   d|  d}t jt|d tt |  W 5 Q R X dS )zUCheck the error message when a response method is not supported by the
    estimator.z7EstimatorWithFit has none of the following attributes: .r   N)r   r   r  r)   r   )r  r   r[   r[   r\   8test_check_response_method_not_supported_response_method  s    
r  c               	   C   s   dg} t | }d}ddg}dd| d}tjt|d t||| W 5 Q R X ddg}t|||}|dksvtddg} t | }dddg}t|||}|dkstd	S )
z0Check that we can pass a list of ordered method.r  Zmocking_datar  r  zD_MockEstimatorOnOffPrediction has none of the following attributes: z, r  r   N)r   joinr   r   r  r)   rG   )Zmethod_implementedZmy_estimatorrX   r  r   Zmethod_name_predictingr[   r[   r\   #test_check_response_method_list_str  s     
r  c                  C   sJ   t d} t| ddgdd}tddg}|j|jks<tt|| dS )zRegression test for gh-25145r   TFr   N)r   r   r   rB   r   r;   rG   r   )r   r/  expectedr[   r[   r\   #test_boolean_series_remains_boolean#  s
    r  input_valuesc                 C   sL   t d}|j| dd}t|ddddd}t|jjtjs>tt	||  dS )zpCheck pandas array with extensions dtypes returns a numeric ndarray.

    Non-regression test for gh-25637.
    r   ZInt32r:   NF)r;   r   r   rc   )
r   r   r   rB   r  r;   r   floatingrG   r   )r  r   Zinput_seriesr   r[   r[   r\   !test_pandas_array_returns_ndarray-  s    r  array_namespaceznumpy.array_apizcupy.array_apic              
   C   s   t | }|j|jddgd|jdgg|jd}tdd( t jtdd t| W 5 Q R X W 5 Q R X |j|j	ddgd|j	dgg|jd}tdd( t jtd	d t| W 5 Q R X W 5 Q R X d
S )z9Checks that Array API arrays checks non-finite correctly.r`   r   r8   r:   T)Zarray_api_dispatchr   r   zinfinity or a value too largeN)
r   r   rq   rU   rF   r   r   r   r   r+  )r  ZxpZX_nanZX_infr[   r[   r\   )test_check_array_array_api_has_non_finite@  s    
$$r  zextension_dtype, regular_dtype)r3  rK   )r   rI   )r   rJ   )r.  rQ   include_objectc                 C   s   t d}||jddddg|d|jddddgd	dd
}|r\|jddddgdd|d< |j|d | d}t|dd}t|dd}t|| dS )zKCheck pandas extension arrays give the same result as non-extension arrays.r   r`   r   r:   r   r   r   r_   rI   )r   r   r   r   r   rq  rQ   )r   N)r   r   r   r   ZassignrH   r   r   )Zextension_dtypeZregular_dtyper  r   Z	X_regularZX_extensionZX_regular_checkedZX_extension_checkedr[   r[   r\   $test_check_array_multiple_extensionsQ  s    
r  )__doc__r[  r  rX  	itertoolsr   operatorr   tempfiler   numpyrB   r   Zscipy.sparser  rR   r   r,  Zsklearn._configr   Zsklearn.baser   Zsklearn.datasetsr   Zsklearn.ensembler	   Zsklearn.exceptionsr
   r   Zsklearn.linear_modelr   Z(sklearn.metrics.tests.test_score_objectsr   Zsklearn.neighborsr   Zsklearn.random_projectionr   Zsklearn.svmr   Zsklearn.utilsr   r   r   r   r   r   Zsklearn.utils._mockingr   r   Zsklearn.utils._testingr   r   r   r   r   r   r   r    r!   Zsklearn.utils.estimator_checksr"   Zsklearn.utils.fixesr#   Zsklearn.utils.validationr$   r%   r&   r'   r(   r)   r*   r+   r,   r-   r.   r/   r0   r1   r2   r3   r4   r5   r6   r7   r]   markZparametrizer  r   Ztocsrrd   rk   rt   r   r+  rU   rq   r}   r   r   r   r   r   rQ   r   r   r   rF   rJ   r   r   r   r   r   r   r   r   Zfixturer   r   r   r   r  r  r  r  r  r   r"  r#  r$  r'  r*  r-  r1  r:  r<  r=  r>  rA  rD  rF  rS   r   r	  r
  r  Z
dia_matrixrG  rI  rQ  r]  r   r   r\  IntegralrK   r   r   rc  Z_psd_cases_validvalueskeysrf  Z_psd_cases_invalidrh  ri  rm  rn  ro  rz  r}  r  r  r  r  r  integerZunsignedintegerr  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r[   r[   r[   r\   <module>   sV   ,X*$
 (	
j

 
%	,


:*#$%  
 











q





,


	
,*

	 

,	