
    -i3                     p   S r SSKrSSKrSSKrSSKrSSKJr  SSKJr  SSK	J
r
  SSKrSSKJr  SSKrSSKJr  SSKJr  SS	KJr  SS
KJrJr  SSKJr  SSKJrJr  SSKJrJrJ r J!r!  SSK"J#r#  SSK$J%r%J&r&J'r'  SSK(J)r)J*r*  SSK+J,r,J-r-J.r.J/r/J0r0J1r1J2r2J3r3J4r4J5r5J6r6J7r7J8r8  S r9SCS jr: " S S\5      r;\Rx                  R{                  S\" \:SS9S4\:S4\" \:S5      S4\" SS9S4\" SSS S!S"9S#4\;" 5       S$4/5      S% 5       r>\8" \?" \'" 5       5      \&S&9S' 5       r@S( rA\Rx                  R                  S)5      \Rx                  R                  S*5      S+ 5       5       rCS, rDS- rES. rFS/ rG\?" \
" \'" 5       \" \" SS95      /\G" 5       5      5      rH\Rx                  R{                  S0\H\%S19S2 5       rIS3S4/rJS5 rK\'" S65       V s/ s H  n \K" U 5      (       d  M  U PM     sn rL\Rx                  R{                  S6\L\%S19S7 5       rM\'" 5        V s/ s H  n \N" U S85      (       d  M  U PM     sn rO\Rx                  R{                  S0\O\%S19S9 5       rP\Rx                  R{                  S0\?" \'" 5       5      \%S19S: 5       rQ\?" \
" \'" S65      \" \!" 5       \" 5       5      \ " S;S<9\" S=S>9/5      5      rR\Rx                  R{                  S0\R\%S19S? 5       rS\Rx                  R{                  S0\R\%S19\Rx                  R{                  S@\4\/\5\0/5      SA 5       5       rT\Rx                  R{                  S0\'" 5       \%S19SB 5       rUgs  sn f s  sn f )Dz.
General tests for all estimators in sklearn.
    N)partial)isgenerator)chain)LinAlgWarning)BaseEstimator)ColumnTransformer)ConvergenceWarning)enable_halving_search_cvenable_iterative_imputer)LogisticRegression)FeatureUnionmake_pipeline)FunctionTransformerMinMaxScalerOneHotEncoderStandardScaler)all_estimators)_get_check_estimator_ids_get_expected_failed_checks_tested_estimators)SkipTestignore_warnings)(check_dataframe_column_names_consistencycheck_estimator!check_get_feature_names_out_error$check_global_output_transform_pandas(check_global_set_output_transform_polarscheck_inplace_ensure_writeablecheck_param_validationcheck_set_output_transform!check_set_output_transform_pandas!check_set_output_transform_polars'check_transformer_get_feature_names_out.check_transformer_get_feature_names_out_pandasparametrize_with_checksc                      [        5        HA  u  pSR                  U 5      nU R                  5       R                  S5      (       d  M<   U5       e   g )NzDBase estimators such as {0} should not be included in all_estimatorsbase)r   formatlower
startswith)name	Estimatormsgs      L/var/www/html/venv/lib/python3.13/site-packages/sklearn/tests/test_common.py test_all_estimator_no_base_classr/   @   sF    )+R
&, 	 ::<**6227C72	 ,       c                     g N )xys     r.   _sample_funcr7   I   s    r0   c                       \ rS rSrSrS rSrg)CallableEstimatorM   ziDummy development stub for an estimator.

