o
    jg/                     @   s  d dl Z d dlZd dl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 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! 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/m0Z0m1Z1m2Z2m3Z3m4Z4 d	d
 Z5dd Z6dd Z7dd Z8dd Z9dd Z:dd Z;dd Z<dd Z=dd Z>dd Z?dd  Z@d!d" ZAd#d$ ZBd%d& ZCd'd( ZDd)d* ZEd+d, ZFd-d. ZGd/d0 ZHd1d2 ZId3d4 ZJd5d6 ZKd7d8 ZLd9d: ZMd;d< ZNd=d> ZOd?d@ ZPdAdB ZQdS )C    N)Q)SymbolFunctionFloatRationalIntegerIMulPowEqLtLeGtGeNe)exp	factorial
factorial2sinMinMax)And)Limit)raisesskip)
parse_exprstandard_transformationsrationalize
TokenErrorsplit_symbolsimplicit_multiplicationconvert_equals_signsconvert_xorfunction_exponentiationlambda_notationauto_symbolrepeated_decimals#implicit_multiplication_applicationauto_numberfactorial_notationimplicit_application_transformationTc                  C   s  t d} i dd|  dtddtddd	ddt  d
t| dt| dt| dt| d d dtdddtdddtdddtdddtdddtdddtdddtddd td!d"td#d$d%td td&td'tdg| jtddt	t
ddd(d)t
ddd(d)d(d)tt| | d*d+d,t| d-	}| D ]\}}t||ksJ qttd.d/  ttd0d/  ttd1d/  ttd2d/  ttd3d/  ttd4d/  ttd5d/  d S )6Nxz2*x   z3.00   z22/7      z2+3jzexp(x)zx!zx!!z(x + 1)! - 1   z3.[3]
   z.0[3]   z3.2[3]a   z1.3[12]i  iJ  z	1 + 3.[3]   z	1 + .0[3]   z
1 + 3.2[3]   z.[0011]i  z0.1[00102] + 1ii i i'  i'  i _7 Fevaluater   -)dir)	z1.[0191]z10!z-(2)z[-1, -2, 3]zSymbol("x").free_symbolszS('S(3).n(n=3)')zfactorint(12, visual=True)zLimit(sin(x), x, 0, dir="-")z	Q.even(x)c                   S   s
   t dtS Nr-   )r   r    r@   r@   ]/var/www/html/zoom/venv/lib/python3.10/site-packages/sympy/parsing/tests/test_sympy_parser.py<lambda>?   s   
z#test_sympy_parser.<locals>.<lambda>c                   S   s   t ddd dS )Nr-   c                 S      dS Nr2   r@   r-   yr@   r@   rA   rB   B       5test_sympy_parser.<locals>.<lambda>.<locals>.<lambda>transformationsr   r@   r@   r@   rA   rB   A   s   c                   S   s   t ddd fdS )Nr-   c                 S   rC   rD   r@   rE   r@   r@   rA   rB   D   rG   rH   rI   rK   r@   r@   r@   rA   rB   C   s   c                   S   s   t dddS )Nr-   )r@   rI   rK   r@   r@   r@   rA   rB   E       c                   S   s   t di g g S r?   rK   r@   r@   r@   rA   rB   F       c                   S      t dg g i S r?   rK   r@   r@   r@   rA   rB   G   rM   c                   S   rN   r?   rK   r@   r@   r@   rA   rB   H   rM   )r   r   r   r   r   r   r   r   free_symbolsr	   r
   r   r   r   evenitemsr   r   	TypeError)r-   inputstextresultr@   r@   rA   test_sympy_parser   sv   

	








!rV   c                  C   sB   dt ddi} ttf }|  D ]\}}t||d|ksJ qd S )Nz0.123{   i  rI   )r   r   r   rQ   r   )rS   rJ   rT   rU   r@   r@   rA   test_rationalizeK   s   

