U
    —9%ePð  ã                   @   s$  d dl mZ d dlmZ d dlmZ d dlmZ d dl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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" d dl#m$Z$ d dl%m&Z&m'Z'm(Z(m)Z)m*Z*m+Z+m,Z, d dl-m.Z.m/Z/ d dl0m1Z1m2Z2m3Z3 d dl4m5Z5m6Z6m7Z7m8Z8m9Z9 d dl:m;Z;m<Z< d dl=m>Z>m?Z? d dl@mAZA d dlBmCZCmDZD d dlEmFZFmGZGmHZHmIZI d dlJmKZK d dlLmMZM d dlNmOZO d dlPmQZQ d dlRmSZS d dlTmUZUmVZV d dlWmXZX e"dƒ\ZYZZZ[Z\Z]Z^e"dd d!Z_d"d#„ Z`d$d%„ Zad&d'„ Zbd(d)„ ZceVd*d+„ ƒZdeVd,d-„ ƒZed.d/„ Zfd0d1„ Zgd2d3„ ZheVd4d5„ ƒZid6d7„ Zjd8d9„ Zkd:d;„ Zld<d=„ Zmd>d?„ Znd@dA„ ZodBdC„ ZpdDdE„ ZqdFdG„ ZrdHdI„ ZsdJdK„ ZtdLdM„ ZudNdO„ ZvdPdQ„ ZwdRdS„ ZxdTdU„ ZydVdW„ ZzdXdY„ Z{dZd[„ Z|d\d]„ Z}d^d_„ Z~d`da„ Zdbdc„ Z€ddde„ Zdfdg„ Z‚dhdi„ Zƒdjdk„ Z„dldm„ Z…dndo„ Z†dpdq„ Z‡drds„ Zˆdtdu„ Z‰dvdw„ ZŠdxdy„ Z‹dzd{„ ZŒd|d}„ Zd~d„ ZŽd€d„ Zd‚dƒ„ Zd„d…„ Z‘d†d‡„ Z’dˆd‰„ Z“dŠd‹„ Z”dŒd„ Z•dŽd„ Z–dd‘„ Z—d’d“„ Z˜d”d•„ Z™eVd–d—„ ƒZšd˜d™„ Z›dšd›„ Zœdœd„ ZdždŸ„ Zžd d¡„ ZŸd¢d£„ Z d¤d¥„ Z¡d¦d§„ Z¢d¨S )©é    )ÚSum)ÚAdd)ÚBasic)ÚTuple)Ú	unchanged)ÚFunctionÚdiffÚexpand)ÚMul)ÚMod)ÚFloatÚIÚRationalÚooÚpiÚzoo)ÚEqÚGeÚGtÚNe)ÚS)ÚSymbolÚsymbols)Ú	factorial)ÚAbsÚadjointÚargÚ	conjugateÚimÚreÚ	transpose)ÚexpÚlog)ÚMaxÚMinÚsqrt)Ú	PiecewiseÚpiecewise_foldÚpiecewise_exclusiveÚ	UndefinedÚExprCondPair)ÚcosÚsin)Ú
DiracDeltaÚ	Heaviside)ÚKroneckerDelta)ÚIntegralÚ	integrate)ÚAndÚITEÚNotÚOr)ÚMatrixSymbol)Úsrepr)ÚContains)ÚInterval)Úsolve)ÚraisesÚslow)Úlambdifyz	a:d, x, yÚzT)Znonzeroc                  C   sn  t ttttdk ƒtddƒƒs t‚tttdk fdƒttttdk ƒtddƒƒksPt‚tttdk fddƒtttdk fdƒkszt‚tttdk fddddkfƒtttdk fƒksªt‚tttdk fdtdk fdƒtttdk fdƒksÜt‚tttdk fdtdk fdƒtttdk fdƒkst‚tttdk fttdk fdƒttttdk tdk ƒfdƒksNt‚tttdk fttdk ftdfƒtksxt‚ttdfƒtksŽt‚ttd	d
„ ƒ tdt tdk ftdfƒtdt tdk ftdfdd  krôtdt tdk fƒksún t‚ttdfƒtkst‚ttdd
„ ƒ ttdfƒtks4t‚ttdd
„ ƒ ttdd
„ ƒ ttdd
„ ƒ tdƒt	ddƒksvt‚tdtdk fdƒt
k } td| fƒtdttdk t
dkt
dkƒfƒks¾t‚tdtdkfdttdktdkƒfƒtdtdkfdtdkfƒkst‚tdtdkfdtdk tdk@ fƒtdtdkfƒks:t‚tdttdktdktttjƒƒfdƒ}| tt¡dksvt‚| td¡dksŒt‚| td¡dks¢t‚tdtdk ftd tdk fttƒtdkfƒ}tdtd dk ftd td dk fttd ƒtd dkfƒ}| ttd ¡|ks$t‚| td¡dks:t‚| td¡dksPt‚| td¡tdƒksjt‚tdttk fdtdt k fdtdt kfƒ}tdttdƒfdt dfƒ}tdttdƒfddt dkfƒ}| td¡dksèt‚| td¡dksþt‚| td¡dkst‚| td¡dks*t‚| td¡dks@t‚tdtd\}}}	t|tƒtdk f|tƒ|	tƒ d tdkfƒ}
t|tƒtdk f|tƒ|	tƒ d tdkfƒ}| ||¡|
ksÄt‚tdttdƒfdƒ td¡dksêt‚tdttdƒfdƒ td¡dkst‚tdttt
ƒfdƒ tt
¡dks6t‚tdtttƒfdƒ tt¡dks\t‚tdtttƒttƒƒfdƒ tt¡tdtttƒttƒƒfdƒks¢t‚tdtttƒt
 dƒfdƒ}| t
d¡tdtttƒdƒfdƒksèt‚tdt
dk fdtdk fdttdƒfdƒ td¡tdt
dk fdƒks0t‚tdttd dƒfdtdk fƒ tt¡dksbt‚tttdkfƒ}tddd}| t|¡tks”t‚| ¡ tdtdk ftd tdk fttƒdfƒksÊt‚|jtdiddksät‚|jtdidd ksþt‚|jtdidtdƒkst‚|jtdidtks6t‚ttttddfƒtdk fƒ}| ¡ ttjtdk fƒksrt‚t}t| }tdtdk fdt tdk fdt tdkfƒ}t| | }t|tƒ|ksÊt‚t|| tƒ|ksât‚t| |ksôt‚t| | |t|  k	st‚|| || k	s(t‚|| || k	s>t‚|| ||  k	sVt‚tdtdk fdtd  tdk fdtd  tdkfƒ}|d |k	sœt‚tt
 d }tt