This is to make sure a callable estimator passes common tests.
c                     g r3   r4   )selfs    r.   __call__CallableEstimator.__call__S   s    r0   r4   N)__name__
__module____qualname____firstlineno____doc__r=   __static_attributes__r4   r0   r.   r9   r9   M   s    
r0   r9   zval, expected)r6   z_sample_func(y=1)r7   worldg       @)CzLogisticRegression(C=2.0)z	newton-cgbalancedT)random_statesolverclass_weight
warm_startz]LogisticRegression(class_weight='balanced',random_state=1,solver='newton-cg',warm_start=True)zCallableEstimator()c                 &    [        U 5      U:X  d   eg r3   )r   )valexpecteds     r.   test_get_check_estimator_idsrO   W   s    . $C(H444r0   )expected_failed_checksc                     [        [        [        [        [        4S9   U" U 5        S S S 5        g ! , (       d  f       g = fNcategory)r   FutureWarningr	   UserWarningr   )	estimatorcheckrequests      r.   test_estimatorsrZ   q   s3    
 
!3[-P
 	i
 
 
s   	0
>c                      [         R                  " [        SS9   [        [	        5       SS9n SSS5        [        W 5      (       d   eg! , (       d  f       N!= f)zPCheck that check_estimator with generate_only=True raises a deprecation
warning.z$`generate_only` is deprecated in 1.6matchT)generate_onlyN)pytestwarnsrU   r   r   r   )all_instance_gen_checkss    r.   .test_check_estimator_generate_only_deprecationrb   }   sJ     
m+Q	R"1 #
 
S .////	 
S	Rs   A
AzZignore:Since version 1.0, it is not needed to import enable_hist_gradient_boosting anymorezGignore:Importing from sklearn.utils._estimator_html_repr is deprecated.c                     [         R                  R                  [        R                  5      /n [
        R                  " U SS S9nU VVs/ s H  u  p#o#PM	     nnnUS/-    H]  nSU;   d  SU;   a  M  SU;   a  M  [        USS	9n[        US
S5       H)  n[        XV5      (       a  M   SR                  X65      5       e   M_     g s  snnf )Nsklearn.c                     g r3   r4   _s    r.   <lambda>-test_import_all_consistency.<locals>.<lambda>   s    r0   )pathprefixonerrorsklearnz.tests.zsklearn.externalszsklearn._build_utilsdummy)fromlist__all__r4   z#Module '{0}' has no attribute '{1}')osrj   dirnamerm   __file__pkgutilwalk_packages
__import__getattrhasattrr(   )sklearn_pathpkgsrg   modnamesubmodspackager+   s          r.   test_import_all_consistencyr~      s     GGOOG$4$456L   *nD -11D=1qwDG1i[(#6'#A!W,Ww7GY3D7)) +P+W+W, ) 4 ) 2s   Cc                     [         R                  R                  [        R                  5      /n Sn[
        R                  " U S S9 H?  u  p#nSU;   d  UR                  S5      (       d  X1;   a  M)  U[        R                  ;   a  M?   e   g )N)utilstestsr'   conftestc                     g r3   r4   rf   s    r.   rh   3test_root_import_all_completeness.<locals>.<lambda>   s    Tr0   )rj   rl   .rg   )	rq   rj   rr   rm   rs   rt   ru   r*   rp   )ry   
EXCEPTIONSrg   r{   s       r.   !test_root_import_all_completenessr      ss    GGOOG$4$456L7J ..>A '>W//448M'//)))r0   c                     [         R                  " S5      n 1 Skn[        R                  R	                  [
        R                  5      /n[        R                  " USS9 VVVs0 s H  u  p4nXE_M
     nnnnUR                  5        VVs/ s H:  u  pEU(       d  M  XA;  d  M  U R                  U5      (       a  M-  US-   U;  d  M8  UPM<     nnnU/ :X  d   SR                  U5      5       eg s  snnnf s  snnf )Nz(?x)
                                      \.externals(\.|$)|
                                      \.tests(\.|$)|
                                      \._
                                      >   sklearn.datasets.datasklearn.datasets.descrsklearn.datasets.imagesrd   )rk   z.testszn{0} do not have `tests` subpackages. Perhaps they require __init__.py or a meson.build in the parent directory)recompilerq   rj   rr   rm   rs   rt   ru   itemssearchr(   )HAS_TESTS_EXCEPTIONSresource_modulesry   rg   r+   ispkglookupmissing_testss           r.   test_all_tests_are_importabler      s    ::	*
 GGOOG$4$456L &33LTTNAU 	T   "<<>)KD 	 ( 	 %++D1	 	
 8O6) 	)   B 	 F=)s$   "C)C0C0 C08C0C0c                     Sn [         R                  " [        U S9   [        [        5        S S S 5        [         R                  " [        U S9   [        [        /5        S S S 5        g ! , (       d  f       NA= f! , (       d  f       g = f)Nz8Passing a class was deprecated.* isn't supported anymorer\   )r_   raises	TypeErrorr   r   r%   r-   s    r.   test_class_support_removedr      s\     EC	y	,*+ 
- 
y	,!3 45 
-	, 
-	, 
-	,s   A'A8'
A58
Bc               #     #    [        5        H  n [        U R                  5       5      nSU;   a  U R                  SSS9v   M6  SU;   ad  U R                  SSS9nUR                  R
                  S;   a4  [        R                  " U[        R                  R                  SS	9S
9v   M  Uv   M  SU;   d  M  U R                  SS9v   M     g 7f)N	oob_scoreT)r   	bootstrapearly_stoppingr1   )r   n_iter_no_change>   MLPRegressorMLPClassifierzMLP still validates in fitr   )marksr   )r   )
r   set
get_params
set_params	__class__r?   r_   parammarkxfail)rW   
est_paramsests      r.   _estimators_that_predict_in_fitr      s     ')	--/0
*$&&&FF+&&dQ&OC}}%%)JJllv{{005Q0R  	:-&&&:: *s   B/C5CrW   )idsc                    [        U [        5      (       a  [        R                  " S5        S[	        U 5      ;   a  [        R                  " S5        [        [        S9   [        R                  " SS9 n[        U R                  R                  U 5        S S S 5        W H  nS[        UR                  5      ;  a  M   e   S S S 5        g ! , (       d  f       N;= f! , (       d  f       g = f)Nz$ColumnTransformer is not tested herer   zCEstimator does not support check_dataframe_column_names_consistencyrS   T)recordz was fitted without feature names)
isinstancer   r_   skipr   r   rU   warningscatch_warningsr   r   r?   strmessage)rW   r   warnings      r.   #test_pandas_column_name_consistencyr      s     ).//:;15P6  	Q	
 
=	2$$D1V4##,,i 2 G5S=QQQQ  
3	211 
3	2s*   C3!C	$C<C	
C	C
C(ensemblekernel_approximationc                 t    [        U S5      (       a  gU R                  R                  S5      S   nU[        ;  $ )Nget_feature_names_outTr   r1   )rx   r@   split"GET_FEATURES_OUT_MODULES_TO_IGNORE)transformermodules     r.   '_include_in_get_feature_names_out_checkr     s:    {344##))#.q1F;;;r0   r   c                     [        [        S9   [        U R                  R                  U 5        [        U R                  R                  U 5        S S S 5        g ! , (       d  f       g = frR   )r   rU   r#   r   r?   r$   )r   s    r.   'test_transformers_get_feature_names_outr   *  sL     
=	2/!!**K	
 	7!!**K	
	 
3	2	2s   AA
A&r   c                 F    U R                   R                  n[        X5        g r3   )r   r?   r   )rW   estimator_names     r.   +test_estimators_get_feature_names_out_errorr   <  s     ((11N%n@r0   c                     [        U [        5      (       a  [        R                  " S5        U R                  R
                  n[        X5        g )NzFeatureUnion is not tested here)r   r   r_   r   r   r?   r   rW   r+   s     r.   test_check_param_validationr   D  s7     )\**56''D4+r0   F)sparse_outputz
one-to-one)feature_names_outc                    U R                   R                  n[        U S5      (       d  [        R                  " SU S35        [        [        S9   [        U R                   R                  U 5        S S S 5        g ! , (       d  f       g = f)N
set_outputz(Skipping check_set_output_transform for z!: Does not support set_output APIrS   )r   r?   rx   r_   r   r   rU   r    r   s     r.   test_set_output_transformr   Z  sk     ''D9l++6tf = 	
 
=	2"9#6#6#?#?K 
3	2	2s   !A99
B
check_funcc                 (   U R                   R                  n[        U S5      (       d'  [        R                  " SUR                   SU S35        [        [        S9   U" U R                   R                  U 5        S S S 5        g ! , (       d  f       g = f)Nr   z	Skipping z for z%: Does not support set_output API yetrS   )r   r?   rx   r_   r   r   rU   )rW   r   r+   s      r.   $test_set_output_transform_configuredr   h  sx     ''D9l++
++,E$ 8" "	
 
=	29&&//; 
3	2	2s   B
Bc                 f   U R                   R                  n[        U S5      (       a  U R                  SS9  O/[        U S5      (       a  U R                  SS9  O[	        U S35      eUS:X  a  U R                  SS	S
9  US:X  a  U R                  SS9  US:X  a  U R                  SS9  [        X5        g )NcopyF)r   copy_X)r   z! doesn't require writeable input.HDBSCANprecomputedbrute)metric	algorithmPCAfull)
svd_solver	KernelPCA)kernel)r   r?   rx   r   r   r   r   s     r.   #test_check_inplace_ensure_writeabler     s     ''Dy&!!%(	H	%	%E*$@ABB yMWEu}/{M2"43r0   )r1   )VrC   rq   rt   r   r   	functoolsr   inspectr   	itertoolsr   r_   scipy.linalgr   rm   sklearn.baser   sklearn.composer   sklearn.exceptionsr	   sklearn.experimentalr
   r   sklearn.linear_modelr   sklearn.pipeliner   r   sklearn.preprocessingr   r   r   r   sklearn.utilsr   -sklearn.utils._test_common.instance_generatorr   r   r   sklearn.utils._testingr   r   sklearn.utils.estimator_checksr   r   r   r   r   r   r   r    r!   r"   r#   r$   r%   r/   r7   r9   r   parametrizerO   listrZ   rb   filterwarningsr~   r   r   r   r   column_name_estimatorsr   r   r   GET_FEATURES_OUT_ESTIMATORSr   rx   %ESTIMATORS_WITH_GET_FEATURE_NAMES_OUTr   r   SET_OUTPUT_ESTIMATORSr   r   r   )r   s   0r.   <module>r      s   
  	      &  & - 1 4 8  ) 
   "8	  		#%89	~&	w	'8	c	"$?@"'	6	
 
	34#,5-,5 		7R0 ,
 M**#L	6;* 		)A.	/0')  '-E  RR* & "< "-00.s3 0  .4L  

 &')'C738O+PC') %
 6<T  AA
 (*+1I  ,, 	=).*LN;.,?	
	  &,D  LL &,D   ),)0	<< #%+C  44()s   =L.L.L3L3