rX   c               	   C   s6   g d} | D ]}zt | J  ty   	 Y qw d S )N)zx!!!zx!!!!z(!))r   r   )rS   rT   r@   r@   rA   test_factorial_failT   s   rY   c                     sP   g d} | D ] t t fdd qg d} | D ] t ttf fdd qd S )N)z1[1]z.1e1[1]z0x1[1]z1.1j[1]z
1.1[1 + 1]z0.1[[1]]z0x1.1[1]c                         t  S NrK   r@   rT   r@   rA   rB   g       z$test_repeated_fail.<locals>.<lambda>)z0.1[z0.1[1z0.1[]c                      rZ   r[   rK   r@   r\   r@   rA   rB   l   r]   )r   rR   r   SyntaxError)rS   r@   r\   rA   test_repeated_fail`   s   r_   c                   C   s0   t dtddksJ t dtddksJ d S )Nz.[1]r2   	   z1 + .[1]r3   )r   r   r@   r@   r@   rA   test_repeated_dot_onlyo   s   ra   c                  C   sB   ddd i} dt di}| D ]\}}t|| d|ksJ qd S )Nmy_functionc                 S   s   | d S )Nr.   r@   r-   r@   r@   rA   rB   v   r]   z!test_local_dict.<locals>.<lambda>zmy_function(2)   
local_dict)r   rQ   r   )rf   rS   rT   rU   r@   r@   rA   test_local_dictt   s   rg   c                  C   sB   t ttf } tddd}td}tdd|i| d|| ksJ d S )NwT)realrF   yxr-   rf   rJ   r   r   r    r   r   )trh   rF   r@   r@   rA   test_local_dict_split_implmult   s   "rn   c                     sR   t d} dtdi td d d | ksJ dt di tt fdd d S )	Nr-   foobarfoo(x)re   bazc                         t d dS )Nrq   re   rK   r@   dr@   rA   rB      rL   z/test_local_dict_symbol_to_fcn.<locals>.<lambda>)r   r   r   r   rR   rc   r@   rt   rA   test_local_dict_symbol_to_fcn   s
   rv   c                  C   sH   dt i} dtt dt di}| D ]\}}t|| d|ks!J qd S )Nr   zQ & Sr   Sglobal_dict)r   r   rQ   r   )ry   rS   rT   rU   r@   r@   rA   test_global_dict   s   rz   c                  C   s   i } t d|  tt}| D ]\}}t|tjr|| |< qt| d< t| d< | 	d dt
i}| D ]}t||d}|t
|ksAJ q1d S )Nzfrom sympy import *maxminr   rx   )execvarsbuiltinsrQ   
isinstancetypesBuiltinFunctionTyper   r   popr   r   )default_globalsbuiltins_dictnameobjry   r@   r@   rA   test_no_globals   s   

r   c                   C   s    t tdd  t tdd  d S )Nc                   S      t dS )Nz(()rK   r@   r@   r@   rA   rB      r]   z!test_issue_2515.<locals>.<lambda>c                   S   r   )Nz"""rK   r@   r@   r@   rA   rB      r]   )r   r   r@   r@   r@   rA   test_issue_2515   s   r   c                  C   sJ   t d} d}t|ddt|ddksJ t|ddd| d  s#J d S )Nr-   z2*(x+1)r   r;   Fr.   r2   )r   r   equals)r-   er@   r@   rA   test_issue_7663   s   "r   c                  C   s@   ddddd} |   D ]\}}t|ddt|ddksJ qd S )N4*-3z(-4)*3z(-2)*x*yzx*(-4)*x)r   z-4*3z-2*x*yzx*-4*xFr;   rQ   r   rS   rT   rU   r@   r@   rA   #test_recursive_evaluate_false_10560   s   r   c                  C   sz   g d} | D ]}t |dd}|t|  krt| ks"J  J qtt ddddks/J tt ddddks;J d S )N)!zAbs(0)zim(0)zre(0)zsign(0)zarg(0)zconjugate(0)zacos(0)zacot(0)zacsc(0)zasec(0)zasin(0)zatan(0)zacosh(0)zacoth(0)zacsch(0)zasech(0)zasinh(0)zatanh(0)zcos(0)zcot(0)zcsc(0)zsec(0)zsin(0)ztan(0)zcosh(0)zcoth(0)zcsch(0)zsech(0)zsinh(0)ztanh(0)zexp(0)log(0)zsqrt(0)Fr;   zln(0)r   zcbrt(0)z0**(1/3))r   strdoit)rS   caseexprr@   r@   rA   test_function_evaluate_false   s   *r   c                  C   s<   ddd} |   D ]\}}t|ddt|ddksJ q	d S )Nz(-10)/5z
(-10)/(-5))z-10/5z-10/-5Fr;   r   r   r@   r@   rA   test_issue_10773   s   r   c                  C   sP   t ttf } td}td}td}td|ksJ td| d|| ks&J d S )Nr-   rF   xyrI   rl   )rJ   r-   rF   r   r@   r@   rA   test_split_symbols   s   r   c                  C   sv   t ttf } td}td}td}td}td| d|| |d  ks&J td| d|id	|||d  ks9J d S )
Nr-   rF   afzay(x+1)rI   r2   zaf(x+1))rJ   rf   )r   r   r    r   r   r   )rJ   r-   rF   r   r   r@   r@   rA   test_split_symbols_function   s    r   c                  C   s   t ttf } td}td}td}td}td| dt|d ks$J td| dt|| ks2J td| dt|| ks@J td	| dt||ksNJ td
| d||| ks\J d S )Nr-   rF   r   zsin^2(x)rI   r.   zsin^y(x)zexp^y(x)zE^y(x)za^y(x))r   r"   r#   r   r   r   r   r   )rm   r-   rF   r   yfcnr@   r@   rA   test_functional_exponent   s    r   c                      s    t tf  tt fdd d S )Nc                      rs   )Nz(1,2),(3,4]rI   rK   r@   rI   r@   rA   rB     rL   z@test_match_parentheses_implicit_multiplication.<locals>.<lambda>)r   r    r   r   r@   r@   rI   rA   .test_match_parentheses_implicit_multiplication  s   r   c                  C   sv   t tf } td}td}td| dtd|ksJ td| dt||ks'J td| dttd| |dks9J d S )	Nr-   rF   z1*2=xrI   r.   zy = xz(2*y = x) = FalseF)r   r!   r   r   r   )rJ   r-   rF   r@   r@   rA   test_convert_equals_signs
  s   r   c                  C   s(   t d} td}td|| ksJ d S )Nr-   r   zf(x))r   r   r   )r-   r   r@   r@   rA   test_parse_function_issue_3539  s   r   c               
   C   sx   t ddddtddddtddddtddddtddddtddddd} |  D ]\}}t|dd|ks9J q+d S )Nr2   r.   Fr;   )z1 < 2z1 <= 2z1 > 2z1 >= 2z1 != 2z1 == 2)r   r   r   r   r   r   rQ   r   r   r@   r@   rA   test_issue_24288  s   r   c                  C   sv   t tf } td}td}td| d}||  kr$d| d|  ks'J  J td| d}||d | d	 ks9J d S )
Nnz2**n * 3**nz2**n3**nrI   r.   r/   n12n34   "   )r   r'   r   r   )rJ   r   expr1expr2r@   r@   rA   test_split_symbols_numeric&  s   (r   c                   C   s   t dtdks
J d S )Nu   α)r   r   r@   r@   r@   rA   test_unicode_names4  s   r   c                   C   s   t jdk r	td tddksJ tdtd  kr#tddks&J  J td	td
  kr8tddks;J  J tdtd  krMtddksPJ  J tdtd  krbtddkseJ  J tdtd  krwtddkszJ  J d S )N)r/      z2test_python3_features requires Python 3.8 or newer123_456i@ z1.2[3_4]z1.2[34]ic  i  z1.2[012_012]z1.2[012012]i  iM  z.[3_4]z.[34]r   c   z.1[3_4]z.1[34]   i  z123_123.123_123[3_4]z123123.123123[34]l   [.X,i)sysversion_infor   r   r   r@   r@   r@   rA   test_python3_features8  s   
****.r   c                  C   s4   t d} tdd| ittf d}|j| hksJ d S )Nr-   z	E**x(1+x)rk   )r   r   r   r'   rO   )r-   eqr@   r@   rA   test_issue_19501F  s   
r   c                  C   s  ddl m}  ttdksJ td tksJ td tksJ td tks&J td tks.J td tks6J td t	ks>J td	 t
ksFJ td
 tksNJ td tksVJ td tks^J td tksfJ td tksnJ td d td   krtksJ  J t}td |t|d  |d fksJ td ddf t|d f ksJ tdddd| d  d ksJ tdddtd|  ksJ d S )Nr   rc   r   r2   r.   r/   rd         r1   r   r`   r3      )r   r2   r.   r/   rd   )r9   r   z0.3x^2allrI   zsin 3ximplicit)	sympy.abcr-   lenr+   r$   r%   r&   r(   r)   r'   r"   r*   r    r!   r#   r   r,   r   r   r   )r-   rm   r@   r@   rA   test_parsing_definitionsN  s(   ($"  r   c                  C   sB   g d} | D ]\}}t |t |ksJ qtt ddksJ d S )N))zabs(x)zAbs(x))z	max(x, y)z	Max(x, y))z	min(x, y)z	Min(x, y))z	pow(x, y)z	Pow(x, y)zpow(38, -1, 97)23)r   r   )casesbuilt_in_func_callsympy_func_callr@   r@   rA   test_builtinse  s   r   c                  C   s,   t tdd  dd i} td| du sJ d S )Nc                   S   s   t dddiS )Nr-    r2   rK   r@   r@   r@   rA   rB   r  rM   z"test_issue_22822.<locals>.<lambda>some_parameterzsome_parameter is NoneT)r   
ValueErrorr   )datar@   r@   rA   test_issue_22822q  s   r   )Rr   r   r   sympy.assumptionsr   
sympy.corer   r   r   r   r   r   r	   r
   r   r   r   r   r   r   sympy.functionsr   r   r   r   r   r   sympy.logicr   sympy.seriesr   sympy.testing.pytestr   r   sympy.parsing.sympy_parserr   r   r   r   r   r    r!   r"   r#   r$   r%   r&   r'   r(   r)   r*   r+   r,   rV   rX   rY   r_   ra   rg   rn   rv   rz   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r@   r@   r@   rA   <module>   sN   @ P
2		