
    e!hK                          G d  d      Z y)c                        e Zd ZdZdZed        Zed        Zed        Zed        Z	ed        Z
ed        Zed	        Zd
 Zd Zd Zd Zd Z eeed      Zd Zd Zd ZddZd Zd Zd Zd fd	Z xZS )spmatrixzThis class provides a base class for all sparse matrix classes.

    It cannot be instantiated.  Most of the work is provided by subclasses.
    )   c                     ddl m} |S )N   )
bsr_matrix)_bsrr   )selfr   s     \/var/www/html/diagnosisapp-backend/venv/lib/python3.12/site-packages/scipy/sparse/_matrix.py_bsr_containerzspmatrix._bsr_container       $    c                     ddl m} |S )Nr   )
coo_matrix)_coor   )r	   r   s     r
   _coo_containerzspmatrix._coo_container   r   r   c                     ddl m} |S )Nr   )
csc_matrix)_cscr   )r	   r   s     r
   _csc_containerzspmatrix._csc_container   r   r   c                     ddl m} |S )Nr   )
csr_matrix)_csrr   )r	   r   s     r
   _csr_containerzspmatrix._csr_container   r   r   c                     ddl m} |S )Nr   )
dia_matrix)_diar   )r	   r   s     r
   _dia_containerzspmatrix._dia_container   r   r   c                     ddl m} |S )Nr   )
dok_matrix)_dokr   )r	   r   s     r
   _dok_containerzspmatrix._dok_container!   r   r   c                     ddl m} |S )Nr   )
lil_matrix)_lilr#   )r	   r#   s     r
   _lil_containerzspmatrix._lil_container&   r   r   c                 $    | j                  |      S N)_matmul_dispatchr	   others     r
   __mul__zspmatrix.__mul__,   s    $$U++r   c                 $    | j                  |      S r'   )_rmatmul_dispatchr)   s     r
   __rmul__zspmatrix.__rmul__/   s    %%e,,r   c                      ddl m}  || |      S )Nr   )matrix_power)linalgr0   )r	   powerr0   s      r
   __pow__zspmatrix.__pow__3   s    (D%((r   c                 ~    | j                  |d      j                  | j                        }|j                  | _        y)z$Set the shape of the matrix in-placeF)copyN)reshapeasformatformat__dict__)r	   shapenew_selfs      r
   	set_shapezspmatrix.set_shape:   s2     <<E<2;;DKKH ))r   c                     | j                   S )zGet the shape of the matrix)_shaper	   s    r
   	get_shapezspmatrix.get_shapeA       {{r   zShape of the matrix)fgetfsetdocc                 "    | j                         S )z7Upcast matrix to a floating point format (if necessary))	_asfptyper?   s    r
   asfptypezspmatrix.asfptypeH   s    ~~r   c                 "    | j                         S )z3Maximum number of elements to display when printed.)_getmaxprintr?   s    r
   getmaxprintzspmatrix.getmaxprintL   s      ""r   c                     | j                   S )zMatrix storage format)r8   r?   s    r
   	getformatzspmatrix.getformatP   rA   r   c                 &    | j                  |      S )zNumber of stored values, including explicit zeros.

        Parameters
        ----------
        axis : None, 0, or 1
            Select between the number of values across the whole array, in
            each column, or in each row.
        )axis)_getnnz)r	   rN   s     r
   getnnzzspmatrix.getnnzT   s     |||&&r   c                 >    | j                         j                         S )zReturn the Hermitian transpose of this matrix.

        See Also
        --------
        numpy.matrix.getH : NumPy's implementation of `getH` for matrices
        )	conjugate	transposer?   s    r
   getHzspmatrix.getH_   s     ~~))++r   c                 $    | j                  |      S )zgReturns a copy of column j of the matrix, as an (m x 1) sparse
        matrix (column vector).
        )_getcol)r	   js     r
   getcolzspmatrix.getcolh        ||Ar   c                 $    | j                  |      S )z`Returns a copy of row i of the matrix, as a (1 x n) sparse
        matrix (row vector).
        )_getrow)r	   is     r
   getrowzspmatrix.getrown   rY   r   c                 $    t         |   ||      S )a  
        Return a dense representation of this sparse matrix.

        Parameters
        ----------
        order : {'C', 'F'}, optional
            Whether to store multi-dimensional data in C (row-major)
            or Fortran (column-major) order in memory. The default
            is 'None', which provides no ordering guarantees.
            Cannot be specified in conjunction with the `out`
            argument.

        out : ndarray, 2-D, optional
            If specified, uses this array (or `numpy.matrix`) as the
            output buffer instead of allocating a new array to
            return. The provided array must have the same shape and
            dtype as the sparse matrix on which you are calling the
            method.

        Returns
        -------
        arr : numpy.matrix, 2-D
            A NumPy matrix object with the same shape and containing
            the same data represented by the sparse matrix, with the
            requested memory order. If `out` was passed and was an
            array (rather than a `numpy.matrix`), it will be filled
            with the appropriate values and returned wrapped in a
            `numpy.matrix` object that shares the same memory.
        )supertodense)r	   orderout	__class__s      r
   r`   zspmatrix.todenset   s    < wuc**r   r'   )NN)__name__
__module____qualname____doc__	_allow_ndpropertyr   r   r   r   r   r!   r%   r+   r.   r3   r<   r@   r:   rG   rJ   rL   rP   rT   rX   r]   r`   __classcell__)rc   s   @r
   r   r      s     I             
,-)* )).0E #	',+ +r   r   N)r    r   r
   <module>rl      s   Q+ Q+r   