o
    8VaQ                     @   s  d 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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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-m.Z.m/Z/m0Z0m1Z1m2Z2m3Z3m4Z4m5Z5m6Z6m7Z7m8Z8m9Z9m:Z:m;Z;m<Z<m=Z=m>Z>m?Z?m@Z@mAZAmBZB ddlCmDZD ddlEmFZF ddlGmHZHmIZImJZJ ddlKmLZL dd	 eF D \ZMZNZOZPZQZRZSeeeMd
eJeJddd
eJZTdd ZUdd ZVdd ZWdd ZXdd ZYdd ZZd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/d0 Zfd1d2 Zgd3d4 Zhd5d6 Zid7d8 Zjd9d: Zkd;d< Zld=d> Zmd?d@ ZndAdB ZodCdD ZpdEdF ZqdGdH ZrdIdJ ZsdKdL ZtdMdN ZudOdP ZvdQdR ZwdSdT ZxdUdV ZydWdX ZzdYdZ Z{d[d\ Z|d]d^ Z}d_d` Z~dadb Zdcdd Zdedf Zdgdh Zdidj Zdkdl Zdmdn ZdoS )pz4Tests for dense recursive polynomials' arithmetics.     )
dup_normal
dmp_normal)>dup_add_termdmp_add_termdup_sub_termdmp_sub_termdup_mul_termdmp_mul_termdup_add_grounddmp_add_grounddup_sub_grounddmp_sub_grounddup_mul_grounddmp_mul_grounddup_quo_grounddmp_quo_grounddup_exquo_grounddmp_exquo_ground
dup_lshift
dup_rshiftdup_absdmp_absdup_negdmp_negdup_adddmp_adddup_subdmp_subdup_muldmp_muldup_sqrdmp_sqrdup_powdmp_powdup_add_muldmp_add_muldup_sub_muldmp_sub_muldup_pdivdup_premdup_pquo
dup_pexquodmp_pdivdmp_premdmp_pquo
dmp_pexquo
dup_rr_div
dmp_rr_div
dup_ff_div
dmp_ff_divdup_divdup_remdup_quo	dup_exquodmp_divdmp_remdmp_quo	dmp_exquodup_max_normdmp_max_normdup_l1_normdmp_l1_norm
dup_expand
dmp_expand)ExactQuotientFailed)f_polys)FFZZQQ)raisesc                 C   s   g | ]}|  qS  )Zto_dense).0frH   rH   C/usr/lib/python3/dist-packages/sympy/polys/tests/test_densearith.py
<listcomp>.   s    rL            c                  C   s  t g t} t| tddtt g tksJ t| tddtt dgtks&J t| tddtt ddgtks8J t| tddtt g dtksJJ t g dt} t| tddtt g dtkscJ t| tddtt g dtksuJ t| tddtt g dtksJ t| tdd	tt g d
tksJ t| tddtt g dtksJ t| tddtt g dtksJ t| tddtt g dtksJ t| tddtt ddgtksJ d S )Nr   rN   rM   rN   r   r   rN   rN   rN   )rN   rN   rM   )rN   rM   rN   )rM   rN   rN      )rN   rN   rN   rN      )rN   r   rN   rN   rN      )rN   r   r   rN   rN   rN      )rN   r   r   r   rN   rN   rN   )r   rE   r   rJ   rH   rH   rK   test_dup_add_term1   $   
 "$$$$$$$$(rX   c                   C      t tdtdtdgtdddtttdtdtdgtddtks'J t tg gddttks4J t tg gddttksAJ d S NrN   rM   r   rR   )r   rE   r   f_0F_0rF   rH   rH   rH   rK   test_dmp_add_termI   
   $"r^   c                  C   s  t g t} t| tddtt g tksJ t| tddtt dgtks&J t| tddtt ddgtks8J t| tddtt g dtksJJ t g dt} t| tddtt g dtkscJ t| tddtt g dtksuJ t| tddtt g d	tksJ t| tdd
tt g dtksJ t| tddtt g dtksJ t| tddtt g dtksJ t| tddtt g dtksJ t| tddtt ddgtksJ d S )Nr   rN   rV   rM   )rV   r   r   rQ   )rN   rN   rV   )rN   rV   rN   )rV   rN   rN   rR   )rV   rN   rN   rN   rS   )rV   r   rN   rN   rN   rT   )rV   r   r   rN   rN   rN   rU   )rV   r   r   r   rN   rN   rN   )r   rE   r   rW   rH   rH   rK   test_dup_sub_termP   rY   r`   c                   C   rZ   r[   )r   rE   r   r\   r]   rF   rH   rH   rH   rK   test_dmp_sub_termh   r_   ra   c                  C   s   t g t} t| tddtt g tksJ t ddgt} t| tddtt g tks,J t g dt} t| tddtt g dtksEJ t| tddtt g dtksWJ t| tddtt g dtksiJ t| tddtt g d	tks{J d S )
NrM   rR   rN   r   rN   rM   rR   rM   rS   rU   )rM   rS   rU   r   )rM   rS   rU   r   r   )rM   rS   rU   r   r   r   )r   rE   r   rW   rH   rH   rK   test_dup_mul_termo   s   
  $$$(rd   c                   C   s  t tdtdtdgtdddtttdtdtdgtddtks'J t g gtdgddtg gks8J t tdggg ddtg gksIJ t tdtdgtdggtdgddttdtdgtdgg g gkspJ t g gtddgddtg gksJ t tddggg ddtg gksJ t tddtddgtddggtddgddttddtddgtddgg g gksJ d S )	NrN   rM   rR   r   rS   rU   rT      )r	   rE   r   rF   rH   rH   rH   rK   test_dmp_mul_term   s   $"""*$$2"rf   c                  C   8   t g d} t g d}t| t dt |ksJ d S )NrN   rM   rR   rS   )rN   rM   rR      rS   )rE   mapr
   rJ   grH   rH   rK   test_dup_add_ground      rm   c                  C   sR   t dgdgdgdgg} t dgdgdgdgg}t| t ddt |ks'J d S )NrN   rM   rR   rS   ri   )rE   rj   r   rk   rH   rH   rK   test_dmp_add_ground   s   ro   c                  C   rg   )Nrh   )rN   rM   rR   r   rS   )rE   rj   r   rk   rH   rH   rK   test_dup_sub_ground   rn   rp   c                  C   sP   t dgdgdgdgg} t dgdgdgg g}t| t ddt |ks&J d S )NrN   rM   rR   rS   )rE   rj   r   rk   rH   rH   rK   test_dmp_sub_ground   s   rq   c                  C   sz   t g t} t| tdtt g tksJ t g dt} t| tdtt g tks*J t| tdtt g dtks;J d S )NrM   rb   r   rc   )r   rE   r   rW   rH   rH   rK   test_dup_mul_ground   s
   
