o
    e1                     @  s  U d dl mZ d dlmZ d dlmZmZ d dlmZ d dl	m
Z
mZ d dlmZmZmZmZ d dlmZ d dl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 d dlm Z  d dl!m"Z" d dl#m$Z$m%Z% d dl&m'Z'm(Z( d dl)m*Z* d dl+m,Z, d dl-m.Z.m/Z/ d dlm0Z0 d dl1m2Z2m3Z3 d dl4m5Z5 d dl6m7Z7m8Z8m9Z9m:Z:m;Z;m<Z<m=Z= d dl>m?Z? d dl@mAZA ed\ZBZCde0iZDdeEd< eFdeD d}dd ZGd!d" ZHd#d$ ZId%d& ZJd'd( ZKd)d* ZLd+d, ZMd-d. ZNd/d0 ZOd1d2 ZPd3d4 ZQd5d6 ZRd7d8 ZSd9d: ZTd;d< ZUd=d> ZVd?d@ ZWdAdB ZXdCdD ZYdEdF ZZdGdH Z[dIdJ Z\dKdL Z]dMdN Z^dOdP Z_dQdR Z`dSdT ZadUdV ZbdWdX ZcdYdZ Zdd[d\ Zed]d^ Zfd_d` Zgdadb Zhdcdd Zidedf Zjdgdh Zkdidj Zldkdl Zmdmdn Zndodp Zodqdr Zpdsdt Zqdudv Zrdwdx Zsdydz Ztd{d| ZudS )~    )annotations)Any)raiseswarns_deprecated_sympy)Q)FunctionWildFunction)AlgebraicNumberFloatIntegerRational)S)DummySymbolWildsymbols)sympify)Abs)rootsqrt)sin)	Heaviside)falsetrue)Matrixones)MatrixSymbol)ImmutableDenseMatrix)CyclePermutation)Str)PointEllipse)srepr)ringfieldZZQQlexgrlexPoly)DMP)FiniteExtensionx,yr    zdict[str, Any]ENVzfrom sympy import *Nc                 K  sN   |du rt }n	t  }t|| t| fi ||ksJ t||| ks%J dS )z
    sT := sreprTest

    Tests that srepr delivers the expected string and that
    the condition eval(srepr(expr))==expr holds.
    N)r.   copyexecr#   eval)exprstringimport_stmtkwargsZENV2 r6   ND:\Projects\ConvertPro\env\Lib\site-packages\sympy/printing/tests/test_repr.pysT#   s   
r8   c                  C  s(   G dd dt } t| tdksJ d S )Nc                   @  s   e Zd Zdd ZdS )ztest_printmethod.<locals>.Rc                 S  s   d| | jd  S )Nzfoo(%s)r   )Z_printargs)selfprinterr6   r6   r7   
_sympyrepr6   s   z&test_printmethod.<locals>.R._sympyreprN)__name__
__module____qualname__r<   r6   r6   r6   r7   R5   s    r@   zfoo(Symbol('x')))r   r#   x)r@   r6   r6   r7   test_printmethod4   s   rB   c                   C  sf   t tt d ttd d dddksJ ttd d dddks#J ttd	d
ddddks1J d S )NzAdd(Symbol('x'), Symbol('y'))      r(   orderz-Add(Pow(Symbol('x'), Integer(2)), Integer(1))oldz-Add(Integer(1), Pow(Symbol('x'), Integer(2)))z	x + 3 - 2Fevaluatenonez:Add(Symbol('x'), Integer(3), Mul(Integer(-1), Integer(2)))r8   rA   yr#   r   r6   r6   r6   r7   test_Add;   s    rM   c                  C  sJ   ddl m}  ddlm} | |fD ]}|td }tt||ks"J qd S )Nr   )Add)Mulzx:256)Zsympy.core.addrN   Zsympy.core.mulrO   r   r1   r#   )rN   rO   opr2   r6   r6   r7   #test_more_than_255_args_issue_10259B   s   rQ   c                   C  s<   t tdtd t tdd t ttd t td d S )NfzFunction('f')(Symbol('x'))zFunction('f')zsin(Symbol('x'))r   )r8   r   rA   r   r6   r6   r6   r7   test_FunctionJ   s   rS   c                   C  s"   t ttd t ttdd d S )NzHeaviside(Symbol('x'))rD   z"Heaviside(Symbol('x'), Integer(1)))r8   r   rA   r6   r6   r6   r7   test_HeavisideS   s   rT   c                   C  s,   t tddd t ttddddd d S )Nr   zPoint2D(Integer(0), Integer(0))   rD   z@Ellipse(Point2D(Integer(0), Integer(0)), Integer(5), Integer(1)))r8   r!   r"   r6   r6   r6   r7   test_GeometryX   s   rV   c                   C  s  t tjd t tjd t tjd t tjd t tjd t tjd t tjd t tj	d t tj
d	 t tjd
 t tjd t tjd t tjd t tjd t tjd t tjd t tjd t tjd t tjd t tjd t tjd t tjd t tjd d S )NCatalanZzoo
