
    e!h                        d dl 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	m
Z
mZmZmZmZ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mZmZmZmZmZm Z m!Z!m"Z"m#Z#m$Z$m%Z%m&Z&m'Z'm(Z(m)Z)m*Z*m+Z+m,Z,m-Z-m.Z.m/Z/m0Z0m1Z1 d d	l2m3Z3 d d
l4m5Z5m6Z6m7Z7m8Z8 d dl9m:Z:m;Z;m<Z<m=Z=m>Z> d dl?m@Z@mAZA d ZBej                  j                  de;      ej                  j                  de<      ej                  j                  de:      ej                  j                  de=      d                             ZE e8eF      ej                  j                  de      d               ZGd ZHej                  j                  de*e.g      d        ZId ZJ ej                  dd      j                  dd      ddZMd  ZNej                  j                  d!e*d"i fe*eeMfe*d#eMfe.d$d%dife.eNd&d'ifg      ej                  j                  d(ej                  ej                  eQg      d)               ZRd* ZSej                  j                  dg d+      ej                  j                  de=      d,               ZTd- ZUd. ZVej                  j                  d/ ej                               ej                  j                  de=      d0               ZXd1 ZYej                  j                  d2e>      ej                  j                  de=      d3               ZZd4 Z[d5 Z\d6 Z]ej                  j                  d7d8 d9 d: ge=D  cg c]  } | fd;	 c} z   e>D cg c]  }|fd<	 c}z         d=        Z^ej                  j                  d>d? e_d@fdA e_dBfdC e_dDfdE e`dFfdG e`dHfdI e`dJfg      dK        ZaddLZbej                  j                  ddM      dN        Zcej                  j                  ddM      dO        Zdej                  j                  dP      dQ        Zfej                  j                  dRej                  ge=z   dSge=D cg c]  }|j                   c}z   T      ej                  j                  dUej                  ge=z   dSge=D cg c]  }|j                   c}z   T      dV               Ziej                  j                  dUej                  ge=z   dSge=D cg c]  }|j                   c}z   T      dW        Zjej                  j                  dXdYdg      dZ        Zkd[ Zlej                  j                  dRej                  ge=z   dSge=D cg c]  }|j                   c}z   T      ej                  j                  dUej                  ge=z   dSge=D cg c]  }|j                   c}z   T      d\               Zmej                  j                  dRej                  ge=z   dSge=D cg c]  }|j                   c}z   T      d]        Znej                  j                  d^g d_      ej                  j                  dRej                  ge=z   dSge=D cg c]  }|j                   c}z   T      ej                  j                  dUej                  ge=z   dSge=D cg c]  }|j                   c}z   T      d`                      Zoej                  j                  d^g d_      ej                  j                  dRej                  ge=z   dSge=D cg c]  }|j                   c}z   T      da               Zpej                  j                  dbej                  dcddf ej                  ej                  dedfej                  j                  dgh      i      g      ej                  j                  djddkg      dl               Zsej                  j                  dmdYdg      dn        Ztej                  j                  do ej                  ej                  d gg       ej                  d ej                   gg      g      ej                  j                  dp ej                  ej                  d gg       ej                  d ej                   gg      dg      dq               Zvej                  j                  dr ej                  d dgdd gg       ej                  ds      ej                  f ej                  d dgdej                  gg       ej                  ds      ej                  f ej                  ej                  dgdej                  gg      ej                  ej                  f ej                  ej                  dgej                  d gg       ej                  ds      ej                  f ej                  d ej                  gdej                  gg       ej                  ds      ej                  f ej                  d dgdd gg       ej                  ds      dtf ej                  d dgddtgg       ej                  ds      dtf ej                  dtdgddtgg      ej                  dtf ej                  dtdgdtd gg       ej                  ds      dtf ej                  d dtgddtgg       ej                  ds      dtfg
      du        Zyej                  j                  dvej                  dtg      dw        Zzej                  j                  dvej                  dtg      dx        Z{ej                  j                  dvej                  dtg      dy        Z|dz Z}d{ Z~d| Zd} Zd~ Zd Zej                  j                  de#e/e0e"e1ef      d        Zej                  j                  de#e/e0e"e1ef      ej                  j                  de=      d               Zd Zd Zd Zej                  j                  dde#fdefg      ej                  j                  de=      d               Zej                  j                  de=      d        Zd Zd Zd Zd Zej                  j                  de=      d        Zd Zd Zd Zej                  j                  dddsg      ej                  j                  dddg      ej                  j                  de*e-g      d                      Zej                  j                  dddg      d        Zej                  j                  dg d      ej                  j                  ddYdgddgT      d               Zej                  j                  de*e+e,g      d        Zd Zej                  j                  dg ddg dg dg dgfg dddgddgddgddggfg      d        Zd Zej                  j                  de=      d        Zd Zyc c} w c c}w c c}w c c}w c c}w c c}w c c}w c c}w c c}w c c}w c c}w )    N)GeneratorType)linalg)issparse)cdist	cityblockcosine	minkowskipdist
squareform)config_context)DataConversionWarning)PAIRED_DISTANCESPAIRWISE_BOOLEAN_FUNCTIONSPAIRWISE_DISTANCE_FUNCTIONSPAIRWISE_KERNEL_FUNCTIONS_euclidean_distances_upcastadditive_chi2_kernelcheck_paired_arrayscheck_pairwise_arrayschi2_kernelcosine_distancescosine_similarityeuclidean_distanceshaversine_distanceslaplacian_kernellinear_kernelmanhattan_distancesnan_euclidean_distancespaired_cosine_distancespaired_distancespaired_euclidean_distancespaired_manhattan_distancespairwise_distancespairwise_distances_argminpairwise_distances_argmin_minpairwise_distances_chunkedpairwise_kernelspolynomial_kernel
rbf_kernelsigmoid_kernel)	normalize)assert_allcloseassert_almost_equalassert_array_equalignore_warnings)BSR_CONTAINERSCOO_CONTAINERSCSC_CONTAINERSCSR_CONTAINERSDOK_CONTAINERS)Paralleldelayedc                 	   t         j                  j                  d      }|j                  d      j	                  | d      }t        |d      }t        |      }t        ||       |j                  |j                  cxk(  r| k(  sJ  J |j                  d      j	                  | d      }t        ||d      }t        ||      }t        ||       |j                  |j                  cxk(  r| k(  sJ  J |j                  d      j	                  | d      }|j                  d      j	                  | d      }t         j                  |d<   t         j                  |d<   t        ||d	      }t        ||      }	t        ||	       |j                  |	j                  cxk(  r| k(  sJ  J t        |D 
cg c]  }
t        |
D cg c]  }| c}       c}}
      }t        |D 
cg c]  }
t        |
D cg c]  }| c}       c}}
      }t        ||d      }t        ||       |j                  |j                  cxk(  r| k(  sJ  J |j                  d
      j	                  | d      }|d d df   dz
  dz  t         j                  z  dz  |d d df<   |d d df   dz
  dz  t         j                  z  |d d df<   t        |d      }t        |      }t        ||       |j                  d      j	                  | d      }|d d df   dz
  dz  t         j                  z  dz  |d d df<   |d d df   dz
  dz  t         j                  z  |d d df<   t        ||d      }t        ||      }t        ||       t        |d      }t        |t              }|j                  d   |j                  d   k(  sJ |j                  d   |j                  d   k(  sJ t        ||       t        ||d      }t        ||t              }|j                  d   |j                  d   k(  sJ |j                  d   |j                  d   k(  sJ t        ||       t        ||d      }t        ||t               }|j                  d   |j                  d   k(  sJ |j                  d   |j                  d   k(  sJ t        ||       y c c}w c c}}
