
    xf	              	       z    d dl Zd dlmZmZ ddlmZmZmZm	Z	 ej                  Zeddddd ej                  ddf	dZy)    N)
csr_matrixissparse   )csgraph_to_densecsgraph_from_densecsgraph_masked_from_densecsgraph_from_maskedTFc                    |s|st        d      |s&t        |       r| j                  dk(  r| j                  } t        |       r#|rt	        | t
        |      } nt        | |      } nt        j                  j                  |       rF|r8| j                  }t        j                  | j                  t
        |      } || |<   ndt        |       } nX|rGt        | |||
|	      } | j                  }t        j                  | j                  t
              } || |<   nt!        | ||	|
      } | j"                  dk7  rt        d	      | j$                  d
   | j$                  d   k7  rt        d      | S )z7Routine for validation and conversion of csgraph inputsz*Internal: dense or csr output must be truecsc)dtypecopy)
null_value)r   r   nan_nullinfinity_null)r   )r   r   r      z#compressed-sparse graph must be 2-Dr   r   z,compressed-sparse graph must be shape (N, N))
ValueErrorr   formatTr   DTYPEr   npmaisMaskedArraymaskarraydatar	   r   asarrayr   ndimshape)csgraphdirectedr   
csr_outputdense_outputcopy_if_densecopy_if_sparsenull_value_innull_value_outr   r   r   s               B/usr/lib/python3/dist-packages/scipy/sparse/csgraph/_validation.pyvalidate_graphr(   	   s>    ,EFF (7+%0G)) NKG&w>JG			W	%<<Dhhw||5}MG*GDM)'2G/5B;H9A>K	MG
 <<DjjU;G*GDM(]7D2:<G ||q>??}}Q7==++GHHN    )numpyr   scipy.sparser   r   _toolsr   r   r   r	   float64r   infr(    r)   r'   <module>r0      sB     -3 3 	

 -2"!&u!"266!%	/r)   