d  d! }t|tdk f|tdkfƒ}| td¡| td¡ | td¡ | td¡ }| tdd¡dk
st‚| tdd¡|k
s2t‚t|tdk f|dfƒ}| tdd¡dk
s`t‚| tdd¡| k
szt‚| tdd¡| td¡| td¡ k
s¦t‚| tdd¡|k
s¾t‚| td d¡| td¡k
sÞt‚| tdd ¡| td¡ ks t‚|  ¡ tt tdk ftd! d! t!dd!ƒ tdk ftttƒ t t!dd!ƒ dfƒksXt‚tttdk ftd dtkftd!tk fƒ}t |tddfƒt!d"dƒks t‚t |tddfƒt!ddƒksÀt‚tdtdk fdtdk fdtdk fdtd!k fdƒ}t |tt" t"fƒdkst‚tttd#k ftd tdkftdtk fƒ}t |tddfƒtksNt‚t#|tƒrf|j$dksjt‚d S )$Né   r   T©r   T©r?   T)r   Féÿÿÿÿé   c                   S   s   t ƒ S ©N©r&   © rF   rF   ún/var/www/html/Darija-Ai-API/env/lib/python3.8/site-packages/sympy/functions/elementary/tests/test_piecewise.pyÚ<lambda>7   ó    z!test_piecewise1.<locals>.<lambda>F©Úevaluatec                   S   s   t tƒS rD   ©r&   ÚxrF   rF   rF   rG   rH   =   rI   c                   S   s   t tdfƒS ©NrC   rL   rF   rF   rF   rG   rH   ?   rI   c                   S   s   t ttd fƒS rN   rL   rF   rF   rF   rG   rH   @   rI   c                   S   s   t dgdfƒS ©Nr?   TrE   rF   rF   rF   rG   rH   A   rI   ))r?   rC   T©rC   Té   é   é   éûÿÿÿé
   ç        zf,g,h)ÚclsÚn)Únegativeg      ð¿éþÿÿÿ)Úsubsg      ð?é   é   éöÿÿÿ)%r   r&   r*   rM   ÚAssertionErrorr5   r;   Ú	TypeErrorr)   r   Úyr3   r2   r8   r   ZIntegersr[   r   r"   r   r   r   r>   r!   r+   r   Úevalfr0   ÚdoitÚHalfr   Z_eval_intervalr1   r   r   Ú
isinstanceZis_commutative)ÚcondZpwiseÚpZp_x2Úp2Úp3Úp4ÚfÚgÚhÚpfZpgÚp5Úp6rX   Zf_intÚfpZdpZfp_dxZdp2Úf1Úf2ZpevalZpeval_intervalZpeval2rF   rF   rG   Útest_piecewise1$   s    ÿ
ÿÿÿÿ
ÿ
*ÿ
þ
ÿ
"ÿ
 ÿ
þ,<, ..&&&&"ÿ
*( ÿÿ
26 ,4 ÿ
ÿ
ÿ
ÿ, "ý(  0(rt   c                  C   s.   t ttdk ftdfƒ} | jttthks*t‚d S )Nr   T)r&   rM   Úara   Zfree_symbolsr_   ©rk   rF   rF   rG   Útest_piecewise_free_symbols½   s    rw   c                  C   s¼  t ddd\} }t| d d | dkfdƒ}t|| ddfƒtdd	ƒksHt‚t| d
 d
 | dkf|dfƒ}t|| ddfƒtdd	ƒks„t‚t|| dd
fƒtddƒks¢t‚|t| d
 d
 | dkf|| dk fƒksÌt‚t| d
 d
 d| kf|| dk fƒ}t|| ddfƒtdd	ƒkst‚t|| dd
fƒtddƒks.t‚|t| d
 d
 d| kf|dfƒksVt‚t| d
 d
 d| kfd| dfƒ}t|| ddfƒtdd	ƒks˜t‚t|| dd
fƒtddƒks¸t‚d S )Núx yT©ÚrealrC   r   rA   rZ   é   r\   r]   rS   é+   rQ   iCýÿÿé   i_ýÿÿ)r   r&   r1   r   r_   )rM   ra   rk   rl   rF   rF   rG   Útest_piecewise_integrate1Â   s    *"  (" r~   c                  C   s>  t dtdkfdttdƒfdtdk fƒ} t| tddfƒdks>t‚t dtt dk fdƒ} t| tt dfƒtdtƒ ksvt‚|  td¡ tt df¡dks˜t‚t| tdt fƒtdtƒks¸t‚t| tdtfƒt	dtƒ t ksÜt‚t| tt dfƒtdtƒ d kst‚t| tt tfƒt t ks&t‚t dtdk fttdkfdƒ} |  ttdf¡}|  tdtf¡}dt
jd	fD ]J}|  t|df¡| t|¡ks”t‚|  td|f¡| t|¡ksnt‚qn|t tdt	dtƒƒd	  d	 t
j tdk ft d d
fƒksüt‚|t tdt	dtƒƒd	 d	 t
j tdk ftd d
fƒks:t‚d S )Nr?   r   rB   r@   éýÿÿÿr\   é*   rA   rC   T)r&   rM   r   r1   r_   ra   r   r$   r[   r#   r   rd   )rl   Úgy1Úg1yÚyyrF   rF   rG   Útest_piecewise_integrate1bÙ   s.    &"" $(""&&þ$
þr„   c                  C   s¦  t ddd} tdt tddƒ t¡fdt tddƒ t¡fdƒ}| t| df¡}| td| f¡}| tddf¡| | d¡ks€t‚| tddf¡| | d¡ks t‚| tddf¡| | d¡ksÀt‚| tddf¡| | d¡ksàt‚| td	df¡| | d	¡kst‚| tdd	f¡| | d	¡ks$t‚t| 	t¡ƒ 
¡ td| dkf| d	  d	 |  tj | dkf| d	 d	 |  tj | dk fdƒksˆt‚t| 	t¡ƒ 
¡ td| dkf| d	 d	 |  tj | dkf| d	  d	 |  tj | dk fdƒksìt‚|ttdtd| ƒƒd	  d	 tdtd| ƒƒ tdtd| ƒƒd	  tj | dk fdƒksHt‚|ttdtd| ƒƒd	 d	 tdtd| ƒƒ tdtd| ƒƒd	  tj | dk fdƒks¢t‚d S )
Nra   Try   r?   r   rB   r@   rZ   rC   )r   r&   rM   r9   Úcontainsr1   r[   r_   r'   ÚrewriteÚsimplifyr   rd   r$   r#   ©ra   rl   r   r‚   rF   rF   rG   Útest_piecewise_integrate1caó   sd    ý    ""
üÿ

üÿ
(ÿÿþü&ÿÿþür‰   c                  C   s¢  t ddd} tdttdktdkƒfdt tdkfdt dfƒ}| t| df¡}| td| f¡}| tddf¡| | d¡ks~t‚| tddf¡| | d¡ksžt‚| tddf¡| | d¡ks¾t‚| tddf¡| | d¡ksÞt‚| tddf¡| | d¡ksþt‚| tddf¡| | d¡ks t‚t| t¡ƒ 	¡ td| dkf| d  d |  t
j | dkf| d d |  t
j | dk fd	ƒks„t‚t| t¡ƒ 	¡ td| dkf| d d |  t
j | dkf| d  d |  t
j | dk fd	ƒksèt‚|ttdtd| ƒƒd  d tdtd| ƒƒ tdtd| ƒƒd  t
j | dk fd	ƒksDt‚|ttdtd| ƒƒd d tdtd| ƒƒ tdtd| ƒƒd  t
j | dk fd	ƒksžt‚d S )
Nra   Try   r   rB   r?   rZ   rC   r@   )r   r&   r5   rM   r1   r[   r_   r'   r†   r‡   r   rd   r$   r#   rˆ   rF   rF   rG   Útest_piecewise_integrate1cb  sd    
ý     "
üÿ

üÿ
	(ÿÿþü&ÿÿþürŠ   c               
   C   s  ddl m}  ttttƒ}tdttk fdttkfdƒ}| 	|¡}|tt dt  dt
ttttƒƒ  t
tttttƒƒ ttk fdt t dt
ttttƒƒ  t
tttttƒƒ dfƒksºt‚| dƒD ]>}ttttttf|ƒƒ}| |¡ 	| |¡¡| |¡ksÂt‚qÂd S )	Nr   ©Úpermutationsr?   rC   ©r\   TrZ   T)r?   rC   r\   rS   )Ú	itertoolsrŒ   r   rM   ÚcÚdr&   ru   Úbr1   r$   r#   r_   ÚdictÚzipr[   )rŒ   Úlimrg   ÚqÚvÚrrF   rF   rG   Útest_piecewise_integrate2K  s    
:4þ
r˜   c                   C   s*   t dtdk fdƒ ttdf¡dks&t‚d S )Nr?   rS   r@   r   )r&   rM   r1   r   r_   rF   rF   rF   rG   Útest_meijer_bypassX  s    r™   c                  C   s  ddl m}  tddf}d}tdttkfdttkfdƒ}| |¡}| |ddD ]<\}}ttttf||fƒƒ}| 	|¡| 	|¡ |¡ksLt
‚qL| 	td	¡ 	td¡d
ks¦t
‚tdttkfdttk fdƒ}| |¡}| |ddD ]<\}}ttttf||fƒƒ}| 	|¡| 	|¡ |¡ksØt
‚qØd S )Nr   )Úcartesr]   )rZ   rB   r   r?   rC   r]   rQ   rR   r?   rC   r@   )ÚrepeatrS   rR   )Zsympy.utilities.iterablesrš   rM   r&   ru   r‘   r1   r’   r“   r[   r_   )rš   r”   ÚNrg   ÚansÚiÚjÚrepsrF   rF   rG   Ú/test_piecewise_integrate3_inequality_conditions^  s    

 
r¡   c                  C   sp  t ddd} t ddd}t ddd}t ddd}tdt|| k ||kƒfdƒ}td|| k fd||kfdƒ}td||kfd|| k fdƒ}td|| k fd	||k fd
ƒ}td||kfd	|| kfd
ƒ}td	t| |k ||k ƒfd
ƒ}	t|t |ƒ}
||||||	fD ]Š}| |
¡}tdƒD ]r}| d	|d||i}| |¡| |¡ |
 |¡¡ksFt	‚| d|d	||i}| |¡| |¡ |
 |¡¡kst	‚qqöt||tƒ}
||||||	fD ]Œ}| |
¡}tdƒD ]r}| d	|d||i}| |¡| |¡ |
 |¡¡ksît	‚| d|d	||i}| |¡| |¡ |
 |¡¡ks´t	‚q´qžtd|t
| |ƒkf|t
| |ƒ ||kf|t
| |ƒ dfƒ}||||fD ]}| |¡|ksrt	‚qr| |¡td|| k f|  | |t| |ƒkf|  t| |ƒ dfƒksÖt	‚|	 |¡td|| kf|  | |t| |ƒkf|  t| |ƒ dfƒkst	‚td|| k ftj||kfdƒ}ttj||kfd|| k fdƒ}td|| k fd	||k ftjdfƒ}ttj||kfd	|| kfd
ƒ}td	t| |k ||k ƒftj||kfd
ƒ}	t|t |ƒ}
|||||	fD ]Œ}| |
¡}tdƒD ]r}| d	|d||i}| |¡| |¡ |
 |¡¡ks.t	‚| d|d	||i}| |¡| |¡ |
 |¡¡ksôt	‚qôqÞd S )Nru   Try   r‘   rM   ra   r   rA   r?   r@   r]   r\   )r   r&   r5   r2   r   r   r1   Úranger[   r_   r$   r#   r   rd   )ru   r‘   rM   ra   Úp0Úp1rh   ri   rj   ro   r”   rg   r   rž   r    rF   rF   rG   Ú-test_piecewise_integrate4_symbolic_conditionsx  sp    
&,
&.ý

ý

ý"(
&r¥   c                  C   sP   t dttdƒftt dfƒ} t| tddfƒt dttdƒfdt dfƒksLt‚d S )Nr   Tr?   r\   rS   )r&   r   ra   rM   r1   r_   ©rg   rF   rF   rG   Ú0test_piecewise_integrate5_independent_conditions¹  s    r§   c                  C   s  t dttt dkdt dt  dkB dttt dkdt d dk dt dt  dkƒƒft dttt dkddt dt  dkƒfdt dtt dkftdfƒ dfƒdfƒdt dttt dkdt dt  dkB dttt dkdt d dk dt dt  dkƒƒft dttt dkddt dt  dkƒfdt dtt dkftdfƒ dfƒdfƒ  } t| ƒt dtt tjktt dkB fdt d tt dkfdt dt  dfƒks°t‚t| dkƒ t¡ttt tjktt dkB dttt dkdt d dkdt dt  dkƒƒkst‚d S )Nr   r?   rC   FrB   TrS   )	r&   r3   rM   ra   r'   r   rd   r_   r†   r¦   rF   rF   rG   Útest_issue_22917¾  s4    &.ÿ( ÿÿþ(.ÿ( ÿÿþü$þ,.ÿr¨   c            
      C   sZ
  t td d td  ttdt  td  dƒfdt d dfƒ} |  ¡ t tttdƒfdtd  dfƒkslt‚t ttttdƒttt dƒƒfdƒ ¡ t dtttdƒttdƒƒfdƒks¸t‚t dt t	tƒ t	t
ƒt	t
 t ƒ  tt
dƒtt
 t dƒ@ fdt	tƒ t	t
ƒt	t
 t ƒ  tt
dƒtt
 t dƒ@ fdƒ ¡ t dt tttdƒtt
dƒƒfdtttdƒtt
dƒƒfdƒks~t‚dtttdƒtt
dƒƒftdff}t |Ž  ¡ t |Ž ksºt‚dttdƒfttƒt dff}t |Ž  ¡ t |Ž ksòt‚t dt
 tttdƒtt
dƒƒftdfƒ ¡ tks(t‚tdttdƒfttƒd t dfƒ}tttƒ d }tdƒ}t |Ž  ¡ |kszt‚t | t|tƒ¡Ž  ¡ | t|tƒ¡ks¨t‚td	dd
}tddd
}tddd}t | d|  td| dƒf|dd|   |d| d   | d|   dfƒ}| ¡ | d|  ks8t‚t d|dk |dk @ |dk @ f|d d |d  |d  |dk |dk @ ftj|d  d|  |d  |dk |dk @ |dk @ f|d | |d d  tj|d  d|    |dk |dk @ |dk @ |dk @ f|d tj|d  d|  |d d |d    |dk |dk @ f|d | |d d  tj|d  d|    |dk |dk @ |dk @ fd|dk |dk @ f|d d |d  |d  |dk f|d | |d d  tj|d  |d    |dk |dk |dk B @ ftj|d  d|  |d  |dk |dk |dk B @ fdƒt d|dk |dk @ |dk @ fd| |d tj  |d  |dk |dk @ fd| d|d   d|  |dk |dk @ |dk @ fd| d| |d tj  d|d  d|    |dk |dk @ |dk @ |dk @ fd| d|d  d|  |d tj |d    |dk |dk @ fd| d| |d tj  d|d  d|    |dk |dk @ |dk @ fd|dk |dk @ fd| |d tj  |d  |dk fd| |d|d   d| |d tj    |dk |dk |dk B @ fd| d|d   d|  |dk |dk |dk B @ fdƒ } |  ¡ t d|dk f|d |d d  d |dk fd|d  d d|d  d  d |dk fd|d  d d|d  d  d |dk fd| |d d  d |dk fdƒksît‚t}t dtdkfdtdk fdtdkfƒ}	|	 ¡ j|	jks,t‚t dtdk fdtdk fdƒ ¡ t dtdk fdƒksdt‚t dtdkfƒ ¡ t dtdkf|dfƒks”t‚t dtdkttk @ fƒ ¡ t dtdkttk @ f|dfƒksÔt‚t dtdk fdtdktdk @ fdƒ ¡ t dtdk fdtdk fdƒk	st‚t dtdk fdtdktdk@ fdƒ ¡ t dtdk fdtdkfdƒk	sht‚t dtdk fdtdktdk @ fdƒ ¡ t dtdk fdtdktdk @ fdƒk	sºt‚t dtdk fdtdktdk@ fdƒ ¡ t dtdk fdtdkfdƒk
st‚t dtdk fdtdktdk@ fdƒ ¡ t dtdk fdtdktdk@ fdƒk
sVt‚d S )NrC   r?   r   rB   TrA   r@   rk   r   ©ÚintegerrX   Út©ZpositiverS   rZ   r   r\   r]   r   )r&   rM   r   r‡   r   r_   ru   r2   r‘   r   ra   r   r,   r   r   r[   r   r   rd   r)   Úargsr   )
rg   r­   r   rk   r   rX   r«   ÚexprÚnanZcoveredrF   rF   rG   Útest_piecewise_simplifyÎ  s¢   .ÿÿ ÿ ÿþ&ÿÿÿþýý
"*ÿ
$.P(ÿÿÿÿÿÿÿÿ(ÿÿÿ4ÿÿ ÿÿÿ$ÿÿÿÿ÷	ÿÿ"ÿÿ&ÿÿÿÿÿÿÿ(ÿÿÿÿ ÿÿÿ ÿÿÿÿö÷
  ÿÿÿ* ÿ
ÿÿÿý$ÿ
ÿÿ
&ÿ
&ÿ
&ÿÿ
&ÿ
&ÿÿr°   c                     sj  t t tdkfttdkfƒ} |  ttd ¡‰ tˆ tƒdgks@t‚tˆ d tƒddgksZt‚t td d tdkfdƒ‰ tˆ tƒdgksˆt‚t td d tdkfˆ dfƒ}t|tƒddgks¼t‚t td d tdkfˆ tdk fƒ}t|tƒddgksôt‚t td d tdkfˆ tdk fƒ}t|tƒdgks,t‚t td d tdkfˆ dfƒ}t|tƒdgks`t‚t td d tdkfˆ dfd	ƒ}t|tƒdgks–t‚t td d tdkft d td dkftd td dkfƒ}t|tƒdgksêt‚tt td tdkfdt dfƒd ƒd
dgkst‚t td d tdkfdƒ‰ tt‡ fdd„ƒ dd„ }t td d ttk ftd dfƒ}t|tƒ}|dd„ |D ƒƒdgksœt‚|dd„ |D ƒƒddgks¼t‚|dd„ |D ƒƒddgksÜt‚|t dtdkftj	dfƒt dtdkftj	dfƒt dtdkftj	dfƒgks,t‚t td dtd kfdt dtd kfƒ}t|t tƒt t d t dk ftj	dfƒt td tdkftj	dfƒgks¦t‚t
ddd}t|| tƒ| d |d gksØt‚tdƒ‰ ttˆ tƒ t dtdkfdƒƒˆ tƒƒt d
tdkfdƒgks"t‚t dtd  tdtk tdk ƒfdƒ‰ tˆ d ƒdtdƒ gksft‚d S )Nr   rC   r?   r\   rA   r]   rS   T)rU   FrB   r@   c                      s
   t ˆ tƒS rD   )r:   rM   rF   rv   rF   rG   rH   E  rI   z&test_piecewise_solve.<locals>.<lambda>c                 S   s   t tdd„ | ƒƒS )Nc                 S   s
   | t jk	S rD   )r   ÚNaN©rM   rF   rF   rG   rH   H  rI   z4test_piecewise_solve.<locals>.nona.<locals>.<lambda>)ÚlistÚfilter)r   rF   rF   rG   ÚnonaG  s    z"test_piecewise_solve.<locals>.nonac                 S   s   g | ]}|  td ¡‘qS )rZ   ©r[   ra   ©Ú.0rž   rF   rF   rG   Ú