&rr   c                	   C   s  t ttddttdtdtdgtdggtdggtdtdtdgtdtdtdgtdgggks:J t ttdddttddtddtd	dgtddggtd	dggtddtd
dtddgtddtddtddgtddgggksJ d S )NrM   rS   rU   ri   
      rN      rR   rT   )r   r\   rE   r]   rF   rH   rH   rH   rK   test_dmp_mul_ground   s   
2
&*
rv   c                  C   s$  t tdd  tg t} t| tdttg tksJ tg dt} t| tdt| ks.J t| tdttg dtks?J t| tdttg dtksPJ tg dt} t| tdt| kscJ t| tdttdtdtd	gksxJ t| td
ttdd
tdd
tdd
gksJ d S )Nc                   S      t tg dttdtS Nrb   r   )r   r   rE   rH   rH   rH   rK   <lambda>   
   
 z%test_dup_quo_ground.<locals>.<lambda>rR   rU   rM   ri   rN   rM   rR   rN   rS   )rM   r   rM   rS   rO   rU   ri   )rG   ZeroDivisionErrorr   rE   r   rF   rW   rH   rH   rK   test_dup_quo_ground   s   
""*4r~   c                  C   s  t tdd  t tdd  tg t} t| tdttg tks"J tg dt} t| tdt| ks5J t| tdttg dtksFJ tg dt} t| tdt| ksYJ t| tdttdtdtd	gksnJ t| td
ttdd
tdd
tdd
gksJ d S )Nc                   S   rw   rx   r   r   rE   rH   rH   rH   rK   ry      rz   z'test_dup_exquo_ground.<locals>.<lambda>c                   S   rw   )Nrb   rR   r   rH   rH   rH   rK   ry      rz   rR   r{   rN   rM   r|   rS   rO   rU   ri   )rG   r}   rB   r   rE   r   rF   rW   rH   rH   rK   test_dup_exquo_ground   s   
"*4r   c                  C   s   t dgdgdggdt} t| tddt| ksJ t| tddtt dgdgdggdtks0J t t| tddtdtt dgg dggdtksJJ d S NrU   rM   ri   rN   rR   rS   )r   rE   r   rW   rH   rH   rK   test_dmp_quo_ground   s   r   c                  C   sd   t dgdgdggdt} t| tddt| ksJ t| tddtt dgdgdggdtks0J d S r   )r   rE   r   rW   rH   rH   rK   test_dmp_exquo_ground   s   r   c                   C   s2   t g dtg ks
J t dgdtg dksJ d S )NrR   rN   rN   r   r   r   )r   rE   rH   rH   rH   rK   test_dup_lshift     r   c                   C   s2   t g dtg ks
J t g ddtdgksJ d S )NrR   r   rN   )r   rE   rH   rH   rH   rK   test_dup_rshift  r   r   c                   C   s   t g tg ks	J t tdgttdgksJ t tdgttdgks'J t tdtdtdgttdtdtdgksBJ t g tg ksKJ t tddgttddgks\J t tddgttddgksmJ t tddtddtddgttddtddtddgksJ d S )NrN   rO   rV   rM   rR   )r   rE   rF   rH   rH   rH   rK   test_dup_abs  s   6""r   c                   C   s(  t tdgdttdgksJ t tddgdttddgks"J t g ggdtg ggks0J t tdgggdttdgggksDJ t tdgggdttdgggksXJ t g ggdtg ggksfJ t tddgggdttddgggks|J t tddgggdttddgggksJ d S NrV   r   rN   rM   r   rO   	   )r   rE   rF   rH   rH   rH   rK   test_dmp_abs      $((,0r   c                   C   s   t g tg ks	J t tdgttdgksJ t tdgttdgks'J t tdtdtdgttdtdtdgksBJ t g tg ksKJ t tddgttddgks\J t tdd	gttdd	gksmJ t tddtddtddgttddtddtddgksJ d S )
NrN   rV   r   rO   rM   rR   r   )r   rE   rF   rH   rH   rH   rK   test_dup_neg*  s    6""r   c                   C   s(  t tdgdttdgksJ t tddgdttddgks"J t g ggdtg ggks0J t tdgggdttdgggksDJ t tdgggdttdgggksXJ t g ggdtg ggksfJ t tddgggdttddgggks|J t tddgggdttddgggksJ d S r   )r   rE   rF   rH   rH   rH   rK   test_dmp_neg7  r   r   c                   C   s  t g g tg ks
J t tdgg ttdgksJ t g tdgttdgks*J t tdgtdgttdgks=J t tdgtdgttdgksPJ t tdtdgtdgttdtdgksiJ t tdgtdtdgttdtdgksJ t tdtdtdgtdtdtdgttdtdtdgksJ t g g tg ksJ t tddgg ttddgksJ t g tddgttddgksJ t tdd	gtdd	gttddgksJ t tdd	gtddgttdd	gksJ t tddtddgtdgttddtd
dgks J t tdgtddtddgttddtd
dgks>J t tddtddtddgtddtddtddgttddtddtddgksmJ d S )NrN   rM   rR   ri   r   rs         rS   rT   rO   )r   rE   rF   rH   rH   rH   rK   test_dup_addD  s@     &&22
$$,.<<r   c                   C   st  t tdtdgtdgdtttdtdgtdgtks!J t tddtddgtdgdtttddtddgtdgtksFJ t g ggg ggdtg ggksWJ t tdgggg ggdttdgggksnJ t g ggtdgggdttdgggksJ t tdgggtdgggdttdgggksJ t tdgggtdgggdttdgggksJ t g ggg ggdtg ggksJ t tddgggg ggdttddgggksJ t g ggtddgggdttddgggksJ t tddgggtddgggdttddgggksJ t tddgggtddgggdttddgggks8J d S )NrN   rM   r   rR   rO   )r   rE   r   rF   rH   rH   rH   rK   test_dmp_add^      " "..44"22<@r   c                   C   s  t g g tg ks
J t tdgg ttdgksJ t g tdgttdgks*J t tdgtdgtg ks:J t tdgtdgttdgksMJ t tdtdgtdgttdtdgksfJ t tdgtdtdgttdtdgksJ t tdtdtdgtdtdtdgttdtd	td
gksJ t g g tg ksJ t tddgg ttddgksJ t g tddgttddgksJ t tddgtddgtg ksJ t tddgtddgttddgksJ t tddtddgtdgttddtddgksJ t tdgtddtddgttddtddgks6J t tddtddtddgtddtddtddgttddtd	dtd
dgkseJ d S )NrN   rV   rM   rR   ri   r   rs   r   rO   rT   )r   rE   rF   rH   rH   rH   rK   test_dup_subq  s@      &22
$$$,<<r   c                   C   st  t tdtdgtdgdtttdtdgtdgtks!J t tddtddgtdgdtttddtddgtdgtksFJ t g ggg ggdtg ggksWJ t tdgggg ggdttdgggksnJ t g ggtdgggdttdgggksJ t tdgggtdgggdttdgggksJ t tdgggtdgggdttdgggksJ t g ggg ggdtg ggksJ t tddgggg ggdttddgggksJ t g ggtddgggdttddgggksJ t tddgggtddgggdttddgggksJ t tddgggtddgggdttddgggks8J d S )NrN   rM   r   rR   rV   rO   )r   rE   r   rF   rH   rH   rH   rK   test_dmp_sub  r   r   c                   C   s   t tdtdtdgtdtdtdgtdtdgttdtdtdtdgks/J ttdtdgtdggtdgtdtdggtdgtdggdttdgtdtdgtdtdggkskJ d S )NrN   rM   rR   r   rO   rT   rS   )r$   rE   r%   rH   rH   rH   rK   test_dup_add_mul     *2&r   c                   C   s   t tdtdtdgtdtdtdgtdtdgttdtdtdtdgks/J ttdtdgtdggtdgtdtdggtdgtdggdttdgtdtdgtdtdggkskJ d S )	NrN   rM   rR   r   r   rV   r   )r&   rE   r'   rH   rH   rH   rK   test_dup_sub_mul  r   r   c                  C   s~  t g g tg ks
J t g tdgtg ksJ t tdgg tg ks$J t tdgtdgttdgks7J t tdgtdgttdgksJJ t g g tg ksTJ t g tddgtg ksbJ t tddgg tg kspJ t tddgtddgttddgksJ t tddgtddgttdd	gksJ tg d
t} tg dt}tg dt}t | |t|ksJ t || t|ksJ tg dt} tg dt}t | | t|ksJ td}t |d|dg|d|dg||d|dgksJ tg dt}tg dt}tg dt}t ||t|ksJ tg dt}tg dt}tg dt}t ||t|ks=J d S )NrN   rT   rO   #   rM   rS   rR   re   1   )rR   r   r   rU   rN   rM   )rS   r   rN   r   )	rt   r   rR      rS   ru   rN   rM   r   rM   r   r   rN   rO   	rS   r   r   rS      r   rN   ru   r   rU   )O   rV   N   r       r   rM      I   *   U   M   S   r   _   %   r   r   C      L   rM   F   r   A   9   r   r   a   Y   !   r   Q   r   <   +      ,      r   r   r   rR   5      r   B   rN   r   b   r   rU   ri   r   rt      r      r   7   r   D   r   T   ^   -   r   \   r   r   r   ri   K   r   [   r   "   ru   r   r   r   r   rU   r      r   :   r      r   r   rO   r   r   r   r   r   r   r   rT   3   r   r  r   r   r   r   R   r   r   r   r   r   r  r   r   r
  ?   r   r   rU   r   r   rR   rR   .   r   >   X   r   r
  rV   r   H   ru   r  r  r   r   r   r   r   r   r   r   r   d   r   r   r   r   r  4   V   r   r   r  r   r   r  r   r   r	  (\  r   r   rN   Z   r   r   r      r   r   2   r   r      rN   r   r   r   J   P   r   r   r   )   r      r  r   r   E   r   r   r   ru   r   r   r   r   r   r   r   r  r   r  r   r   r   r   r  r   r
  r   r   r  r  r   r   r  rT   r   r   r   r
  r  r   r   r   r   0   r   r   r   r   rs   r   r   r   =   r   r  r   r*  r   r   r   rM   rU   r   r  r   r2  r   r   r4  rV   r.  `   r   r   r   8   r  r  r  r8  r"  r  r   r   r   r   r   r   r   r   r*  (   r   r   r   r  r   r   r  '   r  r   ru   W   @   r   r   r   re   r  r   r   r   r   6   r9  r   rU   r  r  r4  r   r?  r   r   r   r   r   r   r   r   r.  r   $   r   rT   r"  r
  r*  r  r!  r   ir   r   r   r   rS   r;  r@  r   r   r   r   r   r   r.  r  r   r   r  r  rB  r   r   r0  r   r   r   r+  r  r  r  r%  r   r  r   r   r   r   r  r  r  r   r   r;  r   &   r   rD  r  r   r   r?  r  r  r      r   r   r   r   r  r   r   rt   rt   r   r&  rB  r1  r  r%  r%  r   r  r   r  rB  r  r   r   r   r   r   r   r   rN   r   r   ri   ri   r7  r   r   r   r1  r   r   r
  r   r   r)  r)  rT   r   r   r  r<  r   rT   r   r@  r   r(  r  rB  r   r   r-  r   r   r&  r   r   r   r  r>  r   r  r   r  r  r   r   r  r   r   r   r   r   rF  r   r   r  r   r   r   r   rE  r   rt   r  r   r	  r   r   r   r  ri   r  r   r   r   (C  i  ii`  ii  i-  iA  iigiiY  ii_  iOi.  iin%  i0$  io  i[  i	J  i5'  i\ii*  ii?i  i*  iizi?  iDz  i`  i|  i  i  ii  i=  is  i  i|  i  ivki}i%  rH  iQi  i`iHii4  iw  i%  i3Uii,  ii  ii  iY  i}i|idi"li޷iiti\ioiiiNb  iiM  i2  iMiiKl  i#iiiiwN  i$iZi  iQ  i9i%}  5ig  ivF  i;if|  ii4ii0  ib  i&Mi^  i'iHi>iiTiߟir,  iuii'  ixiciL  iilg  iiU  i  ip  iXi  i  i0  i5i,  i iCi7  i  ibi/ i_  iYir  i  iM6  iiS  ii|d i  iY ii ii  iPi#i<  iii  i+  ii  i  iiii9i0|iiibiE  itiy  ii:  id  i ii iii  iwi% iW i  iiiiHxii*Fi[iiuUi+iieiy;  izi+  ii<i  i  i/8  iiihihsi  ii, iPi  i#  ibcii3  i*  iI6i&  i6/  iij ioiiѶiI  i?  i)  iii)  iii  iN  ii i߷  i  iϱ  ii<D  i!i1 iiwiix  isw i!  i]  ii}  i[  i  iiyai  io  i1zi'aidaimiVi  iiԔ i iiiIviJ
  i/  i iVK  ixii&i$c  iy`i"i4i  iOij  ii  i}i3  i4i\i i i  iri^ialiH
ii  ii i]  i.  iv  i  i  ii  i!ii  i^N iii
igi!  ivrI  iZ  i'  i  iZiini2 i~  i  iRiorili  iiia  i  iii71  i\ih  i  iiƺ  ii0  ii(ioifi  ii+i i3i" i+G  i8 ii_ iD  i%}ii  imi i9  i=Ri0*  ii2i  iYV  it  ii5  i  i  i.!  i$  ii>{  ii  i1iiK  iO  i'ii{i}i  i_ii	i;  i  iiI  ig  iI  iifiDii  i2  i!陏iE  iiiiii`  is  i* i  iJiiWii.i]  iiܧ  i  i(q  iizi"_  i\ih  i  iiSiiOQii/iii{  iY  iiii4  i"  iw iI  i  i i  i.  iM\iO  ii  (iDie  i  iat  iz  iIio  iF  iO  i$  iS  iƔiOii^iYii*  iiSif  i9  iy  ini&  iii3.  i*iiw i_  iiwii	OiA#  [ioui]+  iv-  iq  i  i\i$  io5  i  i6  ii?  i   iWisiziAi&  iw  io  i7O  iiiyiii^  iC  ie  i'ii9i<i$X  ii  i-  in  iiiiix}  iiK,  i{ii  i i%iWrL  iU  ild  i   i  ii  iQ  iN  iX  i-  i3  i	  ii7iEii8i  iiiirii  i	  i  ii|)r   r-  r   r.  rt   r   r   r   r   r   r<  r&  r   r   r   r   r   rS   r   rU   r   r   r   r   i/   r  r   r  r   r   r   r$  r*  r.  r=  r   r   r   r!  rV   r:  r   r   r   r   r   r  r*  r   r   r   r   r,  r  rt   r   r   ir   r   r6  r-  r"  rN   G   rS   rt   r1  rS   r   r   r   rT   r1  r  r  r   r   r   r   r   r1  r-  r   rN  r   r   r<  r   r  r   r  r   r   r  rF  r   r!  r  r  r8  r  r   r:  r7  r	  r0  r   r   r  r   r	  rF  r   r   r   r%  r   r   rR   rB  r1  r   r.  r   r   r   r   r   r,  r  r  ru   r0  r   r  r   r  r>  r  r   r   r  r   r  r   rt   r   ;   r   c   r   r   r   r  r   r   rN   r  r   r'  r   r   r   r   r   r=  r  r   r   rs   r   r9  rC  r+  r<  r   r   r  r   r  r   r   r   r6  r>  rP  r  r   r   r-  r   r   r   r-  rS   r   r   r7  r  r   r   r   r   r   ru   r  r   r   r0  r   r   r   r  r  r   r8  r   rR   r9  r   r   r  r   r   r   r(  r;  r  r   r   r  r  r6  r   r   r1  r   r1  r   r   r   (+  r  r  r   r   r   r  r  r   r   r,  r   r8  rE  r   r   r   r   r   r   r  r   r   r"  r   r&  r   r  rS   rN  r   r   r   rP  r&  r  rQ  r  r,  r=  r   r  r   r=  rP  r   r0  r   r   r;  r   rS   r   r  r   r   r6  r   rR      r8  rA  r   r   r   rU   r   r   r:  r   r  r@  r   rP  r   r   r?  r   rB  r)  r   r"  r   r   r   r   r   r   r   r   rO  r   r  r5  r8  r  ri   rV   r8  r   r   r   r   rB  rO  r   r   r   r  rQ  r  rC  rT   r?  r   r0  r2  r   r   r  r   r  r  r<  r   r   rN   r   rG  r  r   r   rR   rt   r  r   r  r/  r   r   r   r   r   r   rT   r   r   ]   r   r   r"  r&  r   rU  rQ  r  r   r  r   r   r   r7  r   r   r   rU  r   r   r   rS  r   r   r  r   r   rD  r)  r   r  r   r"  r   r   rN  r   r  r   r  r   r  r  r   r   r   r   rU   r   r   r   re   r   rU  r   r  r
  r  r"  r   r!  rP  r=  r   r   rS  r   r   r/  r3  r4  r#  r   rT   r   rR  r   r   r  r   r   r   r   r   r  rE  r   r  r  r%  rN   r   r   r	  r   r1  r!  r  r   r   rA  rE  r   r7  r   r   r%  r   r"  r   r   r   r  r4  r  rR   r   r   rM   r2  r   r   r   r   r   r   r   r  r   rS   r  r   r!  r  r  rF  r   r%  rP  r   rQ  r  r   rT  r/  r   r   r   rB  rG  r   r   (  i  i$  i4iiiil  iii6  iA  i?,  idiiC  i+R  iii>  i  iis"  iD  i'  i  ii!  ii  ic  i5&  i/     i=I  iiik  i;ii1  i  ii/L  ii  ivi  i$\  iƐiu  i  ii[.i?iir  i  iV  iii8  iwii<  i  iS;  i:iiibi  i\  iViiA  ibI  i/  i^`  iy  i  ikii  ivii)Q  iL  iP  iڃ  iiUi}  i  iяi0ii5  i|-  iD  i(i\  ii  iQ  i  ii  iix`i`M  iHiZ  i  iqb  iG$  il  ii%  i6i3  i<  i  i_N  i  i-  ij  ivimi6  iʀ  i2ik  ios  iv igiXli(i   i  iˎi(i  iPiSi  iŒ  iii{iiU|igiizD  i  i
  iU$ib  iiiMiC ii\Ri i9  iia(  iN  iuiS)i  i  i8H  ir  i%  iid  i0 iii  i	  i5iiA iei  i  i  i0iʷ  i	f  i![i4 ii	  iipq  i]iHix[  ii?Si@YiiM  i  iw=  i,  i ifiJ  i9  i  ii@  ih i  i  i i  i iiiFiwi'  in i"  iG  iJ  iBr  iR!  i  ii<iiiT  i   izsi5 iii{  iiii**  iia  i  i6i wiy it  iM  i+ioiWiDid ihijisii.  iv  iS\i/]iNz  iNm  iH  i@  iJ  i(iۂ  iu  ii]  iz  ii\  i=i&iieiirM  i%i9iyw  i!  iJ  iiY iH   i-ci_i i
2  ii ii  i\i i^  i: i4  i&  i  i@i  iiiS i.i  iJo  i= iT  i i
  ivi  ip  ibi=  i6  i/  iPi9  iw  i;@iiGq  i  i  iiii)  imGi,  i*  iiiW  ii&  isiaiiu  i  i  i;  i iT  i
iS3 iUi5  i,  i6i.i-ii  iXi~iii  i1i8  ikin  iWdi{rK  i|D i:iǙifIi1  i  isiqiu  i2i  iX  iӉi3iVii  i9ig7  ii-i  i7i  ii i.  i  i`  i  i  i  iR  iii§i{  im i^  iiiiH  iYF  ii1  iiisO  i  ii.iiG  i=  i  i;  iLb  iHip(  iqi  iT  ii)i i}iiˁ  i  iR  i,i^h  iݯi)  i  r  i^  iuiii  i  iABicC  i>in  iii  iim  iib  iii  ii[n  iitiiѝiI  iiyi5iC  iio~ip  iiiDB  i	i[i"7  i7ii  ii-i  iD  iPrJ  iL&  iiu
  io  iii\  ii  i0  i4"  itiwii  iR  iiO  iii	  i{.  i  i
iX  iQ   is+  i\i  iniv/  iti  is  iJi	  i)r   rE   rF   r   rD   )rJ   rl   hKZp1Zp2resrH   rH   rK   test_dup_mul  sP   &&,,8=?8:r[  c                  C   s  t tdgtdgdtttdgtdgtksJ t tddgtddgdtttddgtddgtks:J t g ggg ggdtg ggksKJ t tdgggg ggdtg ggks_J t g ggtdgggdtg ggkssJ t tdgggtdgggdttdgggksJ t tdgggtdgggdttdgggksJ t g ggg ggdtg ggksJ t tddgggg ggdtg ggksJ t g ggtddgggdtg ggksJ t tddgggtddgggdttddgggksJ t tddgggtddgggdttddgggksJ td} t | dg| dgg| dg| d	ggd| | dg| d	ggksEJ d S )
NrT   rO   r   rR   rM   rN   r   rU   rS   )r   rE   r   rF   rD   rY  rH   rH   rK   test_dmp_mul  s,   "((44"**:<(r]  c                  C   s.  t g tg ks	J t tdgttdgksJ t tdtdgttdtdtdgks0J t g tg ks9J t tddgttddgksJJ t tddtddgttddtddtddgksgJ tg dt} t | ttg dtks|J td}t |d|dg||d|d	gksJ d S )
NrM   rS   rN   rR   r   r   r   rU   rO   )r    rE   rF   r   rD   )rJ   rY  rH   rH   rK   test_dup_sqr  s   0":.r^  c                  C   s   t tdtdgdtttdtdgtksJ t g ggdtg ggks'J t tdgggdttdgggks;J t g ggdtg ggksIJ t tddgggdttddgggks_J td} t | dg| dggd| | dg| dggks}J d S )	NrN   rM   r   rS   rR   r   rU   rO   )r!   rE   r    rF   rD   r\  rH   rH   rK   test_dmp_sqr  s   (,8r_  c                  C   s  t g dttdgksJ t g dttdgksJ t g dtg ks$J t g dtg ks.J t tdgdttdgks>J t tdgdttdgksNJ t tdgdttdgks^J t tdgdttdgksnJ t tdgdttdgks~J t tdgdttdgksJ t tddgdttddgksJ t tddgdttddgksJ t tddgdttddgksJ t tddgdttddgksJ t tddgdttddgksJ t tddgdttddgksJ tg dt} t | dttdgtksJ t | dttg dtks J t | dttg d	tks0J t | dttg d
tks@J d S )Nr   rN   rO   rR      r   rM   r   )ri   r   r   rt   r   r   rU   r   i&  rN   r      iW  )r"   rE   rF   r   rW   rH   rH   rK   test_dup_pow  s.         $$$$$$  rc  c                  C   s  t g gddttdggksJ t g gddttdggks J t g gddtg gks-J t g gddtg gks:J t tdggddttdggksMJ t tdggddttdggks`J t tdggddttdggkssJ t tddggddttddggksJ t tddggddttddggksJ t tddggddttddggksJ tg dt} t | ddtt| dtksJ d S )	Nr   rN   rO   rR   r`  ra  r   rM   )r#   rE   rF   r   r"   rW   rH   rH   rK   test_dmp_pow  s     &&&***"rd  c                     s  t g dt t g dtt ddgt} t ddgt}t t| |fks(J t t| ks2J t t|ks<J tt fdd t g dt t g dtt ddgt} t ddgt}t t| |fksnJ t t| ksxJ t t|ksJ tt fd	d d S )
NrR   rN   rN   rT   rT   r   rN   re   ru   r  o   c                         t  tS N)r+   rE   rH   rk   rH   rK   ry         ztest_dup_pdiv.<locals>.<lambda>c                      rh  ri  )r+   rF   rH   rk   rH   rK   ry     rj  )r   rE   r(   r*   r)   rG   rB   rF   qrrH   rk   rK   test_dup_pdiv  s    rn  c                     sd  t dgg g dgdt t dgddggdtt dgddggdt} t g dgdt}t dt| |fks8J t dt| ksCJ t dt|ksNJ tt fdd t dgg g dgdt t dgd	dggdtt dgddggdt} t g d
gdt}t dt| |fksJ t dt| ksJ t dt|ksJ tt fdd d S )NrN   rP   rV   r   rM   r   r   c                         t  dtS NrN   r/   rE   rH   rk   rH   rK   ry   !      ztest_dmp_pdiv.<locals>.<lambda>rM   r   )ri   r   r   c                      rp  rq  rr  rH   rk   rH   rK   ry   -  rs  )r   rE   r,   r.   r-   rG   rB   rk  rH   rk   rK   test_dmp_pdiv  s    rt  c                  C   sP   t tdd  tg dt} tg dt}g | }}t| |t||fks&J d S )Nc                   S      t g dg tS Nrb   )r0   rE   rH   rH   rH   rK   ry   1      z!test_dup_rr_div.<locals>.<lambda>re  rf  )rG   r}   r   rE   r0   rJ   rl   rl  rm  rH   rH   rK   test_dup_rr_div0  s
   
ry  c                  C   sF  t tdd  tdgg g dgdt} tdgddggdt}tdgddggdt}tg dgdt}t| |dt||fks?J tdgg g dgdt} tdgddggdt}tdgddggdt}tg dgdt}t| |dt||fkswJ tdgg g dgdt} tdgd	dggdt}g g| }}t| |dt||fksJ d S )
Nc                   S      t ddgdggg gdtS NrN   rM   rR   )r1   rE   rH   rH   rH   rK   ry   <      z!test_dmp_rr_div.<locals>.<lambda>rN   rP   rV   r   ro  rM   r   )rG   r}   r   rE   r1   rx  rH   rH   rK   test_dmp_rr_div;  s   r}  c                  C   sn   t tdd  tg dt} tg dt}tddtddg}td	dtd
dg}t| |t||fks5J d S )Nc                   S   ru  rv  )r2   rF   rH   rH   rH   rK   ry   W  rw  z!test_dup_ff_div.<locals>.<lambda>re  rf  rR   rT   ru   r"  r  rg  )rG   r}   r   rF   r2   rx  rH   rH   rK   test_dup_ff_divV  s   r~  c                  C   s   zddl m}  W n
 ty   Y d S w ddlm} | }| dd| ddg}| ddg}t||d|| dd| ddgg fksAJ | dd| dd| dd| dd	g}| d
d| dd| d
dg}t||d|| d
d| ddg| dd| ddgfks~J d S )Nr   )mpq)GMPYRationalFieldrN   rR   rM   rU   rS   rT   rV   r   rO   rt   r   r   )Zgmpy2r  ImportErrorsympy.polys.domainsr  r3   )r  r  rY  rJ   rl   rH   rH   rK   test_dup_ff_div_gmpy2a  s   *$>r  c                  C   s  t tdd  tdgg g dgdt} tdgddggdt}tddgtddtddgg}tddtddtddgg}t| |dt||fksJJ tdgg g dgdt} tdgddggdt}tddgtddtddgg}tddtddtddgg}t| |dt||fksJ tdgg g dgdt} tdgddggdt}tddgtddtddgg}tddtddtddgg}t| |dt||fksJ d S )	Nc                   S   rz  r{  )r3   rF   rH   rH   rH   rK   ry   s  r|  z!test_dmp_ff_div.<locals>.<lambda>rN   rP   rV   r   rM   r   )rG   r}   r   rF   r3   rx  rH   rH   rK   test_dmp_ff_divr  s       r  c                     s   g dg dg dddgf\ } }t  t| |fksJ t t| ks(J t t|ks2J tt fdd g dg d	d
dgg df\ } }t  t| |fksZJ t t| ksdJ t t|ksnJ tt fdd d S )NrT   rS   rR   rM   rN   rb   rT   r  r   r  rN   c                      rh  ri  r7   rE   rH   rk   rH   rK   ry     rj  ztest_dup_div.<locals>.<lambda>)rT   rS   rR   rM   rN   r   )rN   rM   r   r   r   rT   r  )re   rM   r   rA  c                      rh  ri  r  rH   rk   rH   rK   ry     rj  )r4   rE   r6   r5   rG   rB   rk  rH   rk   rK   test_dup_div  s   $$r  c                     s
  g dg dg dddgf\ } }t  dt| |fksJ t dt| ks*J t dt|ks5J tt fdd dgggd	ggdggg ggdgggf\ } }t  d	t| |fkscJ t d	t| ksnJ t d	t|ksyJ tt fd
d d S )Nr  rb   r  r  rN   r   c                      rp  )Nr   r;   rE   rH   rk   rH   rK   ry     rs  ztest_dmp_div.<locals>.<lambda>rM   c                      rp  )NrM   r  rH   rk   rH   rK   ry     rs  )r8   rE   r:   r9   rG   rB   rk  rH   rk   rK   test_dmp_div  s   $.r  c                   C   @   t g tdks	J t dgtdksJ t g dtdksJ d S )Nr   rN   rN   rS   rM   rR   rS   )r<   rE   rH   rH   rH   rK   test_dup_max_norm  s   r  c                   C   J   t g ggdtdksJ t dgggdtdksJ t tdtdks#J d S )NrM   r   rN   rU   )r=   rE   r\   rH   rH   rH   rK   test_dmp_max_norm     r  c                   C   r  )Nr   rN   r  rs   )r>   rE   rH   rH   rH   rK   test_dup_l1_norm  s   r  c                   C   r  )NrM   r   rN   r%  )r?   rE   r\   rH   rH   rH   rK   test_dmp_l1_norm  r  r  c                   C   sX   t dtdgks
J t g dddgg dfttg dtddgg dttks*J d S )NrH   rN   rb   rM   )rO   rT   rS   rR   )r@   rE   r   rH   rH   rH   rK   test_dup_expand  s   r  c                	   C   s   t ddtdggksJ t dgdgdggdgdggdgdgdgdggfdttdgdgdggtdgdggdgdgdgdggdtdtksGJ d S )NrH   rN   rM   rR   rO   rT   rS   )rA   rE   r   rH   rH   rH   rK   test_dmp_expand  s   4$r  N)__doc__Zsympy.polys.densebasicr   r   Zsympy.polys.densearithr   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/   r0   r1   r2   r3   r4   r5   r6   r7   r8   r9   r:   r;   r<   r=   r>   r?   r@   rA   Zsympy.polys.polyerrorsrB   Zsympy.polys.specialpolysrC   r  rD   rE   rF   Zsympy.testing.pytestrG   r\   Zf_1Zf_2Zf_3Zf_4Zf_5Zf_6r]   rX   r^   r`   ra   rd   rf   rm   ro   rp   rq   rr   rv   r~   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r[  r]  r^  r_  rc  rd  rn  rt  ry  r}  r~  r  r  r  r  r  r  r  r  r  r  rH   rH   rH   rK   <module>   sx      d 