w c c}w c c}}
w )Nr         Fcopy	euclideanmetric   r:   r   r   nan_euclideanr9   rA         ?rA      	haversine)rA   rA   r   	manhattanr   )nprandomRandomStaterandom_sampleastyper#   r   r,   dtypenanr   tuplepir   r   shaper   )global_dtyperngXSS2YX_maskedY_maskedS_masked	S2_maskedrowvX_tuplesY_tupless                 k/var/www/html/diagnosisapp-backend/venv/lib/python3.12/site-packages/sklearn/metrics/tests/test_pairwise.py&test_pairwise_distances_for_dense_datarb   C   sk   
))


"C 	&!((E(BA1[1A	Q	BAr77bhh.,..... 	&!((E(BA1a4A	Q	"BAr77bhh.,.....   (//5/IH  (//5/IHVVHTNVVHTN!(H_MH'(;IHi(>>Y__<<<<<< ;#e,1Q,-;<H;#e,1Q,-;<H	Hh{	CBAr77bhh.,.....
 	&!((E(BAAw}!BEE)A-AadGAw}!BEE)AadG1[1A	Q	BAr 	&!((E(BAAw}!BEE)A-AadGAw}!BEE)AadG1a4A	Q	"BAr
 	1[1A	Ai	0B771:###771:###Ar 	1a4A	Aq	3B771:###771:###Ar
 	1a1A	Aq	0B771:###771:###Ar_ -;,;s0   4S

	S	S

&S
4	S=	S
S

S
coo_containercsc_containerbsr_containercsr_containerc                    t         j                  j                  d      }|j                  d      j	                  |d      }|j                  d      j	                  |d      } ||      } ||      }	t        ||	d      }
t        ||	      }t        |
|       |
j                  |j                  cxk(  r|k(  sJ  J t        ||	d      }
t        ||	      }t        |
|       |
j                  |j                  cxk(  r|k(  sJ  J t        | ||      d	      }
t         ||       | |            }t        |
|       |t         j                  k(  r$|
j                  |j                  cxk(  r|k(  sLJ  J t        j                  t              5  |
j                  |j                  cxk(  r|k(  sJ  J 	 d d d        t        ||      }t        |
|       |t         j                  k(  r$|
j                  |j                  cxk(  r|k(  sLJ  J t        j                  t              5  |
j                  |j                  cxk(  r|k(  sJ  J 	 d d d        d
di}t        ||fddi|}
t        ||fdt        i|}t        |
|       d
di}t        |fddi|}
t        |fdt        i|}t        |
|       t        j                  t               5  t        |d       d d d        t        j                  t               5  t        ||	d       d d d        y # 1 sw Y   bxY w# 1 sw Y   xY w# 1 sw Y   SxY w# 1 sw Y   y xY w)Nr   r8   Fr;   r@   r=   r>   r   rH   p       @r?   r	   )rI   rJ   rK   rL   rM   r#   r   r,   rN   r   r   float64pytestraisesAssertionErrorr	   	TypeError)rc   rd   re   rf   rS   rT   rU   rX   X_sparseY_sparserV   rW   kwdss                ra   'test_pairwise_distances_for_sparse_datarr      s    ))


"C&!((E(BA&!((E(BA QHQH8XkBA	Xx	0BAr77bhh.,.....8Xh?A	(H	-BAr77bhh.,.....8]1%5kJA	]1-}Q/?	@BArrzz!ww"((2l22222
 ]]>* 	777bhh6,66666	7 
Q	"BArrzz!ww"((2l22222
 ]]>* 	777bhh6,66666	7 :D1a<<t<A	Aq	;	;d	;BAr :D19[9D9A	A	8i	84	8BAr 
y	! 98K89	y	! <1h{;< <;	7 	7	7 	7 9 9< <s0   %L&%L#L/>L;L #L,/L8;Mcategoryr?   c           	      p   t         j                  j                  d      }|j                  dd      }|j	                         }d|d   z
  |d<   t        t              5  |d fD ]G  }t        |||       }t        j                  |dddd	       t        j                  |dk7        dk(  rGJ  	 d d d        d
| z  }t        j                  t        |      5  t        ||        d d d        t        j                  t        |      5  t        |j                  t              ||        d d d        t        j                         5  t        j                   dt               t        |j                  t              |        d d d        y # 1 sw Y   xY w# 1 sw Y   xY w# 1 sw Y   yxY w# 1 sw Y   y xY w)Nr   r9   r:   rF   rB   rs   r>   F)rO   posinfneginfr<   z+Data was converted to boolean for metric %smatchrX   r?   error)rI   rJ   rK   randnr<   r/   r   r#   
nan_to_numsumrk   warnsrM   boolwarningscatch_warningssimplefilter)r?   rT   rU   rX   Zresmsgs          ra   test_pairwise_boolean_distancer      sr    ))


"C		!QA	A!D'kAdG 
"7	8 )T 	)A$Q&9CMM#1QquE66#(#q(((	)) 8&
@C	+3	7 -1V,- 
+3	7 ?188D>Qv>? 
	 	 	" :g'<=188D>&9: :#) )- -? ?: :s7   AF)FF"F ;F,FF F),F5c                     t         j                  j                  d      } | j                  dd      }t	        j
                         5  t	        j                  dt               t        |d       d d d        y # 1 sw Y   y xY w)Nr   r9   r:   r{   r	   r>   )	rI   rJ   rK   r|   r   r   r   r   r#   )rT   rU   s     ra   test_no_data_conversion_warningr      sa    
))


"C		!QA		 	 	" 2g'<=1[12 2 2s   (A77B funcc                    t        j                  t        d      5   | t        j                  d      d       d d d        t        j                  t        d      5   | t        j                  d      t        j                  d      d       d d d        t        j                  t        d      5   | t        j                  d      t        j                  d      d       d d d        t        j                  d      } | |d      }||u sJ t        j                  d      } | |t        j                  d	      d      }||u sJ  | t        j
                  d
ggd      d      }d|j                  j                  k(  sJ  | dggd      }t        |t        j                        sJ y # 1 sw Y   wxY w# 1 sw Y   /xY w# 1 sw Y   xY w)Nz.* shape .*rx   )r9      precomputedr>   )r:   r:   )r:   r   r9   r9   )r   r   rF   intrN   f      ?)
rk   rl   
ValueErrorrI   zerosarrayrN   kind
isinstancendarray)r   rV   rW   s      ra   test_pairwise_precomputedr     sx    
z	7 5RXXfm45 
z	7 GRXXfrxx/FG 
z	7 GRXXfrxx/FG 	A	a	&B7N7
A	a&!-	8B7N7 	RXXse5)-@A!'',, 	seW]+Aa$$$15 5G GG Gs#   F/2F<22G	/F9<G	Gc                      t        j                  t        d      5  t        t	        j
                  dd      d       d d d        y # 1 sw Y   y xY w)Nz.* non-negative values.*rx   r   r   r>   )rk   rl   r   r#   rI   full     ra   &test_pairwise_precomputed_non_negativer      s?    	z)C	D F27762.}EF F Fs   "AArF   r9   doubleFr;   )wrh   c                     t        t        j                  |       t        j                  |      fi |}|j                         S N)r)   rI   
atleast_2ditem)xyrq   Ks       ra   callable_rbf_kernelr   )  s0    2==#R]]1%5>>A668Or   zfunc, metric, kwdsr=   r	   
polynomialdegreegamma皙?rN   c                 z   t         j                  j                  d      }t        j                  d|j	                  d      z  |      }t        j                  d|j	                  d      z  |      } | |f|dd|} | |f|dd|}t        ||        | ||f|dd|} | ||f|dd|}t        ||       y )	Nr   r9   r8   r   r   r:   rF   r?   n_jobsrA   )rI   rJ   rK   r   rL   r,   )	r   r?   rq   rN   rT   rU   rX   rV   rW   s	            ra   test_pairwise_parallelr   0  s    ( ))


