U
    9%e                     @   s   d dl mZmZ d dlmZmZmZmZ d dlm	Z	m
Z
mZ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 d dlmZ edd	d
ZedeeZedeeZedddZdd Zdd Zdd Z dd Z!dd Z"dS )    )Ssymbols)eyeonesMatrix
ShapeError)	Identity
MatrixExprMatrixSymbolDeterminantdetper
ZeroMatrix	Transpose	Permanent)	OneMatrix)raises)Q)refinenT)integerABC      c                  C   s   t tttstt tttr$tttdd  ttddksFttt	dddddddddddg	dksptttt } tt
d	d  ttjtkstd S )
Nc                   S   s   t tS N)r   r    r   r   p/var/www/html/Darija-Ai-API/env/lib/python3.8/site-packages/sympy/matrices/expressions/tests/test_determinant.py<lambda>       ztest_det.<locals>.<lambda>r         r         c                   S   s
   t tjS r   )r   r   Oner   r   r   r   r      r    )
isinstancer   r   AssertionErrorr	   r   r   r   r   r   	TypeErrorarg_r   r   r   test_det   s    *r,   c                   C   s   t ttdkstt tttdks*tt tttttttksJtt tdddks`tt tdddksvtt ttt tkstd S )Nr!   r   r"   )	r   r   r   r'   r   r   r   r   r   r   r   r   r   test_eval_determinant   s     r-   c                   C   sx   t ttttdkstt ttttdks8tt ttttdksTtt ttttttksttd S )Nr!   r   )	r   r   r   r   Z
orthogonalr'   ZsingularZunit_triangularnormalr   r   r   r   test_refine(   s    r/   c                  C   s<   t t} t t}| jst|js$t| | ||  ks8td S r   )r   r   r   Zis_commutativer'   )Zdet_aZdet_br   r   r   test_commutative/   s
    

r0   c                  C   s   t tttstt tttr$tt ttts6tttdd dksPtttt } tt	dddddddddddg	dkstt
tdd	  ttjtkstd S )
Nr      r!   r"   r   r#   g   c                   S   s
   t tjS r   )r   r   r%   r   r   r   r   r   =   r    z test_permanent.<locals>.<lambda>)r&   r   r   r'   r	   r   r   Zdoitr   r   r   r(   r)   r*   r   r   r   test_permanent6   s    *r3   N)#Z
sympy.corer   r   Zsympy.matricesr   r   r   r   Zsympy.matrices.expressionsr   r	   r
   r   r   r   r   r   r   Z"sympy.matrices.expressions.specialr   Zsympy.testing.pytestr   Zsympy.assumptions.askr   Zsympy.assumptions.refiner   r   r   r   r   r,   r-   r/   r0   r3   r   r   r   r   <module>   s   ,	