EulerGammaEGoldenRatioTribonacciConstantzRational(1, 2)IZoonanz-oozInteger(-1)z
Integer(1)piz
Integer(0)	ComplexesEmptySequenceEmptySetNaturals	Naturals0	RationalsRealsUniversalSet)r8   r   rW   ZComplexInfinityrX   ZExp1rZ   r[   ZHalfZImaginaryUnitInfinityNaNNegativeInfinityZNegativeOneZOnePiZZeror_   r`   ra   rb   rc   rd   re   rf   r6   r6   r6   r7   test_Singletons_   s.   rk   c                   C     t tdd d S )N   z
Integer(4))r8   r   r6   r6   r6   r7   test_Integerz      rn   c                   C  s   t ttdgd d S )Nrm   z[Symbol('x'), Integer(4)])r8   rA   r   r6   r6   r6   r7   	test_list~      rp   c                  C  sz   t dftdffD ]2\} }t| td dgttt ggd|  t|  d|  t| td dgttt ggd|  qd S )NZMutableDenseMatrixr   rD   zM%s([[Symbol('x'), Integer(1)], [Symbol('y'), Add(Symbol('x'), Symbol('y'))]])z%s([]))r   r   r8   rA   rL   )clsnamer6   r6   r7   test_Matrix   s   (rt   c                   C  s4   t tddd t tddd t tddd d S )Nr      zMutableDenseMatrix(0, 3, [])rm   zMutableDenseMatrix(4, 0, [])zMutableDenseMatrix([]))r8   r   r6   r6   r6   r7   test_empty_Matrix   s   rv   c                   C  s$   t tddd t tddd d S )NrD   ru   zRational(1, 3)zRational(-1, 3))r8   r   r6   r6   r6   r7   test_Rational      rx   c                   C  s   t tdddd t tdddd t tdd	dd
 t tdddd t tdddd t tdddd t tdddd
 t tdddd t tddd d S )Nz1.23ru   )ZdpszFloat('1.22998', precision=13)z
1.23456789	   z$Float('1.23456788994', precision=33)z1.234567890123456789   z.Float('1.234567890123456789013', precision=66)z0.60038617995049726   z*Float('0.60038617995049726', precision=53)   )	precision!   B   5   )r8   r
   r6   r6   r6   r7   
test_Float   s*   
r   c                   C  s*   t td t td t tdddd d S )NSymbol('x')zSymbol('y')rA   T)negativezSymbol('x', negative=True))r8   rA   rL   r   r6   r6   r6   r7   test_Symbol   s   

r   c                  C  sD   t dddd} d}d}t| ||fv sJ tt| t| ks J d S )NrA   r   rD   )r   integerz)Symbol('x', integer=True, negative=False)z)Symbol('x', negative=False, integer=True))r   r#   r1   r.   )rA   s1s2r6   r6   r7   test_Symbol_two_assumptions   s
   r   c                   C  sZ   t tdd t tdddd t tdddd t tdddd t tdd	dd d S )
NrA   r   F)ZcommutativezSymbol('x', commutative=False)r   TzSymbol('x', commutative=True)rD   )r8   r   r6   r6   r6   r7   ,test_Symbol_no_special_commutative_treatment   s
   r   c                   C  s   t tdddd d S )NrA   T)evenzWild('x', even=True))r8   r   r6   r6   r6   r7   	test_Wild   rq   r   c                  C  s    t d} t| dt| j  d S )NdzDummy('d', dummy_index=%s))r   r8   strdummy_index)r   r6   r6   r7   
test_Dummy   s   r   c                  C  sT   t ddd} | tt| ksJ dt| j }dt| j }t| ||fv s(J d S )Nr   T)Znonzeroz(Dummy('d', dummy_index=%s, nonzero=True)z(Dummy('d', nonzero=True, dummy_index=%s))r   r1   r#   r   r   )r   r   r   r6   r6   r7   test_Dummy_assumption   s
   r   c                  C  s2   t ddd} |  }t|dt|j ksJ d S )NnTr   zDummy('n', dummy_index=%s))r   Zas_dummyr#   r   r   )r   r   r6   r6   r7   test_Dummy_from_Symbol   s
   r   c                   C  s   t tfd t ttfd d S )Nz(Symbol('x'),)z(Symbol('x'), Symbol('y')))r8   rA   rL   r6   r6   r6   r7   
test_tuple   s   r   c                   C  rl   )NwzWildFunction('w'))r8   r   r6   r6   r6   r7   test_WildFunction   ro   r   c                   C  s   t tdd  d S )Nc                   S  s   t tddS )Ngarbage)method)r#   rA   r6   r6   r6   r7   <lambda>   s    ztest_settins.<locals>.<lambda>)r   	TypeErrorr6   r6   r6   r7   test_settins   ro   r   c                   C  sV   t dtd  t d tdtd  t dddksJ ttdddd	dd
ks)J d S )Nru   z:Mul(Integer(3), Pow(Symbol('x'), Integer(3)), Symbol('y'))rG   rE   z:Mul(Integer(3), Symbol('y'), Pow(Symbol('x'), Integer(3)))z(x+4)*2*x*7FrH   rJ   zFMul(Add(Symbol('x'), Integer(4)), Integer(2), Symbol('x'), Integer(7))rK   r6   r6   r6   r7   test_Mul   s     r   c                  C  s2   t td} t| d t tdd} t| d d S )NrC   zJAlgebraicNumber(Pow(Integer(2), Rational(1, 2)), [Integer(1), Integer(0)])ru   zKAlgebraicNumber(Pow(Integer(-2), Rational(1, 3)), [Integer(1), Integer(0)]))r	   r   r8   r   )ar6   r6   r7   test_AlgebraicNumber   s   
r   c                   C  \   t tdttd dksJ t tdttd dksJ t tdtd td dks,J d S )	NrA   r   z!PolyRing((Symbol('x'),), ZZ, lex)r-   z/PolyRing((Symbol('x'), Symbol('y')), QQ, grlex)x,y,ztz=PolyRing((Symbol('x'), Symbol('y'), Symbol('z')), ZZ[t], lex))r#   r$   r&   r(   r'   r)   r6   r6   r6   r7   test_PolyRing      $r   c                   C  r   )	NrA   r   z"FracField((Symbol('x'),), ZZ, lex)r-   z0FracField((Symbol('x'), Symbol('y')), QQ, grlex)r   r   z>FracField((Symbol('x'), Symbol('y'), Symbol('z')), ZZ[t], lex))r#   r%   r&   r(   r'   r)   r6   r6   r6   r7   test_FracField   r   r   c                  C  s4   t dt\} }}td|d  | d dksJ d S )Nr-   ru   rC   rD   zVPolyElement(PolyRing((Symbol('x'), Symbol('y')), ZZ, lex), [((2, 1), 3), ((0, 0), 1)]))r$   r&   r#   )r@   rA   rL   r6   r6   r7   test_PolyElement  s   $r   c                  C  s@   t dt\} }}td|d  | d ||d   dksJ d S )Nr-   ru   rC   rD   ztFracElement(FracField((Symbol('x'), Symbol('y')), ZZ, lex), [((2, 1), 3), ((0, 0), 1)], [((1, 0), 1), ((0, 2), -1)]))r%   r&   r#   )FrA   rL   r6   r6   r7   test_FracElement  s   0r   c                   C  s6   t ttdksJ t tjtttddksJ d S )Nz1FractionField(FracField((Symbol('x'),), QQ, lex))rE   z?FractionField(FracField((Symbol('x'), Symbol('y')), QQ, grlex)))r#   r'   
frac_fieldrA   rL   r)   r6   r6   r6   r7   test_FractionField  s   r   c                   C  sP   t ttdksJ t tt tdksJ t tttdks&J d S )Nz%GlobalPolynomialRing(ZZ, Symbol('x'))z(GlobalPolynomialRing(ZZ[x], Symbol('y'))zTGlobalPolynomialRing(FractionField(FracField((Symbol('x'),), QQ, lex)), Symbol('y')))r#   r&   old_poly_ringrA   rL   r'   r   r6   r6   r6   r7   test_PolynomialRingBase  s   r   c                   C  s<   t tddgtdksJ t ttddgdksJ d S )NrD   rC   zDMP([1, 2], ZZ)z;DMP([1, 2], ZZ, ring=GlobalPolynomialRing(ZZ, Symbol('x'))))r#   r+   r&   r   rA   r6   r6   r6   r7   test_DMP  s   r   c                   C  s&   t tttd d tdksJ d S )NrC   rD   z/FiniteExtension(Poly(x**2 + 1, x, domain='ZZ')))r#   r,   r*   rA   r6   r6   r6   r7   test_FiniteExtension!  s   r   c                  C  s,   t ttd d t} t| jdksJ d S )NrC   rD   zuExtElem(DMP([1, 0], ZZ, ring=GlobalPolynomialRing(ZZ, Symbol('x'))), FiniteExtension(Poly(x**2 + 1, x, domain='ZZ'))))r,   r*   rA   r#   	generator)Ar6   r6   r7   test_ExtensionElement&  s   r   c                   C  s$   t tdksJ t tdksJ d S )Nr   r   )r#   r   r   r6   r6   r6   r7   test_BooleanAtom,  ry   r   c                   C     t tjd d S )NIntegers)r8   r   r   r6   r6   r6   r7   test_Integers1     r   c                   C  r   )Nrb   )r8   r   rb   r6   r6   r6   r7   test_Naturals5  r   r   c                   C  r   )Nrc   )r8   r   rc   r6   r6   r6   r7   test_Naturals09  r   r   c                   C  r   )Nre   )r8   r   re   r6   r6   r6   r7   
test_Reals=  r   r   c                  C  sN   t ddd} td| | }td| | }t|d t|| d t|| d d S )	Nr   Tr   r   BzLMatrixSymbol(Str('A'), Symbol('n', integer=True), Symbol('n', integer=True))zMatMul(MatrixSymbol(Str('A'), Symbol('n', integer=True), Symbol('n', integer=True)), MatrixSymbol(Str('B'), Symbol('n', integer=True), Symbol('n', integer=True)))zMatAdd(MatrixSymbol(Str('A'), Symbol('n', integer=True), Symbol('n', integer=True)), MatrixSymbol(Str('B'), Symbol('n', integer=True), Symbol('n', integer=True))))r   r   r8   )r   r   r   r6   r6   r7   test_matrix_expressionsA  s   
r   c                   C  s   t tdddksJ d S )NrD   rC   zCycle(1, 2))r#   r   r6   r6   r6   r7   
test_CycleJ  s   r   c                  C  s   d} t tddddd| dd t tddddd	| d
d t  tj}dt_t tddddd|  |t_W d    d S 1 sBw   Y  d S )Nz+from sympy.combinatorics import PermutationrD   rC   ru   rm   zPermutation([0, 2, 1, 4, 3])F)Zperm_cycliczPermutation(1, 2)(3, 4)T)r8   r   r   Zprint_cyclic)r4   Zold_print_cyclicr6   r6   r7   test_PermutationR  s   "r   c                  C  s|   ddl m} m}m} i }t|dksJ | |i}t|dks J | |||i}t|dv s.J | ||ii}t|dks<J d S )Nr   )rA   rL   zz{}z{Symbol('x'): Symbol('y')})z4{Symbol('x'): Symbol('y'), Symbol('y'): Symbol('z')}z4{Symbol('y'): Symbol('z'), Symbol('x'): Symbol('y')}z){Symbol('x'): {Symbol('y'): Symbol('z')}})	sympy.abcrA   rL   r   r#   )rA   rL   r   r   r6   r6   r7   	test_dict]  s   r   c                  C  sB   ddl m} m} t }t|dksJ | |h}t|dv sJ d S )Nr   )rA   rL   zset())z{Symbol('x'), Symbol('y')}z{Symbol('y'), Symbol('x')})r   rA   rL   setr#   )rA   rL   sr6   r6   r7   test_setk  s
   r   c                   C  r   )NzQ.even)r8   r   r   r6   r6   r6   r7   test_Predicater  r   r   c                   C  s   t ttdd d S )Nr   z%AppliedPredicate(Q.even, Symbol('z')))r8   r   r   r   r6   r6   r6   r7   test_AppliedPredicateu  s   r   )N)v
__future__r   typingr   Zsympy.testing.pytestr   r   Zsympy.assumptions.askr   Zsympy.core.functionr   r   Zsympy.core.numbersr	   r
   r   r   Zsympy.core.singletonr   Zsympy.core.symbolr   r   r   r   Zsympy.core.sympifyr   Z$sympy.functions.elementary.complexesr   Z(sympy.functions.elementary.miscellaneousr   r   Z(sympy.functions.elementary.trigonometricr   Z'sympy.functions.special.delta_functionsr   Zsympy.logic.boolalgr   r   Zsympy.matrices.denser   r   Z"sympy.matrices.expressions.matexprr   Zsympy.matrices.immutabler   Zsympy.combinatoricsr   r   r    Zsympy.geometryr!   r"   Zsympy.printingr#   Zsympy.polysr$   r%   r&   r'   r(   r)   r*   Zsympy.polys.polyclassesr+   Zsympy.polys.agca.extensionsr,   rA   rL   r.   __annotations__r0   r8   rB   rM   rQ   rS   rT   rV   rk   rn   rp   rt   rv   rx   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   r   r   r   r   r   r   r6   r6   r6   r7   <module>   s    $

	
			