<listcomp>K  s     z(test_piecewise_solve.<locals>.<listcomp>c                 S   s   g | ]}|  td ¡‘qS )rC   r¶   r·   rF   rF   rG   r¹   L  s     rZ   c                 S   s   g | ]}|  td ¡‘qS )r\   r¶   r·   rF   rF   rG   r¹   M  s     rg   r¬   rk   rP   )r&   rM   r[   r:   r_   r;   ÚNotImplementedErrorra   r   r±   r   r   r   r2   r%   )Úabs2rl   rµ   rg   r   Zabsxm3rF   rv   rG   Útest_piecewise_solve%  sf    ""  ÿ4"
  ýþþ&&ÿ
$r¼   c                  C   s>  t ttdk fddtkfƒ} tt|  ƒt td tdk ftdtkfƒksHt‚t| |  ƒt dt tdk fddtkfƒksvt‚tt dtdk fdƒt dtdk fdƒ ƒt dtdk fdƒks´t‚t dtdk fttdkfd	ƒ}t dtdk fdt tdkfd	ƒ}d
| d|  } tt| ƒtt tfƒtdt d tddfƒks4t‚tt dtdkft dtdkfƒ dfƒƒt dtdkfdtdkfƒks|t‚tt tttdktdk tdkƒfƒƒt ttdktdk B tdktdkB @ fƒksÎt‚t dttdƒfd	ƒt ttt t dƒfdtt t dƒfd	ƒ }}tt	||ddƒtt	||ddƒks:t‚d S )Nr?   rC   r   rP   rU   )r^   Té   )iøÿÿÿTr@   rS   TrZ   FrJ   )
r&   rM   r'   r_   r1   r   ra   r3   r   r
   )rg   r¤   rh   ru   r‘   rF   rF   rG   Útest_piecewise_foldh  s>    ..ÿþ  
