o
    …º¥gV„  ã                   @   s¤  d dl 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 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 d dl m!Z!m"Z"m#Z# d d	l$m%Z% d d
l&m'Z' d dl(m)Z)m*Z*m+Z+m,Z,m-Z- d dl.m/Z/ d dl0m1Z1m2Z2 d dl3m4Z4 d dl5m6Z6 d dl7m8Z8 d dl9m:Z: d dl;m<Z<m=Z= d dl>m?Z? d dl@mAZA d dl mBZB d dlmCZC d dlDmEZEmFZFmGZG dd„ ZHdd„ ZIdd„ ZJdd„ ZKd d!„ ZLeEd"d#„ ƒZMd$d%„ ZNd&d'„ ZOd(d)„ ZPd*d+„ ZQd,d-„ ZRd.d/„ ZSd0d1„ ZTd2d3„ ZUd4d5„ ZVd6d7„ ZWd8d9„ ZXeGd:d;„ ƒZYd<d=„ ZZd>d?„ Z[d@dA„ Z\dBdC„ Z]dDdE„ Z^dFdG„ Z_dHdI„ Z`eEdJdK„ ƒZadLdM„ ZbeEdNdO„ ƒZcdPdQ„ ZddRdS„ ZedTdU„ ZfdVdW„ ZgeGdXdY„ ƒZhdZS )[é    )ÚExpr)Ú
DerivativeÚFunctionÚLambdaÚexpand)ÚEÚIÚRationalÚcompÚnanÚooÚpiÚzoo)ÚEq)ÚS)ÚSymbolÚsymbols)ÚAbsÚadjointÚargÚ	conjugateÚimÚreÚsignÚ	transpose)ÚexpÚ	exp_polarÚlog)Úsqrt)Ú	Piecewise)ÚacosÚatanÚatan2ÚcosÚsin)Úsinh)Ú
DiracDeltaÚ	Heaviside)ÚIntegral)ÚMatrix)ÚFunctionMatrix)ÚMatrixSymbol)ÚImmutableMatrixÚImmutableSparseMatrix)ÚSparseMatrix)ÚInterval)Ú	unchanged)ÚArgumentIndexError)ÚXFAILÚraisesÚ_both_exp_powc                 C   s   t |  ¡ | ¡ dƒS )z7Check whether two complex numbers are numerically closegíµ ÷Æ°>)r
   Ún)ÚaÚb© r8   úf/var/www/visachat/venv/lib/python3.10/site-packages/sympy/functions/elementary/tests/test_complexes.pyÚN_equals   s   r:   c                  C   sü  t dƒ\} }t ddd\}}tddd}tddd}ttƒtu s"J ‚ttƒtu s*J ‚tt ƒt u s4J ‚tdƒdks<J ‚td	ƒd	ksDJ ‚td