"C
S&&v..e<A
S&&v..e<AQ0va040A	a	1q	1D	1BArQ3&3d3A	a	46!	4t	4BArr   c                  4    t        dggd       d   dk(  sJ y )Nr   c                      y)Nr9   r   r   r   s     ra   <lambda>z9test_pairwise_callable_nonstrict_metric.<locals>.<lambda>U      r   r>   rB   r9   )r#   r   r   ra   'test_pairwise_callable_nonstrict_metricr   Q  s"     ugn=dCqHHHr   )rbf	laplaciansigmoidr   linearchi2additive_chi2c                    t         j                  j                  d      }|j                  d      }|j                  d      }t        |    }t        ||       } ||      }t        ||       t        |||       } |||      }t        ||       t        |D 	cg c]  }t        |D 	cg c]  }	|	 c}	       c}	}      }
t        |D 	cg c]  }t        |D 	cg c]  }	|	 c}	       c}	}      }t        |
||       }t        ||        ||      } ||      }| dv ry t        |||       }t        ||       y c c}	w c c}	}w c c}	w c c}	}w )Nr   r8   r@   r>   rz   rX   )r   r   )rI   rJ   rK   rL   r   r'   r,   rP   )r?   rf   rT   rU   rX   functionK1K2r]   r^   r_   r`   ro   rp   s                 ra   test_pairwise_kernelsr   Y  s/    ))


"C&!A&!A(0H	!F	+B	!BB	!q	0B	!q	BB;#e,1Q,-;<H;#e,1Q,-;<H	(HV	<BB QHQH**	(hv	>BB -;,;s0   E
(	D>1	E
E
	E	#	E
>E
	E
c                  >   t         j                  j                  d      } | j                  d      }| j                  d      }t        }ddi}t        |f||d|}t        |fd|i|}t        ||       t        |f||d|}t        |fd|i|}t        ||       y )Nr   r8   r@   r   r   rz   rX   )rI   rJ   rK   rL   r   r'   r)   r,   )rT   rU   rX   r?   rq   r   r   s          ra   test_pairwise_kernels_callabler   }  s     ))


"C&!A&!A FS>D	!	8q	84	8B	A	#	#d	#BB 
!	8q	84	8B	A	#	#d	#BBr   c                  ^   t         j                  j                  d      } | j                  d      }| j                  d      }t	        ||d      }ddd}t        ||fdd	d
|}t        ||       t        j                  t              5  t        ||fddi| d d d        y # 1 sw Y   y xY w)Nr   r8   r@   r   r   z:))r   blablar   T)r?   filter_paramsr?   )
rI   rJ   rK   rL   r)   r'   r,   rk   rl   rn   )rT   rU   rX   r   paramsr   s         ra   "test_pairwise_kernels_filter_paramr     s    
))


"C&!A&!A1as#Ad+F	!Q	KuD	KF	KBAr	y	! 7A6e6v67 7 7s   
B##B,zmetric, funcc                    t         j                  j                  d      }|j                  d      }|j                  d      }t	        |||       } |||      }t        ||        | ||       ||            }t        ||       | t        v r1t        |    ||      }	t        j                  |	      }	t        |	|       y y )Nr   r8   r>   )rI   rJ   rK   rL   r    r,   r   diag)
r?   r   rf   rT   rU   rX   rV   rW   S3	distancess
             ra   test_paired_distancesr     s     ))


"C&!A&!AAf-A	aBAr	mAa 0	1BAr,, 071=	GGI&		1% -r   c                    t         j                  j                  d      }|j                  d      j	                  | d      }|j                  d      j	                  | d      }t        ||d      }t        ||d       }t        ||       |j                  d      }t        j                  t              5  t        ||       d d d        y # 1 sw Y   y xY w)	Nr   r8   Fr;   rH   r>   c                 R    t        j                  | |z
        j                  d      S )Nr   axis)rI   absr~   r   s     ra   r   z0test_paired_distances_callable.<locals>.<lambda>  s     BFF1q5M4E4E14E4M r   r   )
rI   rJ   rK   rL   rM   r    r,   rk   rl   r   )rS   rT   rU   rX   rV   rW   s         ra   test_paired_distances_callabler     s     ))


"C&!((E(BA&!((E(BAAk2A	!Q'M	NBAr 	&!A	z	" A  s   7CCdok_containerc                 |   t        j                  dgdgg|      }t        j                  dgdgg|      } | |      } |||      }ddg}ddg}ddg}	t        ||d	      \  }
}t        ||d	      }t	        |
|       t	        ||       t	        ||       t        ||d	      \  }}t        ||d	      }t	        ||       t	        ||       t	        ||       t        |      t         j                  k(  sJ t        |      t         j                  k(  sJ t        ||d
	      \  }
}t        ||dddi      \  }}t        ||d
	      }t        ||dddi      }t	        ||	       t	        ||	       t	        |
|       t	        ||       t	        ||       t	        ||       t        ||d	      \  }
}t        ||d	      }t	        |
|       t	        ||       t	        ||       t        ||d	      \  }}t        ||d	      }t	        ||       t	        ||       t	        ||       t        ||t        ddi      \  }
}t	        |
|       t	        ||       t        ||dddi      \  }
}t	        |
|       t	        ||       t         j                  j                  d      }|j                  dd      }|j                  dd      }t        ||d	      }|j                  d      }||t        t        |            f   }t        ||dd      \  }}t	        ||d       t	        ||d       t        ||d      \  }}t        ||d      \  }}t	        ||       t        ||       t        ||d      \  }}t        ||d      \  }}t	        ||       t        ||       t        ||d      }t        ||d      }t        ||       t        ||d      }t        ||d      }t        ||       t        ||      }t        t        j                   |      t        j                   |            }t        ||       y )Nr   rF   r   r   rA   r:   r=   r>   sqeuclideansquaredT)r?   metric_kwargsrH   rh   r	   a      o   r   )r   r?   Hz>rtol)rI   asarrayr%   r$   r,   typer   r	   rJ   rK   r|   r#   argminrangelenr.   asfortranarray)r   rf   rS   rU   rX   XspYspexpected_idxexpected_valsexpected_vals_sqidxvalsidx2idxspvalsspidxsp2vals2idx3idx4rT   distdist_orig_inddist_orig_valdist_chunked_inddist_chunked_valargmin_0dist_0argmin_1dist_1argmin_C_contiguousargmin_F_contiguouss                                  ra   "test_pairwise_distances_argmin_minr    s6    	

QC!:\2A


RD1#;l3A

C

.Cq6LFM1v .a;GIC$Q+>DC&D,'D-(1#s;OME6&sCDFE<(FL)FM*;"**$$$<2::%%% .a=IIC/	1[D0AKD% %Q-@D$	1[D0AD D*+E+,C&D,'D,'D,' .a;GIC$Q+>DC&D,'D-(1#s;OME6&sCDFE<(FL)FM* .	1YsAhIC C&D-( .	1[aIC C&D-( ))