ÿÿ
"ÿþ
"&ÿ
*ÿÿr¾   c            	      C   s€  t ttƒtdk fdƒ} t dt| dƒf| t| ƒ dfƒ}| tt d ¡dksPt‚| td¡dksdt‚| tt d ¡dks~t‚t dt| dƒfdƒ}t|ƒ}t	ddƒD ] }| t|¡| t|¡ks¤t‚q¤dt dtdk fd	ƒk }t|ƒ}t	dƒD ] }| t|¡| t|¡ksìt‚qìt dtdk fd	ƒ}t dtdk fd	ƒ}t d||k fdƒ}t|ƒ}t	ddƒD ]$}| t|¡| t|¡ksVt‚qVd S )
Nr   r@   TrC   r?   rS   rA   rB   r   )
r&   r+   rM   r   r   r[   r   r_   r'   r¢   )	r¤   rh   rj   r   rž   Úr1ro   rp   Úp7rF   rF   rG   Ú%test_piecewise_fold_piecewise_in_cond…  s&     rÁ   c                  C   s|   t ttƒtdk fdƒ} t dt| dƒfd|  dfƒ}t dtdktttƒdƒB fdttƒ tdk ftdfƒ}t|ƒ|ksxt‚d S )Nr   r@   r?   T)r&   r+   rM   r   r   r'   r_   )r¤   rh   ri   rF   rF   rG   Ú'test_piecewise_fold_piecewise_in_cond_2  s    ýrÂ   c                  C   sê   t dtddddƒ t¡fdƒ} ttdt |  ƒƒ}tdktdk @ }ttdt |  ƒddt dt |ft |fd|fdddks‚t‚ttdt |  ƒd dt dt |fdƒks°t‚|t dt |fdƒksÊt‚|ttdt |  ƒƒksæt‚d S )Nr?   r   FTr@   rJ   )r&   r9   r…   rM   r'   r	   r_   )r¤   rh   rf   rF   rF   rG   Útest_piecewise_fold_expand§  s    "ÿÿrÃ   c                  C   s>   t ttdk ftd tdkftdtk fƒ} | t | jŽ ks:t‚d S )Nr^   rC   rB   r?   )r&   rM   r­   r_   r¦   rF   rF   rG   Útest_piecewise_duplicate´  s    (rÄ   c                  C   s¤   t ttdk ftd dtkftdtk fƒ} t ttdk ftdt ƒdtkftdtk fƒ}| ¡ | ksdt‚|jdd|ksxt‚ttt tdtfƒ ¡ } |  ¡ | ks t‚d S )Nr?   rC   rB   r\   F©Údeep)r&   rM   r0   rc   r_   r   ra   r   )r¤   rh   rF   rF   rG   Ú	test_doit¹  s    (,rÇ   c                  C   s¦   t ttddƒ t¡fdƒ} |  td¡dks.t‚|  td¡dksBt‚|  t¡t dtddƒ t¡fdƒksjt‚t| tƒt dtdkftd d tdkftj	dfƒks¢t‚d S )Nr   r?   r@   g      à¿ç      à?rC   T)
r&   rM   r9   r…   r[   r_   r   r1   r   rd   )r¤   rF   rF   rG   Útest_piecewise_intervalÃ  s    (

ýrÉ   c                  C   s(  t dtdk ftjtdkfdƒ} t| ƒt dtdk ftjttdƒfdtdkfddksVt‚t| d ƒt dtdk ftjttdƒfdtdkfddd ks–t‚tt dtdkft dtdkfƒ dfƒƒt dtdkft dtdkftjtdk fdd tdkfddksþt‚tt dttkfƒƒt dttkftjttkfddks8t‚tt dttkfƒddt dttkfƒksft‚t	d	dd
\}}t d|dk fddd}t d|dk fd|dkfdd}t ||dk fddd}t ||dk fd|dkfdd}t ||dk fd|dkfdd}t|ƒ|kst‚t|dd|ks$t‚d S )Nr   rA   r?   FrJ   rC   T)Zskip_nanzxr, yrry   rP   r   r\   rÅ   )
r&   rM   r   rd   r(   r   r_   ra   r±   r   )rg   ZxrÚyrr¤   Zp1xrh   Zp2xZp2xxrF   rF   rG   Útest_piecewise_exclusiveÎ  sR     
 ÿ$
 ÿÿ
ÿ ÿÿþþþÿÿ
rË   c               	   C   sl  t tdfƒtkst‚tdk } t t| ftd | fƒt t| fƒksBt‚t t| ftd | jfƒt t| fƒksjt‚tdk }dd„ }d| ft d| fd|fƒ|ffd| ft d| fd|jfƒ|ffd| ft d| fd|fƒ|fdfd| ft d| fd|fdƒ|ffd| ft d| fd|fdƒ|fd	ffD ]F}d
D ]:}|t |ddiŽ t|¡ƒ|t |Ž  t|¡ƒkst‚qqtdƒ\}}}}t|k } t|k }t|k }	t|k }
t d| ft d| fd|fd|	fƒ|fd|	fƒt d| fd|fd|	fƒksÖt‚t d| ft d| fd|fd|	fdƒ|	fd|
fƒt d| ft d|fd|	fƒ|	fd|
fƒks0t‚t dt| |
ƒft d|
fd|fd|	fƒ|fd|	fƒt dt| |
ƒft d|
fd|fƒ|fd|	fƒks”t‚t d|	fd|	 fdtjfƒt d|	fdtjfƒksÊt‚t d|	fdt	|	 |ƒfdƒt d|	fd|fdƒks t‚t d|	fdt|	 |ƒfdƒ t
t||||tfdƒƒ¡dks@t‚t d|	fd|	 fƒt d|	fdƒksht‚d S )NTr?   r]   c                 S   s   t | tƒrt| jŽ S | S rD   )re   r&   r­   )rž   rF   rF   rG   Ú	canonicalò  s    

z*test_piecewise_collapse.<locals>.canonicalrC   r\   ©rS   T©r]   T)r   rC   rU   rK   Fzr1:5rS   )rQ   Tr   )r?   rC   r\   rS   g      @rP   )r&   rM   r_   Úreversedr[   r   r5   r   Útruer2   r’   r“   )ru   r‘   rÌ   r­   rž   r¿   Úr2Zr3Zr4r   r   rF   rF   rG   Útest_piecewise_collapseì  s¦    &( ûÿþ
  ÿÿÿþ

   ÿÿÿ
 ÿÿÿþ
  ÿÿÿ ÿÿÿþ
ÿ
ÿ
ÿÿ
rÒ   c                  C   sˆ   t td tdk fttddddƒ t¡fdt tdkfdƒ} tt| ƒ}|dƒdksTt‚|d	ƒd	ksdt‚|d
ƒd
kstt‚|dƒd	ks„t‚d S )NrC   r   r?   FTr@   g       Àg      @rV   rÈ   g       @)r&   rM   r9   r…   r=   r_   )rg   rk   rF   rF   rG   Útest_piecewise_lambdify  s    ü
rÓ   c                  C   sz   ddl m}  tttƒtdk fttƒtdkfƒ}tt| td ƒ tdk fd| td ƒ tdkfƒ}|jtdd|ksvt‚d S )Nr   )ÚOrC   r?   )rX   )Zsympy.series.orderrÔ   r&   r,   rM   r+   Znseriesr_   )rÔ   r¤   rh   rF   rF   rG   Útest_piecewise_series(  s    "2rÕ   c                  C   sn  t dt tdkfdƒ} t ttdkfdƒ}t dt tdkftdfƒ}t ttdkfdt dfƒ}t dt tdkftdfƒ}t dt tdk ftdfƒ}t ttdk fdt dfƒ}t ttdkfdt dfƒ}|  t¡dksÖt‚| t¡dksèt‚| t¡tksút‚| t¡dt kst‚| t¡tks&t‚| t¡dt ks>t‚| t¡tksRt‚| t¡dt ksjt‚d S )Nr?   r@   Tr   )r&   rM   Zas_leading_termr_   )r¤   rh   ri   rj   ro   rp   rÀ   Úp8rF   rF   rG   Útest_piecewise_as_leading_term/  s     r×   c                  C   s<  t dtdk fddtkfƒ} t dt tdk ftdtkfƒ}t tt tdkfdt dfƒ}t t ttƒ tdkfdt dfƒ}t| ƒ| ksŠt‚t|ƒt| ƒks t‚t|ƒ|ks°t‚| jdks¾t‚| jdksÌt‚|jdksÚt‚|jdksèt‚|jd ksöt‚|jd kst‚|  ¡ | dfkst‚| ¡ dt | fks8t‚d S )NrC   r   r?   TF)	r&   rM   r   r   r_   r'   Zis_imaginaryZis_realZas_real_imag)r¤   rh   ri   rj   rF   rF   rG   Útest_piecewise_complexB  s    $rØ   c                  C   sè   t ddd\} }t| |d  tdkf| d | dfƒ}| ¡ tt| |d  ƒtdkft| d | ƒdfƒkspt‚| ¡ tt| |d  ƒtdkft| d | ƒdfƒksªt‚| ¡ tt| |d  ƒtdkft| d | ƒdfƒksät‚d S )NúA BF)ZcommutativerC   r   T)r   r&   rM   r   r_   r   r    )ÚAÚBrg   rF   rF   rG   Útest_conjugate_transposeW  s    &,ÿ,ÿ,ÿrÜ   c                  C   s    t tdfƒtkst‚t tdfddtks,t‚t dtdtƒfƒjdttdƒffksTt‚t dtdtƒfddjdtdtƒffks€t‚t tdfdd} | tksœt‚d S )NTrJ   r?   F)r&   rM   r_   r   r­   r¦   rF   rF   rG   Útest_piecewise_evaluateb  s    (ÿ
rÝ   c                   C   s˜   t ttdkft tdkfƒ ¡ ttdtddƒft tt dƒfgksHt‚t td d tdkfdƒ ¡ td d tdtƒfdtt dddƒfgks”t‚d S )Nr   TrC   r@   )r&   rM   Úas_expr_set_pairsr9   r   r_   rF   rF   rF   rG   Útest_as_expr_set_pairsn  s    "ÿ(ÿrß   c                  C   s0   t dttdƒfdƒ} tt| ƒƒ}| |ks,t‚d S )NrU   r   )é   T)r&   r   rM   r   r7   r_   )rg   r•   rF   rF   rG   Útest_S_srepr_is_identityv  s    rá   c                  C   s¦   t dtdkfdttdktdk@ ƒfdƒ} |  tddf¡d	ks@t‚t dtdkfdttk fdƒ} td
df}|  |¡}tddƒD ]&}| t|¡|  t|¡ |¡kszt‚qzd S )Nr?   rS   rC   r\   rB   r   rT   r]   é   r   )r&   rM   r4   r1   r_   ra   r¢   r[   )rg   r”   r   rž   rF   rF   rG   Útest_issue_12587|  s    (

rã   c                  C   sÊ  t dtttd d ƒ  tddfƒtd ks0t‚tdtttdk tdkƒtdk ƒfdƒ  tddf¡dksjt‚tdtdkfdttd kfdƒ  tddf¡dksžt‚tdtdkfdtdtƒfdƒ  tddf¡d	ksÐt‚tdtdt td ktdk ƒfdƒ  tddf¡dks
t‚tdtdt td ktdk ƒfdƒ  tddf¡dksDt‚tdtdkfdttd kfdƒ  tddf¡dkszt‚tdtdt tdt d  ƒfdƒ  tddf¡d	ks´t‚tdttdk tdkƒfdtdkfdƒ  tddf¡d	ksðt‚tdt	tdƒfd
ƒ  tddf¡dkst‚tttdktdk @ fdtdk fƒ  tddf¡dksRt‚tttdktdk @ fdtdk fƒ} t
}|   tdtf¡}|ttd tdk ftdtƒd d tdtƒ tdtƒ tj ttdtƒkf|dfƒksät‚|   tddf¡| td¡kst‚|   tddf¡dks t‚|   tddf¡|ks:t‚tdtdkfdtttdktdk ƒƒfdƒ} |   tddf¡dks~t‚tdtdtktdkƒfdttdk tdkƒfdtdk fƒ} |   tddf¡dksÐt‚tdtdk fdtttdƒtdkƒfƒ  tddf¡tjkst‚tdtdk fdtttdƒtdkƒfdƒ  tddf¡dksLt‚tdtdk fdtttdƒtdk ƒfdƒ  tddf¡dksŠt‚tdtdk fdttdƒttk @ fdƒ  tddf¡dksÆt‚d S )Nr?   rC   r\   r@   r   r   r]   rS   rQ   rP   rB   TrR   é   rU   é   )r1   rM   r%   r   r_   r&   r2   r5   r   r   r)   ra   r$   r   rd   r[   r4   r±   )rg   r¯   rž   rF   rF   rG   Útest_issue_11045‡  s¸    0&ÿÿ ÿÿÿÿ$ÿÿ
$ÿÿ
 ÿÿ