ƒd
ksLJ ‚ttƒtksTJ ‚tt ƒt ks^J ‚tt| ƒseJ ‚t| t ƒt| ƒ ksrJ ‚t|t ƒdks|J ‚t|ƒ|ks„J ‚t|t ƒt| ksJ ‚t|ƒdks˜J ‚t| | ƒt| ƒt|ƒ ks¨J ‚t| | ƒt| ƒ| ks¶J ‚tt| ƒƒt| ƒksÂJ ‚tdt ƒdksÌJ ‚t| t ƒt| ƒksØJ ‚t| |t  ƒt| ƒt|ƒ ksêJ ‚t| |t  ƒt| ƒksøJ ‚tt	dt ƒƒt	dƒksJ ‚tdt d ƒj
dddksJ ‚tt| ƒƒt| ƒks%J ‚tt| ƒƒt| ƒks2J ‚t| ƒ ¡ t| ƒdfksAJ ‚t|| |  ƒ |¡t||  ƒksUJ ‚t|| |  ƒ |¡t| t| ƒ kskJ ‚tt||t  ƒƒ|d |d  td	dƒ tt||ƒd ƒ ksŽJ ‚t|d|t   ƒd| ksŸJ ‚td	t||t  ƒ d ƒ|d |d  td	dƒ tt||ƒd ƒ d tj ksËJ ‚t| ƒ t¡| tjt| ƒ  ksÞJ ‚| t|ƒ  tt¡| | tjt|ƒ  ksöJ ‚tddd}tddd}tdƒ} t|ƒjsJ ‚t| ƒjd u sJ ‚t|ƒjdu s"J ‚ttjƒtju s-J ‚t dƒ\}}}	td||ƒ}
t|
ƒtj|
t|
ƒ  ksJJ ‚td	dt  dgddt ggƒ}
t|
ƒtd	dgddggƒkskJ ‚td	dt  ddt  gddt ggƒ}
t|
ƒtd	dgddggƒksJ ‚tdd„ tdƒD ƒƒ}t|ƒtg d¢g d¢g d¢g d¢g d¢gƒ t d¡ksºJ ‚t|ƒtg d ¢g d ¢g d ¢g d ¢g d ¢gƒ t d¡ksÙJ ‚tddt ||f||t  ƒƒ}t|ƒtg d!¢g d"¢g d#¢gƒksüJ ‚d S )$Núx,yúa,bT©ÚrealÚrÚi©Ú	imaginaryr   é   éÿÿÿÿé   ©Úcomplexé   é   r6   ©Ú	algebraicÚt©ÚtranscendentalÚxFún m lÚAéýÿÿÿc                    s"   g | ]‰ ‡ fd d„t dƒD ƒ‘qS )c                    s   g | ]
}d ˆ  |t   ‘qS )rE   ©r   ©Ú.0r@   ©Újr8   r9   Ú
<listcomp>n   s    z&test_re.<locals>.<listcomp>.<listcomp>é   ©Úrange)rU   r8   rV   r9   rX   n   s   " ztest_re.<locals>.<listcomp>rY   )r   r   r   r   r   )rE   rE   rE   rE   rE   )rI   rI   rI   rI   rI   )é   r\   r\   r\   r\   )é   r]   r]   r]   r]   )r   rC   rE   rH   rI   )r   r   r   )rC   rC   rC   )rE   rE   rE   )!r   r   r   r   r   r   r0   r   r   r   r   r   Úas_real_imagÚdiffr   r	   r#   r"   r   ÚHalfÚrewriteÚImaginaryUnitÚis_algebraicÚComplexInfinityÚNaNr+   r)   r,   r.   r[   Úzerosr*   r   )rO   Úyr6   r7   r?   r@   rL   r5   ÚmÚlrQ   ÚXr8   r8   r9   Útest_re   s˜    $"(,ÿ*
ÿ"4
ÿ&0  "("ü
üü
ü,rk   c                  C   sð  t dƒ\} }t ddd\}}tddd}tddd}ttƒtu s"J ‚ttt ƒtu s,J ‚tt t ƒt u s8J ‚tdƒdks@J ‚td	ƒdksHJ ‚td
ƒdksPJ ‚ttt ƒtksZJ ‚tt t ƒt ksfJ ‚tt| ƒsmJ ‚t| t ƒt| ƒksyJ ‚t|t ƒ|ksƒJ ‚t|ƒdks‹J ‚t|t ƒdks•J ‚t|ƒt | ks J ‚t| | ƒt| ƒt|ƒ ks°J ‚t| | ƒt| ƒks¼J ‚t| |t  ƒt| ƒ| ksÌJ ‚tt| ƒt ƒt| ƒksÚJ ‚tdt ƒd	ksäJ ‚t| t ƒt| ƒd	 ksòJ ‚t| |t  ƒt| ƒt|ƒ ksJ ‚t| |t  ƒt| ƒ| ksJ ‚tt	dt ƒƒt
d ks%J ‚tdt d ƒjdddks6J ‚tt| ƒƒt| ƒ ksDJ ‚tt| ƒƒt| ƒksQJ ‚t| ƒ ¡ t| ƒdfks`J ‚t|| |  ƒ |¡t||  ƒkstJ ‚t|| |  ƒ |¡t t||  ƒ ks‹J ‚tt||t  ƒƒ|d |d  td	dƒ tt||ƒd ƒ ks®J ‚t|d|t   ƒ|| ks¿J ‚td	t||t  ƒ d ƒ|d |d  td	dƒ tt||ƒd ƒ d ksèJ ‚t| ƒ t¡tj | t| ƒ  ksüJ ‚| t|ƒ  tt¡| tj|t|ƒ   ksJ ‚tddd}tddd}tdƒ} t|ƒjs,J ‚t| ƒjd u s6J ‚t|ƒjdu s@J ‚ttjƒtju sKJ ‚t dƒ\}}}	td||ƒ}
t|
ƒtjdt  |
t|
ƒ  kslJ ‚td	dt  dgddt ggƒ}
t|
ƒtddgddggƒksJ ‚td	dt  ddt  gddt ggƒ}
t|
ƒtddgddggƒks²J ‚tdd„ tdƒD ƒƒ}tdd„ tdƒD ƒƒ}t|ƒ  ¡ |ksÓJ ‚t!ddt"||f||t  ƒƒ}t|ƒtg d¢g d¢g d¢gƒksöJ ‚d S )Nr;   r<   Tr=   r?   r@   rA   r   rC   rD   rE   rF   rI   r6   rJ   rL   rM   rO   FrP   rQ   rR   rH   éþÿÿÿc                 S   s   g | ]}d d„ t dƒD ƒ‘qS )c                 S   s   g | ]}|t  | ‘qS r8   rS   rT   r8   r8   r9   rX   Ñ   ó    z&test_im.<locals>.<listcomp>.<listcomp>rY   rZ   rT   r8   r8   r9   rX   Ñ   s    ztest_im.<locals>.<listcomp>rY   c                 S   s   g | ]}t td ƒƒ‘qS )rY   )Úlistr[   rT   r8   r8   r9   rX   Ò   rm   )r   rC   rE   )#r   r   r   r   r   r   r   r0   r   r   r   r   r   r^   r_   r   r	   r$   r"   ra   r   rb   rc   rd   re   r+   ÚOner)   r,   r-   r[   r.   Úas_immutabler*   r   )rO   rg   r6   r7   r?   r@   rL   r5   rh   ri   rQ   rj   ÚYr8   r8   r9   Útest_im   s‚     &""(.ÿ*
ÿ".
ÿ(0( "("ÿ,rr   c            
      C   s¢	  t dƒdksJ ‚t dƒdksJ ‚t dt ƒtksJ ‚t dt ƒt ks%J ‚t dƒdks-J ‚t ddd	 ¡ dks9J ‚t tdd	 ¡ dksEJ ‚t tƒtu sMJ ‚t d
d
t  ƒ ¡ td
ƒd
d
t   d kseJ ‚t d
dt  ƒ ¡ t d
dt  ƒksyJ ‚t d
d
t  ƒ ¡ t dt ƒks‹J ‚t ttdtdƒ ƒƒƒdks›J ‚t tdtdƒ ƒƒtks©J ‚tdƒ} t | ƒj	du s¶J ‚t | ƒj
du s¿J ‚t | ƒjd u sÈJ ‚t | ƒjd u sÑJ ‚t | ƒjd u sÚJ ‚t | ƒjd u sãJ ‚t | ƒ ¡ t | ƒksïJ ‚t d|  ƒt | ƒksûJ ‚t d
|  ƒt | ƒksJ ‚t t|  ƒtt | ƒ ksJ ‚t dt |  ƒt t | ƒ ks)J ‚t t| ƒƒtt | ƒƒks8J ‚tddd}tddd}tddd}t d
| |  ƒt | ƒksYJ ‚t ||  ƒt | ƒ ksgJ ‚t || |  ƒt | ƒksvJ ‚tddd} t | ƒjdu s†J ‚t | ƒjdu sJ ‚t | ƒjdu sšJ ‚t | ƒjdu s¤J ‚t | ƒ | ¡d
tt |  ƒ ks·J ‚t | ƒ ¡ | t| ƒ ksÆJ ‚tt | ƒƒt | ƒ ksÔJ ‚tddd} t | ƒjdu säJ ‚t | ƒjdu sîJ ‚t | ƒjdu søJ ‚t | ƒjd u sJ ‚t | ƒ | ¡d
t| ƒ ksJ ‚t | ƒ ¡ t | ƒksJ ‚tt | ƒƒt | ƒks,J ‚tddd} t | ƒjdu s<J ‚t | ƒjdu sFJ ‚t | ƒjdu sPJ ‚t | ƒjdu sZJ ‚t | ƒ ¡ | t| ƒ ksiJ ‚t t| ƒƒdkstJ ‚tt | ƒƒdksJ ‚tddd} t | ƒjdu sJ ‚t | ƒjdu s™J ‚t | ƒjdu s£J ‚t | ƒjdu s­J ‚t | ƒ ¡ | t| ƒ ks¼J ‚t t| ƒƒdksÇJ ‚tt | ƒƒdksÒJ ‚d} t | ƒjdu sÞJ ‚t | ƒjdu sèJ ‚t | ƒjdu sòJ ‚t | ƒjdu süJ ‚t | ƒ ¡ dksJ ‚t t| ƒƒdksJ ‚tt | ƒƒdksJ ‚tdddd}t |ƒjdu s.J ‚t |ƒjdu s8J ‚t |ƒjdu sBJ ‚t |ƒjdu sLJ ‚t |ƒd
 dksWJ ‚t |ƒd jt |ƒdfksgJ ‚t tdddƒjssJ ‚t tdddƒjd u sJ ‚t tdddƒjd u sJ ‚t tdddƒjs›J ‚t tdddƒjd u s©J ‚t tdddƒjd u s·J ‚t tddddƒjd u sÆJ ‚tdddtdƒ} }tdƒ}t | ƒ t¡td| dkfd| dk fdƒksíJ ‚t |ƒ t¡t |ƒksûJ ‚t | ƒ t¡d
t| tdƒd
 d d ksJ ‚t |ƒ t¡t |ƒks!J ‚t |ƒ t¡tdt|dƒf|t|ƒ dfƒks;J ‚t ||ƒƒ t¡tdt||ƒdƒf||ƒt||ƒƒ dfƒks]J ‚t ttt ƒt ƒtju smJ ‚td d!tdƒ  ƒ tdtdƒ ƒ tddtdƒ  ƒ }t |ƒjt u s›t |ƒdks›J ‚dtd
ƒ d
tdƒ  d"td!ƒ  }t |d ƒt!ddƒ }|| }	t |	ƒjt u sÍt |	ƒdksÏJ ‚d S d S )#Ng333333ó?rC   g333333ó¿rD   rH   rR   r   F)ÚevaluaterE   rI   rO   Trl   Úp©Úpositiver5   ©Únegativerh   rA   r=   )ÚnonzeroÚnz)ry   Úinteger)Únonnegative)Únonpositive)r>   Úzerorg   Úf)r   T)ÚH0é
   r\   é3  )"r   r   Údoitr   r   r   Úsimplifyr   r   Ú	is_finiteÚ
is_complexÚis_imaginaryÚ
is_integerÚis_realÚis_zeror   r_   r&   r   ÚargsÚis_nonnegativeÚis_nonpositiver   ra   r   r'   r   r   r   r   ÚNegativeOneÚfuncr   r	   )
rO   rt   r5   rh   rz   rg   r   ÚeqÚqÚdr8   r8   r9   Ú	test_signØ   sÎ   0($ $&  
ÿ04D :"$*r“   c                  C   sÒ  t d } |  ¡ | dfksJ ‚tdƒ}t|ƒ ¡ t|ƒd t|ƒd  tddƒ ttt|ƒt|ƒƒd ƒ t|ƒd t|ƒd  tddƒ t	tt|ƒt|ƒƒd ƒ fksVJ ‚t
ddd	\}}dt||t  ƒ d  ¡ |d |d  tddƒ tt||ƒd ƒ d tj |d |d  tddƒ t	t||ƒd ƒ d fks¡J ‚t|d ƒ ¡ t|d ƒdfks³J ‚t
d
dd}t|d ƒ ¡ dt|ƒfksÉJ ‚dt dt   ¡ dks×J ‚dt d dt   ¡ dksçJ ‚d S )Néè  r   rO   rE   rC   rI   r<   Tr=   r@   rA   )r   rC   rH   )rl   r   )r   r^   r   r   r   r   r	   r#   r"   r$   r   r   r   r`   Úabs)r5   rO   r6   r7   r@   r8   r8   r9   Útest_as_real_imagR  s6   
::ÿÿÿÿÿÿ.ýÿ$ $r–   c                  C   s€   t d } t| ƒ}tdƒ}| |  ¡ dksJ ‚t| | ƒdks J ‚| | jd||iddks/J ‚| | jd||iddks>J ‚d S )Nr”   rO   rC   ©Úsubsr   rE   )r   Úintr   Úroundr   r5   )r5   r@   rO   r8   r8   r9   Útest_sign_issue_3068p  s   "r›   c                     sÐ  t tdd„ ƒ tdƒ\‰ } ttˆ ƒƒtˆ ƒksJ ‚tˆ |  ƒjtu s$J ‚tdƒdks,J ‚tdƒdks4J ‚tdƒdks<J ‚ttƒdksDJ ‚tt ƒdksMJ ‚ttƒtu sUJ ‚ttƒt	u s]J ‚ttt
 ƒt