"C		"cA		#sAa;7DKKQK'Mc-.@(AABM)F	11[*&& M#3$?M#3$? 5QBHf4QBHfFF#x*4QBHf4QBHfFF#x* )AA6H(AA6Hx*(AA6H(AA6Hx* 4Aq93
!b//2 *,?@r   c                     | d d d df   S )Nd   r   r   starts     ra   _reduce_funcr  C  s    4C4=r   c                    t         j                  j                  d      }|j                  d      j	                  | d      }t        |      d d d df   }t        |d t        d      }t        |t              sJ t        |      }t        |      dkD  sJ |d   j                  |j                  k(  sJ t        t        j                  |      |d	
       y )Nr   )i  r:   Fr;   r        >reduce_funcworking_memoryrF   r   atol)rI   rJ   rK   rL   rM   r#   r&   r  r   r   listr   rN   r,   vstack)rS   rT   rU   rV   S_chunkss        ra   &test_pairwise_distances_chunked_reducer  G  s    
))


"C(#**<e*DA1a#g&A)	4\&H h...H~Hx=1A;''' BIIh'6r   c                 (   t         j                  j                  d      }|j                  d      j	                  | d      }t        |d d d      }t        |t              sJ t        |      }t        |      dkD  sJ t        d	 |D              sJ y )
Nr   
   r:   Fr;   c                      y r   r   r  s     ra   r   z=test_pairwise_distances_chunked_reduce_none.<locals>.<lambda>]  r   r   r
  r  rF   c              3   $   K   | ]  }|d u  
 y wr   r   ).0chunks     ra   	<genexpr>z>test_pairwise_distances_chunked_reduce_none.<locals>.<genexpr>b  s     3u}3s   )rI   rJ   rK   rL   rM   r&   r   r   r  r   all)rS   rT   rU   r  s       ra   +test_pairwise_distances_chunked_reduce_noner  X  s    
))


"C'")),U)CA)	45fH h...H~Hx=13(3333r   good_reducec                     t        |       S r   r  Dr  s     ra   r   r   h  s
    a r   c                 ,    t        j                  |       S r   )rI   r   r!  s     ra   r   r   i  s    ! r   c                 .    t        |       t        |       fS r   r   r!  s     ra   r   r   j  s    $q'47+ r   c                      ||       S r   r   )r"  r  scipy_csr_types      ra   r   r   m  s    q8I r   c                 P     ||       t        j                  |       t        |       fS r   )rI   r   r  )r"  r  scipy_dok_types      ra   r   r   q  s#    1HHQKG9
 r   c                     t        j                  d      j                  dd      }t        |d | d      }t	        |       y )Nr  r   rF   @   r  )rI   arangereshaper&   next)r  rU   r  s      ra   ,test_pairwise_distances_chunked_reduce_validr.  e  s:    * 			"b!$A)	4[H 	Nr   )
bad_reduceerr_typemessagec                 6    t        j                  | | dd  g      S Nr   rI   concatenater"  ss     ra   r   r     s    AbcF4 r   zlength 11\..* input: 10\.c                 :    | t        j                  | | dd  g      fS r3  r4  r6  s     ra   r   r     s    !R^^Q"#K89 r   z!length \(10, 11\)\..* input: 10\.c                     | d d | fS )N	   r   r6  s     ra   r   r     s    q!uaj r   z length \(9, 10\)\..* input: 10\.c                      y)N   r   r6  s     ra   r   r     r   r   z2returned 7\. Expected sequence\(s\) of length 10\.c                      y)N)r<     r   r6  s     ra   r   r     r   r   z9returned \(7, 8\)\. Expected sequence\(s\) of length 10\.c                 0    t        j                  d      dfS )Nr  r:  )rI   r+  r6  s     ra   r   r     s    "))B-+ r   z-, 9\)\. Expected sequence\(s\) of length 10\.c                     t        j                  d      j                  dd      j                  | d      }t	        |d |d      }t        j                  ||      5  t        |       d d d        y # 1 sw Y   y xY w)	Nr  r   rF   Fr;   r*  r  rx   )rI   r+  r,  rM   r&   rk   rl   r-  )rS   r/  r0  r1  rU   r  s         ra   .test_pairwise_distances_chunked_reduce_invalidrA    sn    D 			"b!$++Lu+EA)	4ZH 
xw	/ X  s   A22A;c                 :   t        | |||      }t        |t              sJ t        |      }|| n|}t	        |      dz  dz  }|D ]"  }|j
                  }|t        ||      dz  k  r"J  t        j                  |      }t        | ||      }	t        ||	d       y )Nr  r?   r>  g      >i   r>   r   r  )r&   r   r   r  r   nbytesmaxrI   r  r#   r,   )
rU   rX   r  r?   genblockwise_distancesmin_block_mibblockmemory_usedrV   s
             ra    check_pairwise_distances_chunkedrK    s    
$Q.QW
XCc=)))s)YAAFQJ'M$ Illc.-@5HHHHI ))$781a/A'6r   )r=   l2r   c                 @   t         j                  j                  d      }|j                  dd      j	                  |d      }t        t        |d|             }t        |      dkD  sJ t        t        j                  t        j                  |            dd	
       y )Nr     r      _BsizescaleFr;   rF   rC  绽|=r   )rI   rJ   rK   normalrM   r  r&   r   r,   r   r  )r?   rS   rT   rU   chunkss        ra   (test_pairwise_distances_chunked_diagonalrW    sz    
))


"C


$
/66|%6PA,QqPQFv;??BGGBIIf-.>r   c                     t         j                  j                  d      }|j                  dd      j	                  |d      }t        || d      }t        t        j                  |      dd	
       y )Nr   rN  rP  rQ  Fr;   rA   r   rT  r  )rI   rJ   rK   rU  rM   r#   r,   r   )r?   rS   rT   rU   r   s        ra   )test_parallel_pairwise_distances_diagonalrY    s[    
))


"C


$
/66|%6PA"1VA>IBGGI&6r   z0ignore:Could not adhere to working_memory configc                    t         j                  j                  d      }|j                  d      j	                  | d      }t        |d dd       t        dd      D ]  }t        |d d	|z  d        t        |j                         d dd       |j                  d
      j	                  | d      }t        ||dd       t        |j                         |j                         dd       t        ||dd       t        ||dd       t        |      }t        |dd      }t        |t              sJ t        |      |u sJ t        j                  t              5  t        |       d d d        y # 1 sw Y   y xY w)Nr   )   r:   Fr;   rF   r=   rC  irA   )r  r:   i'  r   r
  r   )rI   rJ   rK   rL   rM   rK  r   tolistr#   r&   r   r   r-  rk   rl   StopIteration)rS   rT   rU   powerrX   r"  rF  s          ra   test_pairwise_distances_chunkedr_    sX    ))