$ÿÿ
&ÿÿ
ÿÿ
"ÿÿ
"*ÿü"*
ý&ÿÿ
(ÿÿ
(ÿÿ
&ÿÿræ   c                  C   sŒ  t } tdtdk fƒ t¡tttdk f| dfƒks4t‚tdttdktdk ƒfƒ t¡t| tdk fttdk f| dfƒksxt‚tdttdktdk ƒfƒ tddf¡| ks¦t‚tdttdktdk ƒfƒ tddf¡dksÔt‚tdƒ\}}tddd	\}}t|ttdk |dk ƒf|ttdk |dkƒfƒ t¡t|t |dkft|t tdk f|t tdk f| dfƒ|dk ft|t tdk f| dfƒdfƒksˆt‚d S )
Nr?   rC   Tr   r\   rS   rÙ   za bry   )r)   r&   rM   r1   r_   r2   r   r5   )r¯   rÚ   rÛ   ru   r‘   rF   rF   rG   Ú
test_holesÑ  s.    
 ÿ
 
 
 ÿ
...ÿ.ýÿrç   c                     sÀ   dd„ ‰ ‡ fdd„} | dƒdks$t ‚tdƒ}‡ fdd„}||ƒ}| |d	¡dksTt ‚tdd
d}||ƒ}| |d	¡dks|t ‚tdtdk fdtdkfƒ ¡ tdtdk fdt d d
fƒks¼t ‚d S )Nc                 S   s$   t d| dk fd| d  | dk fdƒS )Nr   rB   r?   rC   r@   rE   r²   rF   rF   rG   rk   æ  s    ztest_issue_11922.<locals>.fc                    s    ˆ t ƒˆ t |  ƒ  t ddf¡S )NrB   r?   ©rM   r1   ©Úkrv   rF   rG   rH   è  s    ÿÿz"test_issue_11922.<locals>.<lambda>gffffffþ?r   rê   c                    s$   dt d  ˆ t |  ƒ  t ddf¡S )Nr?   rC   rB   rè   ré   rv   rF   rG   rH   ì  s    ÿÿr\   Tr¬   r?   rU   )r_   r   r[   r&   rM   r1   )Zautocorrrê   Zgood_autocorrru   rF   rv   rG   Útest_issue_11922å  s    ÿrë   c               	   C   sä   dt dtdk fdt d tdk ft dtdkfd	ƒt d
tdkfdƒ tdkfdt d tdk fdƒ } t| tt tfƒ}|t| tt tfƒ ¡ ks”t‚t|ƒdks¤t‚t dtt dk fdƒ t¡t dttkft t dfƒksàt‚d S )Ngý©§J™¢j?r   gf'vb'6TÀgŠÈlAw¿g¶3Ø†Põ?rC   g333333Ó?é{   )gffffffæ?Tgš™™™™™Ù?)g333333ã?Tgð%Ñ”½€¿g%JMã× @gš$I’$Éw@r@   z1.00195081676351r?   T)	r&   rM   r1   r   r0   rc   r_   Ústrra   )rk   rž   rF   rF   rG   Útest_issue_5227÷  s,    ÿÿÿÿûÿÿrî   c            
      C   st  t ddd} t ddd}t ddd}t ddd}tdt|| k ||kƒfdƒ}tdt| |k||k ƒfdƒ}t|||tfƒt|||tfƒksŒt‚td	td|k || k ƒfd
ƒ}td	t| |k|dkƒfd
ƒ}t||ƒ}|td|dkf||td| ƒkftd| ƒdfƒkst‚t||ƒ}	|	|kst‚| |ddf¡tdtd| ƒƒd ksFt‚| |ddf¡tdtd| ƒƒd kspt‚d S )Nru   Try   r‘   rM   ra   r   rA   r?   r@   rC   rS   )	r   r&   r5   r1   r   r_   r2   r#   r$   )
ru   r‘   rM   ra   r£   r¤   ri   rj   Zip3Zip4rF   rF   rG   Útest_issue_10137  s&    $