ksgJ ‚tt t
 ƒt
ksrJ ‚ttˆ  ƒtˆ ƒks~J ‚tt ˆ  ƒtˆ ƒks‹J ‚tdˆ  ƒdtˆ ƒ ks™J ‚td	ˆ  ƒd
tˆ ƒ ks§J ‚tdt
 ˆ  |  ƒdt
 tˆ |  ƒ ks½J ‚ttˆ ƒƒtˆ ƒksÉJ ‚ttˆ ƒƒtˆ ƒksÕJ ‚tˆ ƒjddttˆ ƒd tˆ ƒd  ƒksíJ ‚tddd}tdt
 ˆ  | ƒdt
 | tˆ ƒ ks
J ‚tdt
 t ˆ  | ƒdt
 | tˆ ƒ ks#J ‚tddd‰ tddd}td| ƒdks:J ‚ˆ d|  tˆ ƒd|  ksKJ ‚tˆ ƒ ˆ ¡tˆ ƒksYJ ‚tˆ ƒtˆ ƒksdJ ‚tˆ ƒd ˆ d tˆ ƒ ksuJ ‚tˆ ƒd ˆ d ks‚J ‚tˆ ƒd|  jtˆ ƒd| fks–J ‚dtˆ ƒ jtˆ ƒdfks¦J ‚dtˆ ƒd  dˆ d tˆ ƒ  ks»J ‚tˆ ƒd tˆ ƒˆ d  ksÌJ ‚tˆ d ƒˆ d tˆ ƒ ksÝJ ‚ttt ƒtt
 d ƒksíJ ‚tddt  ddt   ƒdtdttddƒƒ ƒ ksJ ‚tddd} tt|  ƒdksJ ‚tdƒ} tt|  ƒtt
 t| ƒ d ƒks4J ‚tddd‰ tˆ ƒ ˆ ¡tˆ ƒ ksIJ ‚tddtdƒ  ƒ tdtdƒ ƒ tddtdƒ  ƒ }t|ƒjtu swt|ƒdkswJ ‚dtdƒ dtdƒ  dtdƒ  }t|d ƒtddƒ }|| }t|ƒjtu s©t|ƒdks©J ‚tdtt