"C(#**<e*DA$QQ{SsA 
(tAuH[	


 %	
D; 	(#**<e*DA$Q!KP$	
AHHJq %Q%T %Q!KP 	1A
$Qvm
TCc=)))9>>	}	% S	  s   E33E<x_array_constrdense)idsy_array_constrc                 f     | dgg      } |dgdgg      }t        ||      }t        |ddgg       y Nr   rF   rA   r   ri   )r   r,   )r`  rc  rU   rX   r"  s        ra   %test_euclidean_distances_known_resultrf    s@     	uAaSz"AAq!AAc
|$r   c                 v   t         j                  j                  d      }|j                  d      j	                  | d      }|j                  d      j	                  | d      }|j	                  t         j
                        dz  j                  d      j                  dd	      }|j	                  t         j
                        dz  j                  d      j                  dd	      } ||      }t        ||      }t        |||
      }t        |||      }	t        ||||      }
t        ||       t        |	|       t        |
|       t        ||t        j                  |      t        j                  |            }t        j                  t              5  t        ||       d d d        y # 1 sw Y   y xY w)Nr   r  r  Fr;      r  rA   rF   r   r   X_norm_squaredY_norm_squaredrl  rn  )rI   rJ   rK   rL   rM   rj   r~   r,  r   r,   
zeros_likerk   rl   rm   )rS   rc  rT   rU   rX   	X_norm_sq	Y_norm_sqD1D2D3D4wrong_Ds               ra   #test_euclidean_distances_with_normsrx    su    ))


"C(#**<e*DA(#**<e*DA "**%*//Q/7??2FI"**%*//Q/7??2FIqA	Q	"B	Q)	<B	Q)	<B	Q)I	VBBBB "		}}Y/}}Y/	G 
~	& %$% % %s   F//F8	symmetricTc                 L   t         j                  j                  |       }|j                  d      }|r|n|j                  d      }|j	                  t         j
                        dz  j                  d      j                  dd      }|j	                  t         j
                        dz  j                  d      j                  dd      }t        ||      }t        |||      }t        |||      }	t        ||||	      }
t        ||       t        |	|       t        |
|       y )
Nrh  ri  rA   rF   r   r   rk  rm  ro  )
rI   rJ   rK   rL   rM   float32r~   r,  r   r,   )global_random_seedry  rT   rU   rX   rq  rr  rs  rt  ru  rv  s              ra   &test_euclidean_distances_float32_normsr}  (  s     ))

 2
3C(#AC--h7A"**%*//Q/7??2FI"**%*//Q/7??2FI	Q	"B	Q)	<B	Q)	<B	Q)I	VBBBBr   c            	         t         j                  j                  d      } | j                  d      }| j                  d      }|dz  j	                  d      }|dz  j	                  d      }t        ||||      }t        |||j                  dd      |j                  dd            }t        |||j                  dd      |j                  dd            }t        ||       t        ||       t        j                  t        d	
      5  t        |||d d        d d d        t        j                  t        d
      5  t        |||d d        d d d        y # 1 sw Y   ?xY w# 1 sw Y   y xY w)Nr   rh  ri  rA   rF   r   ro  r   zIncompatible dimensions for Xrx   r9   rk  zIncompatible dimensions for Yrm  )rI   rJ   rK   rL   r~   r   r,  r,   rk   rl   r   )rT   rU   rX   rl  rn  rs  rt  ru  s           ra   $test_euclidean_distances_norm_shapesr  9  sg   
))


"C(#A(#AdZZQZ'NdZZQZ'N		1^N
B 
		%--b!4%--b!4	
B 
		%--a4%--a4	
B BB	z)H	I EAq1CDE	z)H	I EAq1CDE EE EE Es   EE(E%(E1c                 x   t         j                  j                  d      }|j                  d      j	                  | d      }d||dk  <   |j                  d      j	                  | d      }d||dk  <   t        ||      } ||      } ||      }t        ||      }t        ||d       |j                  | k(  sJ y )	Nr   r  r  Fr;   皙?rh  ư>r   )	rI   rJ   rK   rL   rM   r   r   r,   rN   )rS   r`  rc  rT   rU   rX   expectedr   s           ra   test_euclidean_distancesr  [  s     ))


"C)$++Lu+EAAa#gJ(#**<e*DAAa#gJQ{HqAqA#Aq)I Ixd3??l***r   c                 "   t         j                  j                  d      }|j                  d      j	                  | d      }d||dk  <   t        t        |            } ||      }t        |      }t        ||d       |j                  | k(  sJ y )Nr   r  Fr;   r  r  r   )
rI   rJ   rK   rL   rM   r   r
   r   r,   rN   )rS   r`  rT   rU   r  r   s         ra   test_euclidean_distances_symr  z  s     ))


"C)$++Lu+EAAa#gJ%(#HqA#A&I Ixd3??l***r   
batch_size)Nr9   r<  e   c                    t         j                  j                  d      }|j                  d      j	                  t         j
                        }d||dk  <   |j                  d      j	                  t         j
                        }d||dk  <   t        ||      } ||      } ||      }t        |||       }t        j                  t        j                  |d            }t        ||d       y )Nr   r  r  rh  rX   r  r  r   )rI   rJ   rK   rL   rM   r{  r   r   sqrtmaximumr,   )r  r`  rc  rT   rU   rX   r  r   s           ra   test_euclidean_distances_upcastr    s     ))


"C)$++BJJ7AAa#gJ(#**2::6AAa#gJQ{HqAqA+AzJI