ý
*rï   c                     sž   dd„ ‰ ‡ fdd„} | t ƒ}| t d¡| t d¡ks8t‚| t d¡dksLt‚tˆ t t ƒˆ tƒ ƒtdtd	ktdk@ t t d	k@ t t dk@ fd
ƒksšt‚d S )Nc                 S   s   t d| dk| dk@ fdƒS )Nr?   rB   r@   rE   r²   rF   rF   rG   rH     rI   z-test_stackoverflow_43852159.<locals>.<lambda>c                    s$   t ˆ | t ƒˆ tƒ tt t
 fƒS rD   )r1   ra   r   r²   rv   rF   rG   rH     rI   g      ø¿g      ø?r\   r   r?   rB   r@   )rM   r[   r_   r'   ra   r&   )ZConvZcxrF   rv   rG   Útest_stackoverflow_43852159  s    *þrð   c                  C   s®   t ddd} t dddd}dd„ }t|| ƒ| t tfƒtd ksDt‚t||  ƒt| d ƒ }t|| t tfƒtdd	|  |d  d|d   t|d
ƒftd dfƒksªt‚dS )aD  
    # 3200 seconds to compute the fourier part of issue
    import sympy as sym
    x,y,z,t = sym.symbols('x y z t')
    k = sym.symbols("k", integer=True)
    fourier = sym.fourier_series(sym.cos(k*x)*sym.sqrt(x**2),
                                 (x, -sym.pi, sym.pi))
    assert fourier == FourierSeries(
    sqrt(x**2)*cos(k*x), (x, -pi, pi), (Piecewise((pi**2,
    Eq(k, 0)), (2*(-1)**k/k**2 - 2/k**2, True))/(2*pi),
    SeqFormula(Piecewise((pi**2, (Eq(_n, 0) & Eq(k, 0)) | (Eq(_n, 0) &
    Eq(_n, k) & Eq(k, 0)) | (Eq(_n, 0) & Eq(k, 0) & Eq(_n, -k)) | (Eq(_n,
    0) & Eq(_n, k) & Eq(k, 0) & Eq(_n, -k))), (pi**2/2, Eq(_n, k) | Eq(_n,
    -k) | (Eq(_n, 0) & Eq(_n, k)) | (Eq(_n, k) & Eq(k, 0)) | (Eq(_n, 0) &
    Eq(_n, -k)) | (Eq(_n, k) & Eq(_n, -k)) | (Eq(k, 0) & Eq(_n, -k)) |
    (Eq(_n, 0) & Eq(_n, k) & Eq(_n, -k)) | (Eq(_n, k) & Eq(k, 0) & Eq(_n,
    -k))), ((-1)**k*pi**2*_n**3*sin(pi*_n)/(pi*_n**4 - 2*pi*_n**2*k**2 +
    pi*k**4) - (-1)**k*pi**2*_n**3*sin(pi*_n)/(-pi*_n**4 + 2*pi*_n**2*k**2
    - pi*k**4) + (-1)**k*pi*_n**2*cos(pi*_n)/(pi*_n**4 - 2*pi*_n**2*k**2 +
    pi*k**4) - (-1)**k*pi*_n**2*cos(pi*_n)/(-pi*_n**4 + 2*pi*_n**2*k**2 -
    pi*k**4) - (-1)**k*pi**2*_n*k**2*sin(pi*_n)/(pi*_n**4 -
    2*pi*_n**2*k**2 + pi*k**4) +
    (-1)**k*pi**2*_n*k**2*sin(pi*_n)/(-pi*_n**4 + 2*pi*_n**2*k**2 -
    pi*k**4) + (-1)**k*pi*k**2*cos(pi*_n)/(pi*_n**4 - 2*pi*_n**2*k**2 +
    pi*k**4) - (-1)**k*pi*k**2*cos(pi*_n)/(-pi*_n**4 + 2*pi*_n**2*k**2 -
    pi*k**4) - (2*_n**2 + 2*k**2)/(_n**4 - 2*_n**2*k**2 + k**4),
    True))*cos(_n*x)/pi, (_n, 1, oo)), SeqFormula(0, (_k, 1, oo))))
    rM   Try   rê   )rª   Zfinitec                 S   s   t |  | dkf| | dkfƒS ©Nr   rE   r²   rF   rF   rG   rH   D  rI   z"test_issue_12557.<locals>.<lambda>rC   rB   r   N)r   r1   r   r_   r+   r%   r&   r   )rM   rê   r»   ÚfuncrF   rF   rG   Útest_issue_12557%  s    "( 
ÿró   c               	   C   sª  ddl m}  tdƒ\}}}}td||k ftt||k||k ƒfd||kfƒ}| |¡}|td||kf|t |t  |t||ƒkf| t tt||ƒ  dfƒks¢t‚| t	dƒƒD ]T}t
t||f|ƒƒ}t	ddƒD ]2}	| |¡ ||	¡| |¡ |¡ ||	¡ksÎt‚qÎq®t|||ƒ}
| |
¡}t| t tt|t||ƒƒ  ||kfdƒ}| t	dƒƒD ]D}t
t|||f|ƒƒ}| |¡ |
 |¡¡}|| |¡ksRt‚qR||ks¦t‚d S )	Nr   r‹   z
t0, t1 T tTrC   rB   r\   r@   )rŽ   rŒ   r   r&   rM   r2   r1   r#   r_   r¢   r’   r“   Úxreplacer[   r   r$   )rŒ   Út0Út1ÚTr«   rk   rl   rž   r    Úttr”   r   ZtrurF   rF   rG   Útest_issue_6900J  s4    .

ý
ÿ
$þrù   c                   C   sV   t ttƒttd ƒ d dktƒttt tk ttjk ƒttjtk ttk ƒƒksRt	‚d S )Nr?   r   )
r:   ÚabsrM   r5   r2   r   r   ZZeroZOner_   rF   rF   rF   rG   Útest_issue_10122d  s     *ÿrû   c                  C   sÌ  t dtdkfdttkftt dfƒ} | |  tt¡ d tt d  }tdtƒ}t|tƒ ¡ t t dtdkftd  td t td t   ttd   dt tt ƒ td   dt ttt ƒ td   ttd   t|kftd  td  t td |   dt |   dtt   dt tt ƒ td   dt tt | ƒ td   ttd   |td   dfƒttktdk@ tdktt	 k@ B ft dtt  tdkftd  td t td t   dt t td t td t    td td t td t    dtt ƒ t  dttt ƒ t  dt  ttd   dt tt ƒ td   dt ttt ƒ td   ttd   t|kftd  td  t td |   dt t td  t td |    td td  t td |    dtt ƒ t  dtt | ƒ t  dt  dt tt ƒ td   dt tt | ƒ td   ttd   |td   dfƒttkft td  td t td t   tdkfttd  ttd   t|kftd td  t td |   td td t td t    dt t td  t td |    dt t td t td t    td td  t td |    td td t td t    ttd   |td   dfƒdfƒksÈt
‚d S )Nr   r?   TrC   rB   )r&   rM   ru   r[   ra   r#   r1   r	   r"   r   r_   )ÚuÚeÚMrF   rF   rG   Útest_issue_4313i  sÌ    $ 

Fÿ
ÿÿ0
ÿÿÿÿÿ
þ
þþü ùDÿÿÿþ
þþþ
ýý8
ÿ ÿþþþýý
ü
üüúõ( ÿ$ÿ"þ þý
ý
ýýýùërÿ   c                   C   sN  t td ttdƒfƒ t¡dg fks(t‚t dttd kft dttd k fƒdt dt d k fdƒ t¡dt tddfgfks‚t‚t dtttƒfdƒ t¡dt tddfgfks´t‚t ttƒ t	tƒdkfttƒdfƒ t¡ddt
ttƒ dft tttƒdfgfkst‚t dttd ƒdkfdƒ t¡dd	d
t tddfgfksJt‚d S )NrC   r\   Tr?   rA   r@   r   rZ   )rB   r   r?   r   )r   r?   r?   r   )r&   rM   r   Z
_intervalsr_   r   r   r   r+   r,   r   r   rF   rF   rF   rG   Útest__intervalsŒ  s6    (&ýýýÿ
$ÿ"ÿÿ
ÿÿÿr   c                  C   s¾   dddddg\} }}}}t |tdkf|dfƒt | ttd ƒdk f|ttd ƒdk f|dfƒ }| t¡ t¡t || tdkf| | tdkf| | tdk f|| tdk f|| dfƒksºt‚d S )Nr?   rC   r\   rS   r]   Tr   )r&   rM   r   r1   r   r_   )ru   r‘   r   r   rý   rg   rF   rF   rG   Útest_containmentž  s    .ÿ
ûr  c                  C   sš   t td ƒ} t| tt tfƒdks&t‚t| tddfƒdks>t‚t| ttdƒfdƒ t¡dks`t‚t| tdk fdƒ t¡tttd ƒtdk fdƒks–t‚d S )Nr?   r   rC   r@   rA   )r-   rM   r1   r   r_   r&   r   r.   )Zd1rF   rF   rG   Útest_piecewise_with_DiracDeltaª  s    " ÿr  c                  C   sx  t dtdk fdƒjd kst‚t dtdk fdƒjdks8t‚tddd} t dtdk f| dfƒjs`t‚t dtdk f| td	k fƒjd ks„t‚tdƒ} t dtdk f| dfƒjd ks¬t‚t dtdk fdƒjd ksÈt‚t dtdk fd
ƒjsàt‚t dtdk ftdfƒjd kst‚t dtdk fdƒjst‚tƒ }t |tdk fƒjd ks>t‚t dtdk fd
ƒd	k }|dksbt‚t	|ƒdkstt‚d S )Nr   r?   rA   rB   Fru   T)Úzeror\   rP   )
r&   rM   Úis_zeror_   r   Z
is_nonzeror   Ú	is_finiter   r'   ©ru   r‘   r   rF   rF   rG   Útest_issue_10258¶  s     $ "r  c                  C   s–   t ttdkfdƒt ttdkfdƒ } }| | }t|ƒ}dD ] }| t|¡| t|¡ks:t‚q:| | }t|ƒ}dD ] }| t|¡| t|¡kspt‚qpd S )Nr?   rP   r\   r   )r   rC   rS   )r&   rM   r'   r[   r_   )ru   r‘   Úmrk   rž   rF   rF   rG   Útest_issue_10087Ë  s    &r	  c                  C   sê  t dƒ} t dƒ}t| d |dk f| d dfƒ}t| d |tddƒk f| d dfƒ}t|| |ddfƒ| d | d  d d| d  | d  d  | d | d   ks¦t‚td|dk fd	ƒ}td|dk fd
ƒ}t|| |ddfƒdksæt‚t ddd}t ddd\}}} }}ttd||k|dk B || kB f|dfƒ|d|fƒ}| ¡ }	|	td|| kf|t||ƒ |td|ƒ  dfƒkszt‚dD ]f}
tddƒD ]T}t| d|ƒD ]>}|| k|
f||f||fg}|	 	|¡| 	|¡ ¡ ksžt‚qžqŒq~d S )Nzc:5rM   r?   rC   Tr\   rS   r   rP   r@   rQ   ra   r¬   z	a,b,c,x,zry   )TF)
r   r&   r   r1   r_   r0   rc   r$   r¢   r[   )r   rM   rr   rs   ra   ru   r‘   r>   r   r   rf   rƒ   Úzzr    rF   rF   rG   Útest_issue_8919×  s2    $:ÿþþ8r  c                  C   sò   t dƒ} tdt| tƒd dƒfdtd dk fdƒ}| t¡t|tƒksJt‚| tddf¡t|tddfƒksnt‚t|tddfƒ | tƒtd ¡ ¡ dksšt‚| t	¡tt	t| tƒdƒtdk t| tƒdƒ@ B fdt	 tt
 ktdk @ fdƒksît‚d S )	Nrk   r?   r   rC   rU   r@   r]   g      $@)r   r&   r   rM   r1   r0   r_   r[   rX   ra   r   )rk   rg   rF   rF   rG   Útest_unevaluated_integralsð  s    *$,