t d ƒ ƒdksºJ ‚tddt  ƒdksÇJ ‚tddt  ƒdtt
ƒ ksØJ ‚tt	ƒt	u sáJ ‚tt	 ƒt	u sëJ ‚tt	t ƒt	u söJ ‚tt	tt	  ƒt	u sJ ‚tddd }td!dd"}tdƒ‰ t|ƒjsJ ‚tˆ ƒjd u s%J ‚t|ƒjd#u s/J ‚tˆ ƒ ¡ tˆ ƒks<J ‚t t‡ fd$d„ƒ ttdt ƒtdt ƒ ƒ}t|ƒ|ks\J ‚tdˆ  ƒdtˆ ƒ kskJ ‚tdˆ d  ƒ}	|	jr‚|	dtˆ d ƒ ks„J ‚tt| ˆ  ƒsŽJ ‚ttˆ ˆ d  ƒsšJ ‚ttˆ |  ƒs¤J ‚td%dd}tˆ | ƒtˆ ƒ| ks¹J ‚tttddd|  ƒsÇJ ‚td&dd}
t|
ˆ ƒd ƒ|
ˆ ƒksÜJ ‚tttd'ƒƒsæJ ‚d S )(Nc                   S   s   t tddƒƒS )NrE   rH   )r   r/   r8   r8   r8   r9   Ú<lambda>  ó    ztest_Abs.<locals>.<lambda>r;   r   rC   rD   rl   rE   g       Àg       @TrF   r6   ru   rO   r=   r5   ©r{   rH   rI   rR   rY   r\   é   i9 éùÿÿÿrg   rA   r   r‚   é	   rJ   rL   rM   Fc                      s   t ˆ ƒ d¡S )NrE   )r   Úfdiffr8   ©rO   r8   r9   rœ   Í  r   rt   r   zim(acos(-i + acosh(-g + i))))r3   Ú	TypeErrorr   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r_   r•   r‹   r   r!   r	   rc   r¢   r1   r    Úis_Mulr0   r   r   )rg   r6   r5   r   r‘   rt   r’   rL   r   Úer   r8   r£   r9   Útest_Abs~  s¢   ,0.2""
ÿ *"" <(:"$""""r§   c                  C   sø  t ddd} t| ƒ t¡ ¡ }|| t| ƒ | t|  ƒ  ks J ‚dD ]}| | |¡t|ƒks0J ‚q"t dƒ}t|ƒ t¡t|ƒksBJ ‚t dddt dƒ} }t| ƒ t¡t| | dkf|  dfƒksbJ ‚t|ƒ t¡t|ƒksoJ ‚t|ƒ t¡|t|ƒ ks~J ‚t ddd}t|ƒ t¡tt	| t	| dkft	 | dfƒksŸJ ‚t|ƒ t
¡t|t
|ƒ ƒks°J ‚t|ƒ t
¡t|d	  ƒksÀJ ‚t ddd
}ttt	 |  ƒtt	 | ƒ ƒd	  t
¡tt	|  ƒ tt	 | ƒ d	 tt	 |  ƒtt	| ƒ  ksúJ ‚d S )NrO   Tr=   )rl   rD   r   rC   rE   rg   r   r@   rA   rE   ©Úextended_real)r   r   ra   r'   r   r˜   r•   r   r   r   r   r   r   )rO   r6   r@   rg   r8   r8   r9   Útest_Abs_rewriteæ  s&   "*6" (8ÿrª   c                  C   sº   t ddd} t| d ƒt| ƒksJ ‚t| d ƒ| d ksJ ‚t ddd} t| d ƒt| ƒks0J ‚t| d ƒ| d ks<J ‚t dddd}t dddd	}t|ƒ|ksRJ ‚t|ƒ| ks[J ‚d S )
NrO   TrF   rE   r=   Únn)r|   r>   Únp)r}   r>   ©r   r   r   )rO   r«   r¬   r8   r8   r9   Útest_Abs_real   s   r®   c            
      C   sl  t dƒ} t| ƒjd u sJ ‚t| ƒjdu sJ ‚t| ƒjd u sJ ‚t| ƒjd u s(J ‚t| ƒjd u s1J ‚t| ƒjd u s:J ‚t| ƒjdu sCJ ‚t ddd}t|ƒjdu sRJ ‚t|ƒjdu s[J ‚t|ƒjd u sdJ ‚t|ƒjd u smJ ‚t|ƒjdu svJ ‚t|ƒjd u sJ ‚t|ƒjdu sˆJ ‚t dddd}t|ƒjdu s˜J ‚t|ƒjdu s¡J ‚t|ƒjd u sªJ ‚t|ƒjdu s³J ‚t|ƒjdu s¼J ‚t|ƒj	du sÅJ ‚t ddd}t|ƒjdu sÔJ ‚t|ƒjdu sÝJ ‚t|ƒjd u sæJ ‚t|ƒjdu sïJ ‚t|ƒj	du søJ ‚t d	dd
}t|ƒjdu sJ ‚t|ƒjdu sJ ‚t|ƒj
d u sJ ‚t|ƒjd u s&J ‚t|ƒjdu s0J ‚t ddd}t|ƒjdu s@J ‚t|ƒj
du sJJ ‚t|ƒjd u sTJ ‚t|ƒjdu s^J ‚t ddd}t dddd}t|ƒjdu suJ ‚t|ƒjdu sJ ‚t|ƒjd u s‰J ‚t ddd}t dddd}	t|ƒjdu s J ‚t|	ƒjdu sªJ ‚t|ƒjd u s´J ‚d S )NrO   T)ÚfiniteÚzF)rG   r~   rt   ru   r‘   )Úrationalr@   rž   r5   )ÚevenÚne)r>   r²   )ÚoddÚno)r>   r´   )r   r   r‰   Úis_extended_realÚis_rationalÚis_positiverŒ   Úis_extended_positiveÚis_extended_nonnegativerŠ   rˆ   Úis_evenÚis_odd)
rO   r   r°   rt   r‘   r@   r¦   r³   Úorµ   r8   r8   r9   Útest_Abs_properties  sd   r¾   c                  C   s4   t ddd} ttd|  d  ƒd|  d ksJ ‚d S )Nr6   Tru   rC   rE   )r   r•   r   )r6   r8   r8   r9   Útest_absN  s   (r¿   c                  C   s4  t dƒtu sJ ‚t dƒdksJ ‚t dƒtksJ ‚t tƒtd ks"J ‚t t ƒt d ks.J ‚t dt ƒtd ks:J ‚t dt ƒttddƒ ksIJ ‚t dt ƒt d ksVJ ‚t tdt t ƒƒdt ksfJ ‚t tdt t ƒƒdt ksvJ ‚t tddt t d  ƒƒttd	dƒ ksJ ‚t ttt d
 ƒƒtd
 ksJ ‚t tdt ƒƒddt  ks­J ‚t tdt t d ƒƒdt d ksÁJ ‚t tddt  ƒƒddt  ksÓJ ‚t ttddt  ƒƒƒdt tdƒt	dƒ  ksíJ ‚t
ddd} t t| dt  ƒƒdksJ ‚tdƒ}t |dƒt|dƒ  ƒ t¡rJ ‚t
dƒ}t t t |ƒƒƒtjus*J ‚t t t t |ƒƒƒƒtju s:J ‚t
ddd} t t | ƒƒtjusLJ ‚t t t | ƒƒƒtju sZJ ‚tddd}t ||ƒƒdkskJ ‚t dt ||ƒ ƒt dt ƒks~J ‚t
ddd}t |ƒdksJ ‚t |t ƒtd ksšJ ‚t
ddd}t |ƒtks©J ‚t |t ƒt d ks·J ‚t
dƒ}tt |ƒƒt |ƒksÈJ ‚|t|d   }t |ƒt d|t  ƒksßJ ‚d| dt |d   }t |ƒt dd| t  ƒksüJ ‚tddd}|t|  }t |ƒt |dt  ƒksJ ‚t || ƒt |dt  ƒks(J ‚|t|ƒ tt|ƒ t|ƒ  }t |ƒjd |ksDJ ‚|d t|d d   }t |ƒjd |ks\J ‚tdƒ}d| |dƒd  d| |dƒ  }t |ƒt d| ƒksJ ‚t |dƒƒjt kr–t |dƒƒj|dƒfks˜J ‚d S )Nr   rC   rD   rE   rI   rH   r    rY   rR   rŸ   é   r\   é   é   iõÿÿÿé{   éûÿÿÿrl   r?   Tr=   r   rO   r¨   rt   )Úextended_positiveru   r5   rw   )r   r   r   r   r	   r   r   r$   r#   r%   r   r   Úatomsr   r   re   r   r   r   r‹   r   )r?   r   rO   rt   r5   r¦   r8   r8   r9   Útest_argU  sj     .  ($4$ &"" $6rÇ   c                  C   sZ   t dt ƒtddƒksJ ‚tddd} tddd}t | t|  ƒ t¡t|| ƒks+J ‚d S )NrC   rO   Tr=   rg   )r   r   r"   r   ra   )rO   rg   r8   r8   r9   Útest_arg_rewriteš  s   (rÈ   c                  C   s&  t ddd} t ddd}t| ƒ|  ksJ ‚tt|  ƒt|  ks!J ‚t|ƒ|ks)J ‚tt| ƒt | ks6J ‚t| | ƒ| |  ksCJ ‚tt|  | ƒt| |  ksSJ ‚tdƒ\}}tt|ƒƒ|kscJ ‚t|| ƒt|ƒt|ƒ kssJ ‚t|| ƒt|ƒt|ƒ ksƒJ ‚t|| ƒt|ƒt|ƒ ks“J ‚t|| ƒt|ƒt|ƒ ks£J ‚t| ƒt|ƒ ks¯J ‚tddd\}}tt|ƒƒ|ksÁJ ‚t|| ƒt|ƒt|ƒ ksÑJ ‚t|| ƒt|ƒt|ƒ ksáJ ‚t|| ƒt|ƒt|ƒ ksñJ ‚t|| ƒd	t|ƒ t|ƒ ksJ ‚t| ƒt|ƒ ksJ ‚d S )
Nr6   T)Úantihermitianr7   )Ú	hermitianúx yF©ÚcommutativerC   )r   r   r   r   )r6   r7   rO   rg   r8   r8   r9   Útest_adjoint¢  s,           &rÎ   c                  C   sÀ  t ddd} t ddd}t| ƒ| ksJ ‚tt|  ƒt |  ks!J ‚t|ƒ| ks*J ‚tt| ƒt| ks6J ‚t| | ƒ|  | ksCJ ‚tt|  | ƒt|  | ksSJ ‚tdƒ\}}tt|ƒƒ|kscJ ‚t|ƒ ¡ tksmJ ‚t|| ƒt|ƒt|ƒ ks}J ‚t|| ƒt|ƒt|ƒ ksJ ‚t|| ƒt|ƒt|ƒ ksJ ‚t|| ƒt|ƒt|ƒ ks­J ‚t| ƒt|ƒ ks¹J ‚t ddd} t ddd	}t| ƒjsÌJ ‚t|ƒjd u sÕJ ‚t|ƒjd
u sÞJ ‚d S )Nr6   Tr=   r7   rA   rË   rJ   rL   rM   F)r   r   r   r   Úinverser   rc   )r6   r7   rO   rg   rL   r8   r8   r9   Útest_conjugate½  s*        rÐ   c                  C   sÖ   t dƒ} tt| ƒƒt| ƒksJ ‚tt| ƒƒt| ƒksJ ‚tt| ƒƒt| ƒks(J ‚tt| ƒƒt| ƒks4J ‚tt| ƒƒt| ƒks@J ‚tt| ƒƒt| ƒksLJ ‚G dd„ dtƒ}|ƒ } t| ƒt| ƒksaJ ‚t| ƒ| ksiJ ‚d S )NrO   c                   @   s$   e Zd Zdd„ Zdd„ Zdd„ ZdS )z+test_conjugate_transpose.<locals>.Symmetricc                 S   ó   d S ©Nr8   ©Úselfr8   r8   r9   Ú_eval_adjointá  ó   z9test_conjugate_transpose.<locals>.Symmetric._eval_adjointc                 S   rÑ   rÒ   r8   rÓ   r8   r8   r9   Ú_eval_conjugateä  rÖ   z;test_conjugate_transpose.<locals>.Symmetric._eval_conjugatec                 S   s   | S rÒ   r8   rÓ   r8   r8   r9   Ú_eval_transposeç  rÖ   z;test_conjugate_transpose.<locals>.Symmetric._eval_transposeN)Ú__name__Ú
__module__Ú__qualname__rÕ   r×   rØ   r8   r8   r8   r9   Ú	Symmetricà  s    rÜ   )r   r   r   r   r   )rO   rÜ   r8   r8   r9   Útest_conjugate_transpose×  s   	rÝ   c                  C   s°  t ddd} t| ƒ| ksJ ‚tt|  ƒt|  ksJ ‚tdƒ\}}tt|ƒƒ|ks*J ‚t|| ƒt|ƒt|ƒ ks:J ‚t|| ƒt|ƒt|ƒ ksJJ ‚t|| ƒt|ƒt|ƒ ksZJ ‚t|| ƒt|ƒt|ƒ ksjJ ‚t| ƒt|ƒ ksvJ ‚tddd\}}tt|ƒƒ|ksˆJ ‚t|| ƒt|ƒt|ƒ ks˜J ‚t|| ƒt|ƒt|ƒ ks¨J ‚t|| ƒt|ƒt|ƒ ks¸J ‚t|| ƒdt|ƒ t|ƒ ksÊJ ‚t| ƒt|ƒ ksÖJ ‚d S )Nr6   TrF   rË   FrÌ   rC   )r   r   r   r   )r6   rO   rg   r8   r8   r9   Útest_transposeî  s"          $rÞ   c            
   	   C   s’  ddl m} m} tdƒ}tddd}tdƒ}i }|dƒ| dƒ|fks$J ‚|d	t ƒ| d	t ƒ|fks4J ‚|t|ƒd
dt|ƒksBJ ‚|d	| d
dd	| ksPJ ‚||tƒ| d
d|| tƒƒ| ksdJ ‚||dd| |ƒkspJ ‚||dd|kszJ ‚|||ƒdd|| |ƒƒksŠJ ‚|d	| dd| d	| ƒksšJ ‚|d	||ƒ dd| d	|| |ƒƒ ƒks°J ‚|||ƒ| ƒ\}}| |¡||ƒ| ksÇJ ‚tdƒ}tddd}	|tt	dƒ| t| | d  d|	d   ƒ dt	t
ƒ |	  |t tfƒddtt	dƒ|	tdƒ ttt
 ƒ  t|	tdƒ dttt
 ƒ  ttt
 ƒ | | | ƒdtdƒ   d ƒ tdƒ | |ƒ dt	t
ƒ  |t tfƒksGJ ‚d S )Nr   )Ú
polar_liftÚpolarifyrO   r°   T)Úpolarr   rD   rC   Fr—   )ÚliftÚmuÚsigmaru   rE   )Ú$sympy.functions.elementary.complexesrß   rà   r   r   r   r   r˜   r(   r   r   r   r   )
rß   rà   rO   r°   r   ÚESÚnewexr˜   rã   rä   r8   r8   r9   Útest_polarify  sR    (  ,<
ÿþ 4
ÿÿÿþþ
þ
þþrè   c                  C   sÜ  ddl m} m}m} ddlm} ddlm} ddlm	} ddl
m}m} ddlm} tdt ƒd	 }	tdt ƒd	 }
|d	ƒd	ksBJ ‚||	ƒ|
ksJJ ‚||	d
 ƒ|
d
 ksVJ ‚||	| ƒ|	| ksbJ ‚||	| ƒ|
| ksnJ ‚||	| ƒ|
| kszJ ‚|tt|	ƒƒƒtt|
ƒƒksŠJ ‚||d
t ƒ}||ƒ|ks™J ‚|t|ƒƒt|ƒks¥J ‚||	|	 dd|	|
 ks³J ‚||||	|	 ƒƒ|||	|
 ƒksÅJ ‚|t|	ƒƒt|
ƒksÑJ ‚|||	ƒƒ||
ƒksÝJ ‚|||	ƒƒ||
ƒkséJ ‚|||	ƒƒ||
ƒksõJ ‚||||	ƒƒ|||	ƒksJ ‚||t|	ƒt|	tdƒ ƒƒƒ|t|
ƒt|
d	 ƒƒks!J ‚||| dƒd
tdƒ ƒƒ|dd
ƒks6J ‚|t|	dƒƒt|
dƒksEJ ‚|||	dƒƒ||
dƒksTJ ‚|| |ƒdkƒ|dkkscJ ‚|dƒdu slJ ‚d S )Nr   )rß   Úprincipal_branchÚ
unpolarify)ÚNe)Útanh)Úerf)ÚgammaÚ
uppergammar£   rŸ   rC   rE   T)Úexponents_only)rå   rß   ré   rê   Úsympy.core.relationalrë   Ú%sympy.functions.elementary.hyperbolicrì   Ú'sympy.functions.special.error_functionsrí   Ú'sympy.functions.special.gamma_functionsrî   rï   Ú	sympy.abcrO   r   r   r   r   r$   r   r   )rß   ré   rê   rë   rì   rí   rî   rï   rO   rt   ÚurL   r8   r8   r9   Útest_unpolarify(  sF    $
ÿ
ÿr÷   c                  C   s`   t dƒ} t| ƒjddt| ƒksJ ‚t| ƒjddt| ƒks J ‚t| ƒjddt| ƒks.J ‚d S )NrO   T)Útrig)r   r   r   r   r   r£   r8   r8   r9   Útest_issue_4035W  s    rù   c                  C   s$   t dƒ} tt| ƒƒt| ƒksJ ‚d S )NrO   )r   r   r£   r8   r8   r9   Útest_issue_3206^  s   rú   c                  C   sv   t ddd} t ddd}tdƒ}|| ƒ ¡  | ¡|| ƒ | ¡ ¡ ks$J ‚||ƒ ¡  |¡||ƒ |¡ ¡  ks9J ‚d S )NrO   Tr=   rg   rA   r   )r   r   r   r_   ©rO   rg   r   r8   r8   r9   Ú$test_issue_4754_derivative_conjugatec  s
   (.rü   c                  C   sÚ  t ddd} t ddd}tdƒ}t|| ƒƒ | ¡t|| ƒ | ¡ƒks$J ‚t|| ƒƒ | ¡t|| ƒ | ¡ƒks8J ‚t||ƒƒ |¡t t||ƒ |¡ƒ ksOJ ‚t||ƒƒ |¡t t||ƒ |¡ƒ ksfJ ‚t|| ƒƒ | ¡ || ƒdt|   ¡ ¡ | t	d| d  ƒ ks‡J ‚t
|| ƒƒ | ¡ || ƒdt| d   ¡ ¡ d|  d| d	   ksªJ ‚t||ƒƒ |¡ ||ƒd| ¡ ¡ | t	d|d  ƒ ksÊJ ‚t
||ƒƒ |¡ ||ƒt|d  ¡ ¡ d| d|d	   ksëJ ‚d S )
NrO   Tr=   rg   rA   r   rC   rE   rI   )r   r   r   r_   r   r   r   r˜   rƒ   r   r   rû   r8   r8   r9   Útest_derivatives_issue_4757k  s   ((..BF@Frý   c               	   C   sP  ddl m}  tdƒ}tdƒ}tdƒ}t|g|g|ggƒ}| ¡ }|t|tt|ƒd t|ƒd  t|ƒd  ƒ g|tt|ƒd t|ƒd  t|ƒd  ƒ g|tt|ƒd t|ƒd  t|ƒd  ƒ ggƒksjJ ‚t|d |d |d  |d   |d |d |d  |d    |d |d |d  |d    ƒ|_| |jƒdks¦J ‚d S )Nr   ©r„   Úv0Úv1Úv2rE   rC   )Úsympy.simplify.simplifyr„   r   r)   Ú
normalizedr   r   Únorm)r„   rÿ   r   r  ÚVÚUr8   r8   r9   Útest_issue_11413y  s   ,,,ýfr  c                  C   s(  ddl m} m}m}m} tdƒ}tddd}|dt ƒ| dt tƒks%J ‚|d| ƒ| d| tƒks4J ‚t|dt d ƒt	d ƒsCJ ‚t|dt d ƒt	 d ƒsSJ ‚t| dt d d	t	 ƒt	d ƒseJ ‚t| dt d d	t	 ƒt	 d ƒsxJ ‚|||t	ƒƒ| |t	ƒks†J ‚||dt ƒƒ|dt ƒks–J ‚| |dt ƒdt	 ƒ| dt dt	 ƒks¬J ‚| |dt ƒd	t	 ƒ| dt d	t	 ƒksÂJ ‚| |dt ƒt	ƒ| |dt ƒt	ƒksÖJ ‚||dt ƒƒt	d
 ksäJ ‚| d| |ƒ| ||ƒksòJ ‚| t	| |ƒ| ||ƒksJ ‚t
|dt ƒƒt
dt ƒksJ ‚d S )Nr   )Úperiodic_argumentrß   ré   Úunbranched_argumentrO   rt   Tru   rE   rC   rH   rI   )rå   r  rß   ré   r	  r   r   r   r:   r   r   )r  rß   ré   r	  rO   rt   r8   r8   r9   Útest_periodic_argumentˆ  s4    $&ÿ ÿÿÿ&r
  c                  C   s0   ddl m}  t| dt d td ƒdƒsJ ‚d S )Nr   ©ré   rC   rE   )rå   ré   r:   r   r   r  r8   r8   r9   Útest_principal_branch_fail¦  s   $r  c                  C   sN  ddl m} m} tddd}tdƒ}tddd}|| |ƒ|ƒ|||ƒks&J ‚|| dt ƒ|ƒ|dt |ƒks8J ‚|d| |ƒd|||ƒ ksHJ ‚|d	tƒtdƒksSJ ‚|d
dt ƒttt ƒksbJ ‚|d
tƒtdƒksmJ ‚|tdt t ƒ| dt ƒ|ttt ƒ| dt ƒks‹J ‚||ttt ƒ dt ƒ|tt t ƒ ks£J ‚|tt t d ƒ| |ƒ dt ƒtt t d ƒ| ksÂJ ‚t|d	t d dt ƒdt ƒsÔJ ‚t|d	t d dt ƒdt ƒsæJ ‚t|d	t d d	t ƒdt ƒsøJ ‚||tƒj|u sJ ‚||dƒj|u sJ ‚||t	 ƒj|u sJ ‚||t
ƒj|u s%J ‚d S )Nr   )rß   ré   rt   Tru   rO   rw   rE   rC   rD   rH   éüÿÿÿ)rå   rß   ré   r   r   r   r   r:   r   r   r   )rß   ré   rt   rO   Únegr8   r8   r9   Útest_principal_branch­  s0   $ ÿ0"ÿ$$$r  c            	      C   sÐ   t d } t| ƒ}t| | ƒdksJ ‚t| | ƒ| | ksJ ‚tdƒ}t d }t d }t|ƒd t|ƒd  }|| | | }ddlm} t||ƒƒdksNJ ‚dd	dt	dd
ƒfD ]}t| 
||¡ƒdkseJ ‚qWd S )Nr”   rC   rO   i$úÿÿrE   r   rþ   éo   é   r   )r   r™   r   r•   r   r#   r$   r  r„   r	   r˜   )	r5   r@   rO   ÚepsÚbigÚoner¦   r„   Úxir8   r8   r9   Útest_issue_6167_6151Ë  s   ÿr  c                  C   s\   ddl m}  tdddƒ}| |d ƒ|d ksJ ‚| |d |d  ƒ|d |d  ks,J ‚d S )Nr   )rê   rQ   rE   )r   r   )rC   r   )rå   rê   r+   )rê   rQ   r8   r8   r9   Útest_issue_14216Ü  s   ,r  c                  C   s6   t ddd} t| td| dkfd|  dfƒ ƒsJ ‚d S )Nr?   Tr=   r   rC   )r   r   r   )r?   r8   r8   r9   Útest_issue_14238ã  s   *r  c                  C   sL   t dƒ} tdd|   ƒd d|  fD ]}t|ƒt| ƒ dks#J |ƒ‚qd S )NrO   rŸ   rE   rC   r   r­   )rO   r6   r8   r8   r9   Útest_issue_22189é  s     ÿr  c                  C   s˜   t dddd} t ddd}t dddd}t| ƒjd u sJ ‚t| ƒjdu s&J ‚t|ƒjd u s/J ‚t|ƒjd u s8J ‚t|ƒjdu sAJ ‚t|ƒjd u sJJ ‚d S )	NÚnonrealFT)r>   r¯   ÚnonimaginaryrA   Únonzerononimaginary)r~   rB   )r   r   rŠ   r   )ÚnrÚniÚnznir8   r8   r9   Útest_zero_assumptionsï  s   r   c                  C   sJ   t ddd} tddd}tt| |ƒƒ| |ƒƒ}| ¡ t| |ƒƒks#J ‚d S )Nr   Tr=   rO   )r   r   r   r   rƒ   r   )r   rO   r   r8   r8   r9   Útest_issue_15893ÿ  s   r!  N)iÚsympy.core.exprr   Úsympy.core.functionr   r   r   r   Úsympy.core.numbersr   r   r	   r
   r   r   r   r   rñ   r   Úsympy.core.singletonr   Úsympy.core.symbolr   r   rå   r   r   r   r   r   r   r   r   Ú&sympy.functions.elementary.exponentialr   r   r   Ú(sympy.functions.elementary.miscellaneousr   Ú$sympy.functions.elementary.piecewiser   Ú(sympy.functions.elementary.trigonometricr    r!   r"   r#   r$   rò   r%   Ú'sympy.functions.special.delta_functionsr&   r'   Úsympy.integrals.integralsr(   Úsympy.matrices.denser)   Ú%sympy.matrices.expressions.funcmatrixr*   Ú"sympy.matrices.expressions.matexprr+   Úsympy.matrices.immutabler,   r-   Úsympy.matricesr.   Úsympy.sets.setsr/   r0   r1   Úsympy.testing.pytestr2   r3   r4   r:   rk   rr   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!  r8   r8   r8   r9   Ú<module>   sz    ((`Yz
h<E
#/