9a01I Ixd3r   c                 p   t         j                  j                  d      }|j                  d      j	                  t         j
                        }d||dk  <   t        t        |            } ||      }t        |||       }t        j                  t        j                  |d            }t        ||d       y )Nr   r  r  r  r  r   )rI   rJ   rK   rL   rM   r{  r   r
   r   r  r  r,   )r  r`  rT   rU   r  r   s         ra   #test_euclidean_distances_upcast_symr    s     ))


"C)$++BJJ7AAa#gJ%(#HqA+AzJI

9a01I Ixd3r   zdtype, eps, rtolg-C6?h㈵>g:0yE>gGz?z failing due to lack of precision)reason)marksdimi@B c                     t        j                  dg|z  g|       }t        j                  d|z   g|z  g|       }t        ||      }t        ||      }t	        ||d       y )Nr   r   r  r   )rI   r   r   r   r,   )rN   epsr   r  rU   rX   r   r  s           ra   'test_euclidean_distances_extreme_valuesr    s]      	3%#+e,A
39+#$E2A#Aq)IQ{HIxd3r   r   c                     t         j                  j                  d      }|j                  dd      }|j                  dd      }t	        |||       }t        |||       }t        ||       y )N9  r   r:   )rX   r   )rI   rJ   rK   r|   r   r   r,   )r   rT   rU   rX   normal_distancenan_distances         ra   8test_nan_euclidean_distances_equal_to_euclidean_distancer    s\     ))


%C		!QA		!QA)!q'BO*17CLO\2r   rU   rX   c                     t        j                  t              5 }t        | |       d d d        d}|t	        j
                        k(  sJ y # 1 sw Y   &xY w)Nr   zBInput contains infinity or a value too large for dtype('float64').)rk   rl   r   r   strvalue)rU   rX   excinfoexp_msgs       ra   ,test_nan_euclidean_distances_infinite_valuesr    sP     
z	" (gQ'( SGc'--((((	( (s   AAzX, X_diag, missing_valuerA   r   c                 *   t        j                  d|g|dgg      }t        | |      }t        ||       t        | d|      }t        |dz  |       t        | | |      }t        ||       t        | | j	                         |      }t        ||       y )N        r   missing_valuesTr   r  rA   )rI   r   r   r,   r<   )rU   X_diagmissing_valueexp_distr   dist_sqdist_twodist_two_copys           ra    test_nan_euclidean_distances_2x2r    s      xx#v45H"1]CDHd#%amTGHaK)&q!MJHHh'+AqvvxVMHm,r   r  c                 F   t        j                  | | gddgg      }t        j                  t         j                  t         j                  gt         j                  dgg      }t        ||       }t	        ||       t        ||j                         |       }t	        ||       y )Nr   rF   r  )rI   r   rO   r   r,   r<   )r  rU   r  r   s       ra   )test_nan_euclidean_distances_complete_nanr    sz    
=-01a&9:Axx"&&"&&)BFFA;78H"1]CDHd#"1affh}MDHd#r   c           	         t        j                  d| dddg| ddd| gd| | | dgg      }t        j                  | dd| dg| | dddg| | | ddgg      }t        |||       }t        |||       }t        ||j                         t        t        |d d	 |d d	 d
|       dgg       t        t        |d	d |d	d d|       t        j                  d      gg       t        ||       }t        |||       }t        ||j                         |       }t        ||       t        ||       t        ||d
      }t        ||d      }	t        ||	       y )Nr   g      @g      @ri   g      @g      @g      @r  rF   Tr  g      D@rA   Fg      9@r;   )rI   r   r   r-   Tr,   r  r<   )
r  rU   rX   rs  rt  ru  rv  D5D6D7s
             ra   'test_nan_euclidean_distances_not_trivalr  "  s   
-c3/Cc=9-sC	
	A 	CmS9M3S9M=#sC	
	A 
!Am	DB	 Am	DBBDD! bqE1Ra5$}	
 4	45	 aFAaFE-	
 '';
<	=>	 
!=	AB	 Am	DB	 AFFH]	KBBB 
!AD	1B	 AE	2BBr   c                     t        j                  dd| dgd| d| gg      }t        || d      }t        j                  |dk\        sJ t        || d      }t	        |d	       y )
NgzG^g     @@gB@g|ï@T)r  r   r   Fr  )rI   r   r   r  r,   )r  rU   dist_squaredr   s       ra   7test_nan_euclidean_distances_one_feature_match_positiver  W  ss    
 	e]E2mZ?	
	A +	-L 66,!#$$$"1]ERDD#r   c                     t         j                  j                  d      } t        j                  | j	                  d            }t        j
                  ||g      }t        |      }t        |ddgddggd       t        j                  |dk\        sJ t        j                  |dk        sJ t        |t        j                  |         ddg       t        j
                  || g      }t        |      }t        j                  |dk\        sJ t        j                  |dk        sJ t        |ddgddgg       t        j                  | j	                  dd            }t        |      }t        |t        j                  |         dg|j                  d	   z         t        j                  |dk\        sJ t        j                  |dk        sJ y )
Nr  i  r  rT  r  ri   rO  i  r   )rI   rJ   rK   r   randr  r   r,   r  diag_indices_fromrR   )rT   r   XAr"  XBrt  rU   s          ra   test_cosine_distancesr  l  s   
))


%C
sxx}A	Aq6	BAAc
S#J/e<66!s(66!s(Ab**1-.c
;	Ar7	B	"	B66")66")B#sc3Z01 	sxxd#$AAAb**1-.
0BC66!s(66!s(r   c                     d } t         j                  j                  d      }|j                  d      }|j                  d      }t        j                  |D cg c]  }|D cg c]  } | ||       c} c}}      }t        ||      }t        ||       |j                  d      }d}t        j                  t        |      5  t        |       d d d        y c c}w c c}}w # 1 sw Y   y xY w)Nc                 Z   |d   | d   z
  }|d   | d   z
  }t        j                  |dz        dz  t        j                  | d         t        j                  |d         z  t        j                  |dz        dz  z  z   }dt        j                  t        j                  |            z  }|S )Nr   rF   rA   )rI   sincosarcsinr  )r   r   diff_latdiff_lonacs         ra   slow_haversine_distancesz:test_haversine_distances.<locals>.slow_haversine_distances  s    Q4!A$;Q4!A$;FF8a< A%FF1Q4L266!A$<'"&&A*>!*CC
 		"''!*%%r   r   rD   )r  rA   )r  r   z-Haversine distance only valid in 2 dimensionsrx   )
rI   rJ   rK   rL   r   r   r,   rk   rl   r   )	r  rT   rU   rX   r   r   rs  rt  err_msgs	            ra   test_haversine_distancesr    s     ))


"C&!A'"A	J1A>q,Q2>J	KB	Q	"BB'"A=G	z	1 A  ?J s$   	C
"C2C
C%C
%C.c                  P    dgdgg} dgdgg}t        | |      }t        |ddg       y re  )r!   r,   rU   rX   r"  s      ra   test_paired_euclidean_distancesr    6    
qc
A
qc
A"1a(AASz"r   c                  P    dgdgg} dgdgg}t        | |      }t        |ddg       y re  )r"   r,   r  s      ra   test_paired_manhattan_distancesr    r  r   c                  P    dgdgg} dgdgg}t        | |      }t        |ddg       y )Nr   rF   rA   rE   )r   r,   r  s      ra   test_paired_cosine_distancesr    s6    
qc
A
qc
A1%AASz"r   c                  T   t         j                  j                  d      } | j                  d      }| j                  d      }t	        ||      }d}t        |||      }|j                  t        k(  sJ t        |      D ]t  \  }}t        |      D ]a  \  }}	t        j                  ||	z
  dz  ||	z   z         }
t        j                  ||
z        }t        |||f   |
       t        |||f   |       c v t        |      }t        t        j                  |      d       t        j                  |dkD        sJ t        j                  |t        j                  t        j                  |            z
  dk        sJ | j                  d      j                  t         j                         }| j                  d      j                  t         j                         }t        ||      }|j                  t         j                   k(  sJ | j                  d      j                  t         j"                        }t        ||      }t        j$                  |      j                         sJ |j                  t        k(  sJ dd	gd
dgg}ddgddgg}t        ||      }|d   |d   kD  sJ |d   |d   kD  sJ t'        j(                  t*              5  t        ddgg       d d d        t'        j(                  t*              5  t        ddggddgg       d d d        t'        j(                  t*              5  t        ddggddgg       d d d        t'        j(                  t*              5  t        ddggg dg       d d d        y # 1 sw Y   xY w# 1 sw Y   ~xY w# 1 sw Y   VxY w# 1 sw Y   y xY w)Nr   r8   r  r   r   rA   rF   g333333?gffffff?r   g?rB   )r   rF   )rF   rF   )rF   r   r   )皙?r  g333333?)rI   rJ   rK   rL   r   r   rN   float	enumerater~   expr-   r.   r   r  rM   r{  int32isfiniterk   rl   r   )rT   rU   rX   K_addr   r   ir   jr   r   chi2_exps               ra   test_chi_square_kernelr    s<   
))


"C&!A'"A A&EEAq&A77e! 31aL 	3DAqFFAEa<1q5122Dvvedl+HadT2!Q$2		33 	AArwwqz1%66!a%==66!bggbggaj))A-...&!((4A'"))"**5AAqA77bjj    	'"))"((3AAqA;;q>77e sc1XA
Q#sAAqAT7QtWT7QtW 
z	" aWI	z	" +aWIRz*+	z	" *aVHBxj)* 
z	" 1aVH/01 1 + +* *1 1s0   M:6N*NN:NNNN'kernelc                     t         j                  j                  d      }|j                  d      } | ||      }t	        ||j
                  d       y )Nr   r8      )rI   rJ   rK   rL   r,   r  )r  rT   rU   r   s       ra   test_kernel_symmetryr    sC     ))


"C&!Aq!AAqssBr   c                     t         j                  j                  d      }|j                  d      } ||      } | ||      } | ||      }t	        ||       y Nr   r8   )rI   rJ   rK   rL   r,   )r  rf   rT   rU   ro   r   r   s          ra   test_kernel_sparser    sS     ))


"C&!AQHq!A	(	#BArr   c            	         t         j                  j                  d      } | j                  d      }t	        ||      }t        |j                  d d d   |D cg c]  }t        j                  |      dz   c}       y c c}w )Nr   r8      rA   )	rI   rJ   rK   rL   r   r,   flatr   norm)rT   rU   r   r   s       ra   test_linear_kernelr    sc    
))


"C&!AaAAFF3Q3Kq!A!&++a.A"5!AB!As   A>
c                      t         j                  j                  d      } | j                  d      }t	        ||      }t        |j                  d d d   t        j                  d             y )Nr   r8   r  r9   )rI   rJ   rK   rL   r)   r,   r  onesrT   rU   r   s      ra   test_rbf_kernelr  #  sP    
))


"C&!A1aAAFF3Q3K,r   c                     t         j                  j                  d      } | j                  d      }t	        ||      }t        t        j                  |      t        j                  d             t        j                  |dkD        sJ t        j                  |t        j                  t        j                  |            z
  dk        sJ y )Nr   r8   r9   rF   )	rI   rJ   rK   rL   r   r,   r   r  r  r  s      ra   test_laplacian_kernelr  +  s    
))


"C&!AAABGGAJ
+ 66!a%==66!bggbggaj))A-...r   zmetric, pairwise_funcr   r   c                    t         j                  j                  d      }|j                  d      }|j                  d      } ||      } ||      } |||d      }t	        |      sJ  |||d      }	t	        |	      rJ t        |j                         |	       t        |||       }
t        |j                         |
       y )Nr   r8   r   F)dense_outputTrz   )rI   rJ   rK   rL   r   r,   toarrayr'   )r?   pairwise_funcrf   rT   rU   rX   XcsrYcsrr   r   K3s              ra   &test_pairwise_similarity_sparse_outputr  7  s     ))


"C&!A&!ADD 
tT	6BB<< 
q!$	/B|BJJL"% 
!q	0BBJJL"%r   c                 R   t         j                  j                  d      }|j                  d      }|j                  d      } | |      } | |      }|d f||f|d f||ffD ]E  \  }}t	        ||d      }t        |      }|t        |      }t	        ||d      }	t        ||	       G y )Nr   r8   r   r   rz   r   )rI   rJ   rK   rL   r'   r+   r,   )
rf   rT   rU   rX   r  r  X_Y_r   r   s
             ra   test_cosine_similarityr  Q  s     ))


"C&!A&!ADDt9q!ftTlT4LA  B bBx8r]>2BbBx8B r   c                      t        j                  t        j                  d      d      } t        | d       \  }}||u sJ t	        | |       y N(   r9   r>  )rI   resizer+  r   r.   )r  
XA_checked
XB_checkeds      ra   test_check_dense_matricesr  f  sE     
299R=&	)B22t<J
###r:&r   c                     t        j                  t        j                  d      d      } t        j                  t        j                  d      d      }t        | |      \  }}t	        | |       t	        ||       t        j                  t        j                  d      d      }t        | |      \  }}t	        | |       t	        ||       y )Nr   r      r:   r>  )rI   r  r+  r   r.   r   r  r  r  r  s       ra   test_check_XB_returnedr
  o  s     
299R=&	)B	299R=&	)B22r:J
r:&r:&	299R=&	)B0R8J
r:&r:&r   c                     t        j                  t        j                  d      d      } t        j                  t        j                  d      d      }t        j                  t
              5  t        | |       d d d        t        j                  t        j                  d      d      }t        j                  t
              5  t        | |       d d d        y # 1 sw Y   axY w# 1 sw Y   y xY w)N-   )r9   r:  r  r  $   )r:   r:  )rI   r  r+  rk   rl   r   r   r   r  r  s     ra   test_check_different_dimensionsr    s    	299R=&	)B	299R=&	)B	z	" &b"%& 
299U#V	,B	z	" $B#$ $	& &$ $s   ,CC%C"%C.c                     t        j                  d      j                  dd      } t        j                  d      j                  dd      }t        j                  t
              5  t        | |       d d d        t        j                  d      j                  dd      } t        j                  d      j                  dd      }t        j                  t
              5  t        | |       d d d        y # 1 sw Y   xY w# 1 sw Y   y xY w)Nr  r:  r9   r  r:   r>  )rI   r+  r,  rk   rl   r   r   r  s     ra   test_check_invalid_dimensionsr    s     
2		q!	$B	2		q!	$B	z	" &b"%&	2		q!	$B	2		q!	$B	z	" &b"%& &	& && &s   $C2C>2C;>Dc                 R   t         j                  j                  d      }|j                  d      } | |      }|j                  d      } | |      }t	        ||      \  }}t        |      sJ t        ||z
        j                         dk(  sJ t        |      sJ t        ||z
        j                         dk(  sJ t	        ||      \  }}t        |      sJ t        ||z
        j                         dk(  sJ t        |      sJ t        ||z
        j                         dk(  sJ y r  )rI   rJ   rK   rL   r   r   r   r~   )	rf   rT   r  	XA_sparser  	XB_sparser  r  XA_2_checkeds	            ra   test_check_sparse_arraysr    s,    ))


"C			6	"Bb!I			6	"Bb!I29iHJ
 Jy:%&**,111Jy:%&**,1114Y	JJJy:%&**,111L!!!|j()--/1444r   c                 ~    | j                   }t        |      dkD  rt        d | D              S t        d | D              S )NrF   c              3   2   K   | ]  }t        |        y wr   )tuplify)r  r]   s     ra   r  ztuplify.<locals>.<genexpr>  s     /cWS\/s   c              3       K   | ]  }|  y wr   r   )r  rs     ra   r  ztuplify.<locals>.<genexpr>  s     N1QNs   )rR   r   rP   )rU   r7  s     ra   r  r    s8    	A
1vz/Q/// NN""r   c                      t         j                  j                  d      } | j                  d      }t	        |      }| j                  d      }t	        |      }t        ||      \  }}t        ||       t        ||       y r  )rI   rJ   rK   rL   r  r   r.   )rT   r  	XA_tuplesr  	XB_tuplesr  r  s          ra   test_check_tuple_inputr    sm    
))


"C			6	"BI			6	"BI29iHJ
y*-y*-r   c                  B   t        j                  t        j                  d      d      j                  t         j                        } t        j                  t        j                  d      d      j                  t         j                        }t        | d       \  }}|j                  t         j                  k(  sJ t        | |      \  }}|j                  t         j                  k(  sJ |j                  t         j                  k(  sJ t        | j                  t              |      \  }}|j                  t        k(  sJ |j                  t        k(  sJ t        | |j                  t                    \  }}|j                  t        k(  sJ |j                  t        k(  sJ y r  )rI   r  r+  rM   r{  r   rN   r  r	  s       ra   test_check_preserve_typer!    sD   	299R=&	)	0	0	<B	299R=&	)	0	0	<B22t<J
rzz))) 32r:J
rzz)))rzz))) 3299U3CRHJ
u$$$u$$$ 32ryy7GHJ
u$$$u$$$r   r   
seuclideanmahalanobisdist_functionc           
      8   t        d      5  t        j                  j                  d      }|j	                  d      }t        t        ||            }t        j                  t         ||||                   }t        ||       d d d        y # 1 sw Y   y xY w)Nr   )r  r   r  r>   r   )
r   rI   rJ   rK   rL   r   r
   r  rP   r,   )r   r?   r$  rT   rU   expected_distr   s          ra   +test_pairwise_distances_data_derived_paramsr'    s|     
s	+ -ii##A&i("56#:;yy}QvfMNOm,- - -s   A:BBc                 
   t         j                  j                  d      }|j                  d      }|j                  d      }t	        j
                  t        d|  d      5  t        |||        d d d        y # 1 sw Y   y xY w)Nr   r  z+The '(V|VI)' parameter is required for the z metricrx   r>   )rI   rJ   rK   rL   rk   rl   r   r#   )r?   rT   rU   rX   s       ra   1test_pairwise_distances_data_derived_params_errorr)    sv     ))


"C)$A)$A	<&Q
 0 	1a/	0 0 0s   !A99B)
braycurtiscanberra	chebyshevcorrelationhammingr#  r	   r"  r   r   r   r=   y_is_xzY is Xz
Y is not Xc           	         t         j                  j                  d      }|j                  d      j	                  |d      }i }|r|}t        t        ||             }n|j                  d      j	                  |d      }t        |||       }| dk(  r?dt        j                  t        j                  ||g      ddt         j                  	      i}nb| d
k(  r]dt         j                  j                  t        j                  t        j                  ||g      j                              j                  i}t        ||fd| i|}t!        ||       y )Nr   r8   Fr;   r>   r"  VrF   )r   ddofrN   r#  VIr?   )rI   rJ   rK   rL   rM   r   r
   r   varr  rj   r   invcovr  r#   r,   )	r?   rS   r/  rT   rU   r   rX   r&  r   s	            ra   )test_numeric_pairwise_distances_datatypesr7     s   6 ))


"C&!((E(BAF"56#:;f%,,\,Fa62\!266"))QF"3!!2::VWF}$BIIMM"&&Aq61B1D1D*EFHHIFa<6<V<DD-(r   pairwise_distances_funcc                     ddgdt         j                  gddgddgg} | ||d      }t        j                  |      j                         rJ y)	z8Check that `nan_euclidean` is lenient with `nan` values.r   rF   rA   r   r9   rC   r>   N)rI   rO   isnanany)r8  rU   outputs      ra   test_nan_euclidean_supportr=  1  sR     Q!RVVq!fq!f-A$Q/BFxx##%%%%r   c                  (   t         j                  t         j                  gt         j                  t         j                  gt         j                  t         j                  gg} t        | | d      }ddgddgddgg}t        ||d      }t        ||       y)zyCheck that the behavior of constant input is the same in the case of
    full of nan vector and full of zero vector.
    rC   r>   r   N)rI   rO   r$   r,   )X_nan
argmin_nanX_constargmin_consts       ra   (test_nan_euclidean_constant_input_argminrC  >  su    
 ffbff/"&&"&&1ABE*5%PJ1v1v1v&G,WgoVLJ-r   zX,Y,expected_distance)r  ababc)r  r   ri   )r   r  r   )ri   r   r  r  rD  r  r   ri   c                 >    d }t        | ||      }t        ||       y)z8Check pairwise_distances with lists of strings as input.c                 V    t        j                  t        |       t        |      z
        S r   )rI   r   r   r   s     ra   dummy_string_similarityzLtest_pairwise_dist_custom_metric_for_string.<locals>.dummy_string_similarity^  s    vvc!fs1vo&&r   )rU   rX   r?   N)r#   r,   )rU   rX   expected_distancerH  actual_distances        ra   +test_pairwise_dist_custom_metric_for_stringrK  L  s#    $' )1:QROO%67r   c                      d } t        j                  g dg dg dgt              }t        j                  g dg dg dg      }t        || 	      }t	        ||       y
)zjCheck that pairwise_distances does not convert boolean input to float
    when using a custom metric.
    c                 V    d| |z  j                         | |z  j                         z  z
  S )NrF   )r~   )v1v2s     ra   dummy_bool_distzBtest_pairwise_dist_custom_metric_for_bool.<locals>.dummy_bool_distj  s&    BG==?b2g]]_444r   )rF   r   r   r   )rF   r   rF   r   )rF   rF   rF   rF   r   )r  rE         ?)rE   r  rE   )rQ  rE   r  )rU   r?   N)rI   r   r   r#   r,   )rP  rU   rI  rJ  s       ra   )test_pairwise_dist_custom_metric_for_boolrR  e  sV    
5 	,l;4HA	
 )1_EOO%67r   c                      | t        j                  d            g} | t        j                  d            g} t        dd      d t        ||      D               y )Nr   rA   r   )r   
max_nbytesc              3   N   K   | ]  \  }} t        t              ||        y wr   )r6   r   )r  m1m2s      ra   r  z9test_sparse_manhattan_readonly_dataset.<locals>.<genexpr>  s)      %17R$#$R,%s   #%)rI   r  r5   zip)rf   	matrices1	matrices2s      ra   &test_sparse_manhattan_readonly_datasetr[  |  sU     rwwv/0Irwwv/0I %HA!$ %;>y);T% r   c                     t         j                  j                  d      } t         j                  j                  d      }d}t        j                  t
        |      5  t        | |d       d d d        t        j                  t
        |      5  t        | |d       d d d        y # 1 sw Y   <xY w# 1 sw Y   y xY w)Nrh  )rR  z5'force_all_finite' was renamed to 'ensure_all_finite'rx   T)force_all_finite)rI   rJ   uniformrk   r   FutureWarningr   r#   )rU   rX   r   s      ra   $test_force_all_finite_rename_warningr`    s    
		x(A
		x(A
AC	m3	/ ;aT:; 
m3	/ 81a$78 8; ;8 8s   B(B4(B14B=)r=   )r   typesr   numpyrI   rk   r   scipy.sparser   scipy.spatial.distancer   r   r   r	   r
   r   sklearnr   sklearn.exceptionsr   sklearn.metrics.pairwiser   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r    r!   r"   r#   r$   r%   r&   r'   r(   r)   r*   sklearn.preprocessingr+   sklearn.utils._testingr,   r-   r.   r/   sklearn.utils.fixesr0   r1   r2   r3   r4   sklearn.utils.parallelr5   r6   rb   markparametrizerr   DeprecationWarningr   r   r   r   r+  rM   _minkowski_kwdsr   rj   r{  r   r   r   r   r   r   itemsr   r   r  r  r  r  r.  r   rn   rA  rK  rW  rY  filterwarningsr_  r   __name__rf  rx  r}  r  r  r  r  r  paramxfailr  r  infr  r  rO   r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r  r
  r  r  r  r  r  r!  r'  r)  r7  r=  rC  rK  rR  r[  r`  )r&  r(  	containers   000ra   <module>rw     s.        !  # 4       > ,   5L^ .9.9.9.9>< : : : :><F ,-#=>: ? .:<2 "46F!GH% I%:F "		!Q..xe.D1M 	["-	
 	

 
<(A7	.#?$ 2::rzz3"?@ A%&I T .9 :	
>&
7 )?)9)?)?)AB.9& : C&*( .9.9vA : :vAr7"
4  $+ - )7I -  )7 	
()( ) 5(	
 :0	

 
!*.QRA	
  H	
 ,<	
->?>7  #EF? G? #EF7 G7 NO! P!H XXJ		HIY''HH  
 XXJ		HIY''HH  
%% XXJ		HIY''HH  
%
%@ tUm4 5 ED XXJ		HIY''HH  
 XXJ		HIY''HH  
++* XXJ		HIY''HH  
+
+$ '89XXJ		HIY''HH  
 XXJ		HIY''HH  
4 :4( '89XXJ		HIY''HH  
4 :4" 	T4 JJ++##+M#N		
 G-	4 .	4 T5M23 33 xrxx"&&!61rvvg,8PQRxrxx"&&!61rvvg,8PRVWX) Y S) 	Aq6Aq6"	#WRWWQZ8	Aq6Arvv;'	('"''!*bff=	BFFA;BFF,	-rvvrvv>	BFFA;,	-wrwwqz266B	Arvv;BFF,	-wrwwqz266B	Aq6Aq6"	#WRWWQZ4	Aq6Ar7#	$gbggaj"5	B7QG$	%rvvr2	B7RG$	%wrwwqz26	Ar7QG$	%wrwwqz26--  2662,7	$ 8	$ 2662,71 81h 2662,7 8(<6###31l 
 
  
 .9 :
C-	/ +< => .9& :	
&* .9  : ('' 	$& .95 :5,#	.%0 Aq6*L-#@A(*DE
- B +

- L-#@A0 B0 " D%=x6NO) P#$)> 24QR&	&.  o?	
 $K3Z#sc3Z0	
888. .9 :
8{ H I
 I Ip I
 I4 I0 I
 I4 IsB   w3w"w)w;w0w$7w)	w.4w3;w8.w=