& þr  c                  C   s\   t dƒ\} }}ttttdk tdkftdkdfƒfƒttttdktdk tdkƒfƒksXt‚d S )Nza:cr?   r   T)r   r&   rM   ra   r3   r_   r  rF   rF   rG   Ú%test_conditions_as_alternate_booleans  s    $ÿr  c                     sd  t dƒ\‰‰} }dd„ ‰ ˆ ˆtdk fˆtdkfƒttdk ˆˆƒksFt‚ˆ ˆtdk fˆttk fƒttdk ˆˆƒkstt‚ˆ ˆtdk fˆttdk ttk ƒf| tdkfƒttdk ˆˆƒks¶t‚ˆ ˆtdk fˆdfƒttdk ˆˆƒksàt‚ˆ ˆtdk fˆtdk f| dfƒttdk ˆttdk ˆ| ƒƒks"t‚ˆ ˆtdk fˆtdk f| dfƒttdk ˆttdk ˆ| ƒƒksdt‚ˆ ˆtdk fˆttk f| tdk fƒttdk ˆˆƒksžt‚ˆ ˆtdk f| tdk fˆttk f|dfƒttdk ˆttdk | ˆƒƒksêt‚ˆ ˆtdk fˆtttk tdk ƒfƒttdk ˆˆƒks$t‚tt‡ fdd	„ƒ tt	‡ ‡fd
d	„ƒ tt
‡ ‡‡fdd	„ƒ d S )Nza:dc                  W   s   t | Ž  t¡S rD   )r&   r†   r3   )r­   rF   rF   rG   Ú_ITE
  s    z+test_Piecewise_rewrite_as_ITE.<locals>._ITEr?   r   TrC   c                      s   ˆ t d t dk ft dfƒS rO   r²   rF   )r  rF   rG   rH     rI   z/test_Piecewise_rewrite_as_ITE.<locals>.<lambda>c                      s   ˆ t t tk ftt ˆkfƒS rD   )rM   ra   rF   )r  ru   rF   rG   rH      rI   c                      s   ˆ ˆt dk fˆt dkfƒS )NrC   r\   r²   rF   ©r  ru   r‘   rF   rG   rH   !  rI   )r   rM   r3   r_   r   r5   ra   r;   r`   rº   Ú
ValueError)r   r   rF   r  rG   Útest_Piecewise_rewrite_as_ITE  s4    ..,ÿ*ÿ
ÿ
"ÿ
(ÿ
"ÿ
r  c                   C   s(   t tttƒƒtddt fƒdks$t‚d S )Nr   rC   rS   )r1   rú   r,   rM   r   r_   rF   rF   rF   rG   Útest_issue_14052$  s    r  c                   C   sÞ   t tdtfdtfdƒtdtfdƒ ƒtdtfdtfdƒks>t‚t tdtfd	tfd
ƒtdtfdƒ ƒtdtfdtfdƒks|t‚t tdd„ tdƒD ƒŽ ƒtdtfdƒks¨t‚t tdd„ tddƒD ƒŽ ƒttdƒtfdƒksÚt‚d S )Nr?   rC   rÍ   rä   )é   Té	   é   )rå   Tr\   rÎ   rR   )r½   Tr{   é!   )é7   Tc                 S   s   g | ]}t |tfd ƒ‘qS ©r@   ©r&   ru   r·   rF   rF   rG   r¹   2  s    z$test_issue_14240.<locals>.<listcomp>é(   i  r@   c                 S   s   g | ]}t |tfd ƒ‘qS r  r  r·   rF   rF   rG   r¹   5  s    é)   )	r'   r&   ru   r‘   r_   r   r¢   r
   r   rF   rF   rF   rG   Útest_issue_14240(  s0    ÿÿýÿÿý
ÿþ
ÿþr  c                  C   s>   t dƒ} t| | dk ftdƒd dfƒ}t| ¡ ƒdks:t‚d S )NrM   r?   é:   rR   Tz/Piecewise((x, x < 1), (8.28571428571429, True)))r   r&   r   rí   rb   r_   ©rM   rk   rF   rF   rG   Útest_issue_14787:  s    r  c                     sŒ  t dƒ\} }td| dk|dk@ | dk| dk @ |dk @ B |dk| dk @ tt|dƒdƒ@ B |dk| dk@ | dk @ tt|dƒdƒ@ B ftj| dk|dk @ | dk|dk@ | dk @ B |dk| dk @ tt|dƒdƒ@ B |dk| dk@ | dk @ tt|dƒdƒ@ B ftj tt|dƒdƒ|dk| dk @ |dk| dk@ | dk @ B @ fd|dk| dk @ tt|dƒdƒ@ |dk| dk@ | dk @ tt|dƒdƒ@ B fƒ}tdt| dƒt|dƒB t| dƒtt|dƒdƒ@ B fdt| dƒ|dk@ fdt| dƒtt|dƒdƒ@ f|tt| ƒdƒtt|ƒdƒ@ fƒ}t|ƒ}| ¡ }| ¡ }ddtj dtjddf}|D ]N}|D ]B}	| |||	i‰ ‡ fdd„||||fD ƒ}
t	t
|
ƒƒdks@t‚q@q8d S )	Nzb erC   r?   r   rB   rZ   c                    s   g | ]}|  ˆ ¡‘qS rF   )rô   )r¸   rê   ©r—   rF   rG   r¹   a  s     z$test_issue_21481.<locals>.<listcomp>)r   r&   r   r   r   rd   r   r'   r‡   ÚlenÚsetr_   )r‘   rý   ÚCrÚ   rÛ   ÚsaÚsbr–   rž   rŸ   ÚokrF   r   rG   Útest_issue_21481?  s\    ÿþ&ýÿÿþ&ýÿ&ÿÿ&ÿÿò0ür'  c                  C   s  t dƒ\} }tdt| dƒft| ƒdfƒ}| ¡ t| ƒks<t‚t| t| dƒfd|  |d d  t| dƒt| | dƒ@ ft| ƒdfƒ}| ¡ t| ƒks–t‚t| d t| dƒfd|  |d d  t| dƒt| | dƒ@ ft| ƒdfƒ}| ¡ tdt| dƒft| ƒdfƒks
t‚d S )Nrx   r   TrS   rC   r?   rB   )r   r&   r   r,   r‡   r_   )rM   ra   r¤   rh   ri   rF   rF   rG   Útest_issue_8458e  s    FJr(  c               	   C   s”  t dƒ} ttdttt| ƒdƒtt| ƒdƒƒfdƒs6t‚t dƒ}ttt	j
t|ƒdk fdtt|ƒdktt|ƒdƒƒft	jdfƒs€t‚t ddd}tt	j
t|ƒdk fdtt|ƒdktt|ƒdƒƒft	jdfƒ}|tt	j
|dk fd|dkft	jdfd	d
ksøt‚t| }tt	j
t|ƒdk fdtt|ƒdktt|ƒdƒƒft	jdfƒ}|tdtt|ƒdƒft	jdfd	d
ksht‚|tdt|dƒft	jdfd	d
kst‚d S )Nr>   r?   r   rP   rM   Tr—   ry   FrJ   )r   r   r&   r5   r   r   r   r   r_   r   ÚPir   r±   r   )r>   rM   r—   rg   rž   rF   rF   rG   Útest_issue_16417r  s<    .þþ
 þ
þ ÿ ÿr*  c                     sÒ  t dƒ\} }}}}}t‰ ‡ fdd„}tdt| |ƒfdƒ}||ƒdˆ | |ƒ ksRt‚t| t|dƒf|t|dƒf|dfƒ}||ƒ|ˆ d|ƒ ˆ d|ƒ |ˆ d|ƒ  |ˆ d|ƒ  | | ˆ d|ƒ  |ˆ d|ƒ ˆ d|ƒ  |ˆ d|ƒ  ksît‚tdt| |ƒfdƒ}	||	ƒdˆ | |ƒ kst‚tdt| d	ƒfd
dƒ}
||
ƒdd	ˆ d	| ƒ  ksTt‚td	t| dƒfdt|dƒfdƒ}||ƒˆ d| ƒ ˆ d|ƒ dˆ d| ƒ  d	 ksªt‚tdt| dƒt|dƒ@ fdƒ}||ƒˆ d| ƒ ˆ d|ƒ ˆ d| ƒ ˆ d|ƒ ks t‚tdt|d	ƒt| dƒ@ fdƒ}||ƒˆ d| ƒ ˆ d	|ƒ ˆ d	|ƒ d ksPt‚tdt| d	ƒt|dƒ@ fdƒ}||ƒdˆ d|ƒ ˆ d	| ƒ d	ˆ d	| ƒ  d ks¦t‚tdt| dƒt|dƒ@ fdƒ}||ƒdˆ d|ƒ ˆ d| ƒ d ksît‚tdt| dƒt|dƒB fdƒ}||ƒdˆ d| ƒ ˆ d|ƒ d ks6t‚tdt|dƒt| dƒB fdƒ}||ƒˆ d| ƒ ˆ d|ƒ ˆ d| ƒ d ks†t‚tdt| dƒt|d	ƒB fdƒ}||ƒdˆ d| ƒ ˆ d	|ƒ dˆ d	|ƒ  d ksÜt‚td	t| dƒt|dƒB fdƒ}||ƒdˆ d| ƒ ˆ d|ƒ dˆ d| ƒ  dˆ d|ƒ  d ks@t‚tdt| dƒt|dƒB fdƒ}||ƒdˆ d| ƒ ˆ d|ƒ d ksˆt‚tdt| d	ƒt|dƒB fd	t| dƒt|dƒ@ fdƒ}||ƒdˆ d|ƒ ˆ d	| ƒ ˆ d| ƒ ˆ d|ƒ ˆ d|ƒˆ d	| ƒ  dˆ d|ƒ ˆ d| ƒ ˆ d|ƒ  ˆ d|ƒ d ks:t‚tdt||ƒfdƒtdt||ƒfdƒ tdt|| ƒfdƒ tdt|| ƒfdƒ }||ƒˆ ||ƒˆ ||ƒ ˆ || ƒ ˆ || ƒ ksÀt‚tdt|| ƒt||ƒt||ƒB t|| ƒB @ fdt|| ƒfdt||ƒt||ƒB t|| ƒB fdƒ}||ƒˆ ||ƒˆ ||ƒ ˆ || ƒ ˆ || ƒ ksTt‚tdt|dƒt| dƒt| |ƒ@ B fd
ƒ}||ƒdˆ d| ƒ ˆ d|ƒ ˆ | |ƒ dˆ d| ƒ ˆ | |ƒ  dˆ d|ƒ  d ksÖt‚td| dkfdƒ}||ƒ|ksút‚tdt| dk | dkƒfdƒ}||ƒ|ks(t‚tdt| dk| dk ƒfdƒ}||ƒ|ksVt‚tdt|dƒt| dƒB t| dƒt|dƒB @  fdƒ}||ƒˆ d|ƒˆ d| ƒ ˆ d|ƒˆ d| ƒ  ˆ d| ƒ d ksÎt‚d S )Nzx y z n t mc                    s   t |  ˆ ¡ƒS rD   )r	   r†   r¦   ©ÚKrF   rG   rH   •  rI   z5test_eval_rewrite_as_KroneckerDelta.<locals>.<lambda>r   rA   r?   Tr@   r\   rÍ   rÎ   rS   rC   r   rQ   r]   éüÿÿÿrP   rB   rZ   r   rT   rä   )r   r/   r&   r   r_   r   r2   r5   )rM   ra   r>   rX   r«   r  rk   r¤   rh   ri   rj   ro   rp   rÀ   rÖ   Zp9Zp10Zp11Zp12Zp13Zp14Zp15Zp16Zp17Zp18Zp19Zp20Zp21Zp22rF   r+  rG   Ú#test_eval_rewrite_as_KroneckerDelta’  s†    $<ÿÿÿ
  6828**28F*4D ÿÿÿ&ÿÿ6,   ÿ6(Z4r.  c                  C   s8   ddl m} m} | dddƒ}| dddƒ}||| ƒ d S )Nr   )ÚUniformÚdensityÚu1r?   Úu2)Zsympy.statsr/  r0  )r/  r0  r1  r2  rF   rF   rG   Útest_identical_conds_issueÞ  s    r3  c                  C   s:   t dtdkfƒ} t| tdtddƒfƒ}t|ƒdks6t‚d S )Nr?   i`	  r   z252.4é   z252.400000000000000000000000000)r&   rM   r1   r   rí   r_   )rk   r–   rF   rF   rG   Útest_issue_7370è  s    r5  c                  C   s‚   t dƒ} t dƒ}tdddƒ}||d | |d i}tdt|dk| dk dƒfƒ}| |¡tdt|d dk|d dk dƒfƒks~t‚d S )NrM   ra   Úinpr?   )r   r   r   T)r   r6   r&   r3   rô   r_   )rM   ra   r6  Zrep_dictrg   rF   rF   rG   Útest_issue_14933î  s    r7  c                   C   s   t tdd„ ƒ d S )Nc                   S   s   t ttdk fdtdkfƒ ¡ S )Nr   r?   )r&   rM   ra   rÞ   rF   rF   rF   rG   rH   ú  rI   z"test_issue_16715.<locals>.<lambda>)r;   rº   rF   rF   rF   rG   Útest_issue_16715ù  s    r8  c                  C   s†   t ddd\} }t ddd}t|tj  }tt|| ƒ|d| fƒ}| ¡ dtt|  d| d  d ƒ d td| d   ks‚t‚d S )	Nzt tauTry   rX   r©   r   rC   r?   )r   r   r   rd   r1   r!   r‡   r_   )r«   ÚtaurX   ZlamÚeqrF   rF   rG   Útest_issue_20360ý  s
    r;  c                  C   s–  dd„ } | t ttt ktdk @ fƒƒtt ktdk @ ks<t‚| t ttt kttk @ fƒƒtt kttk @ kspt‚| t ttdktdk @ fƒƒtdktdk @ ks t‚| t ttdkttk @ fƒƒtdkttk @ ksÐt‚| t ttdktt k@ fƒƒtdktt k@ kst‚| t ttdktdk@ fƒƒtdktdk@ ks8t‚| t ttdktdk @ fƒƒtdktdk @ ksjt‚| t ttdkttk @ fƒƒtdkttk @ ksœt‚| t ttdktdk@ fƒƒtdktdk@ ksÎt‚| t tttktt k@ fƒƒtt kttk@ kst‚| t tttktdk@ fƒƒtdkttk@ ks6t‚| t ttt ktdk @ fƒƒtdk tt k@ kslt‚| t ttt kttk @ fƒƒttk tt k@ ks¢t‚| t ttt ktdk@ fƒƒtdktt k@ ksØt‚| t ttt kttk@ fƒƒttktt k@ kst‚| t ttdkttk@ fƒƒtdkttk@ ks@t‚| t ttttƒƒdktttƒƒdk B fƒƒtttƒƒdktttƒƒdk B ks’t‚d S )Nc                 S   s   | j d jS rñ   )r­   rf   r²   rF   rF   rG   rH   	  rI   z%test_piecewise_eval.<locals>.<lambda>r\   r   r?   )r&   rM   r   r_   r   r   ru   rv   rF   rF   rG   Útest_piecewise_eval  sh    ÿÿÿÿÿ
ÿ
ÿ
ÿ
ÿ
ÿ
ÿ
ÿ
ÿ
ÿ
ÿ
ÿ
*ÿr<  c                  C   s\   t ddd} td|  | dkfd|  dfƒ}t|| ƒtt| ƒ | dkft| ƒdfƒksXt‚d S )NrM   Try   rB   r   r?   )r   r&   r1   r"   r_   r  rF   rF   rG   Útest_issue_225331  s    r=  c                   C   s>   t dtdkfdtdkfdtdkfƒt dtdkfdƒks:t‚d S )Nr?   rC   r\   rP   )r&   rM   r_   rF   rF   rF   rG   Útest_issue_240727  s    "ÿr>  c                  C   sÆ   t ddd} td| dk ftd|  ƒdfƒ}| | t¡dks>t‚| | d¡dksRt‚| | d¡dksft‚| | d¡dkszt‚| | d	¡dksŽt‚| | td
ƒ¡dks¦t‚| | td
dd¡dksÂt‚dS )z9 Issue 24127: Tests eval_is_meromorphic auxiliary method rM   Try   r?   r   NrB   FrC   ru   )r   r&   r%   Zis_meromorphicr   r_   r   r  rF   rF   rG   Ú#test_piecewise__eval_is_meromorphic<  s    r?  N)£Zsympy.concrete.summationsr   Zsympy.core.addr   Zsympy.core.basicr   Zsympy.core.containersr   Zsympy.core.exprr   Zsympy.core.functionr   r   r	   Zsympy.core.mulr
   Zsympy.core.modr   Zsympy.core.numbersr   r   r   r   r   r   Zsympy.core.relationalr   r   r   r   Zsympy.core.singletonr   Zsympy.core.symbolr   r   Z(sympy.functions.combinatorial.factorialsr   Z$sympy.functions.elementary.complexesr   r   r   r   r   r   r    Z&sympy.functions.elementary.exponentialr!   r"   Z(sympy.functions.elementary.miscellaneousr#   r$   r%   Z$sympy.functions.elementary.piecewiser&   r'   r(   r)   r*   Z(sympy.functions.elementary.trigonometricr+   r,   Z'sympy.functions.special.delta_functionsr-   r.   Z(sympy.functions.special.tensor_functionsr/   Zsympy.integrals.integralsr0   r1   Zsympy.logic.boolalgr2   r3   r4   r5   Z"sympy.matrices.expressions.matexprr6   Zsympy.printingr7   Zsympy.sets.containsr8   Zsympy.sets.setsr9   Zsympy.solvers.solversr:   Zsympy.testing.pytestr;   r<   Zsympy.utilities.lambdifyr=   ru   r‘   r   r   rM   ra   r>   rt   rw   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î   rï   rð   ró   rù   rû   rÿ   r   r  r  r  r	  r  r  r  r  r  r  r  r'  r(  r*  r.  r3  r5  r7  r8  r;  r<  r=  r>  r?  rF   rF   rF   rG   Ú<module>   sÌ    $ 
)
-
@WC

-J%#& L
	,