a
    <bL                     @   s   d Z ddlmZ ddlmZmZmZ ddlmZm	Z	m
Z
mZ e \ZZZZZZZdd Zdd Zd	d
 Zdd Zdd Zdd Zdd Zdd Zdd Zdd Zdd Zdd Zdd Zdd  Z d!d" Z!d#d$ Z"d%S )&zOTests for Euclidean algorithms, GCDs, LCMs and polynomial remainder sequences.     )ring)ZZQQRR)f_polysdmp_fateman_poly_F_1dmp_fateman_poly_F_2dmp_fateman_poly_F_3c            
      C   s  t dt\} }|d d|d   d|d   d|  d }|d |d  d|  d }tdd	 | tdd	 }tdd	|d  tdd	|  d }|d }| ||||fksJ | |||||fksJ |d d|d   | d }|d | d }| ||\}}}| ||\}}}	| | ||| |||ksDJ | | ||| |||	ksjJ d| }|d d
 }tdd| }tdd
 }d}| ||||fksJ | |||||fksJ d S )Nx                               )r   r   Zdup_half_gcdexZ	dup_gcdexZdup_addZdup_mul)
Rr
   fgsthSTH r   r/Users/vegardjervell/Documents/master/model/venv/lib/python3.9/site-packages/sympy/polys/tests/test_euclidtools.pytest_dup_gcdex   s:    ,$



r    c                  C   s<   t dt\} }| d| |d d tdd| ks8J d S )Nr
   r   r   r   r   )r   r   Z
dup_invertr   r
   r   r   r   test_dup_invert1   s    r"   c               	   C   s  t dt\} }|d |d  d|d   d|d   d|d   d|  d }d|d  d|d   d|d   d|  d	 }| ||||tdd |d  td
d|d   td
d tdd |d  d|  tdd tdd| tdd tdd gks
J d S )Nr
      r   r   r   r   r   	      r   u      i  i i=M  id i  iuLiif )r   r   Zdup_euclidean_prsr   r
   r   r   r   r   r   test_dup_euclidean_prs6   s    @0
.$
r)   c                  C   s   t dt\} }|d |d  d|d   d|d   d|d   d|  d }d|d  d|d   d|d   d|  d	 }| ||||d
|d  |d  d d|d  d|  d d| d dgksJ d S )Nr
   r#   r   r   r   r   r   r$   r%      r'   1   i7  i  r   )r   r   Zdup_primitive_prsr(   r   r   r   test_dup_primitive_prsE   s    @0

r-   c                  C   s  t dt\} }| dddks"J | dddks6J | dddksJJ |d |d  d|d   d|d   d|d   d|  d	 }d|d  d	|d   d|d   d
|  d }d|d  d|d   d
 }d|d  d|  d }d| d }d}| ||||||||gks J | ||| |ks<J |d d|  d }|d d }d| d }| |||||gksJ | ||dksJ |d d }|d d }d}| |||||gksJ | ||dksJ |d d }|d |d  d }| ||dksJ d|d  | }d	|d  d }| ||dksTJ |d d|  d }|d | d	 }| ||dksJ |d d|d   d|  d }|d d|d   d|  d }| ||dksJ |d d|d   d|  d }|d d|d   d|  d }| ||dks:J |d d }|d d|d   d|  d }| ||dks|J |d d }|d }| ||dksJ d S ) Nr
   r   r   r#   r   r   r   r   r   r$   r%   r   A   }      in$  i0  id @      i	     J   x   i@
         r   )r   r   dup_resultantZdup_subresultantsZdup_LC)r   r
   r   r   abcdr   r   r   test_dup_subresultantsT   sV    @0"     r@   c                  C   sx  t dt\} }}| dddks$J | ddd dks<J | dddksPJ | dddksdJ | dddksxJ | dddksJ | dddksJ | dddksJ | ddd dksJ | dddksJ | dddksJ d|d  | |d  d }|d ||d   d }d| |d  |d  d|  d }d	|d
  d|d   |d  d|d   d|d   d|d   d|  d }| |}| ||||||gksJ | |||ksJ | ||d |ksJ | |||ks
J | |||ks J |d  d }d|d  | |d  }d|d  d|  d }d|d  d|d   d|  d }| |}| |||||gksJ | |||ksJ | ||d |ksJ | |||ksJ | |||ksJ t dt\} }}}}	}
d|d  d| |  d| |  ||  }|d ||	  ||
  |	|
  }|d |d  d|d  | |	  d|d  | |
  d|d  |	 |
  d| |d  |	  d| |d  |
  d| | |	d   d| | |	 |
  d| | |
d   d| |	d  |
  d| |	 |
d   d|d  |	 |
  d| |	d  |
  d| |	 |
d   d|	d  |
d   }| ||||ksJ t dt	\} }}}}	}
|d t	dd| |  t	dd| |  t	dd| |  }|d ||	  ||
  |	|
  }t	dd|d  |d  t	dd|d  | |	  t	dd|d  | |
  t	dd|d  |	 |
  t	dd| |d  |	  t	dd| |d  |
  t	dd| | |	d   t	dd| | |	 |
  t	dd| | |
d   t	dd| |	d  |
  t	dd| |	 |
d   t	dd|d  |	 |
  t	dd| |	d  |
  t	dd| |	 |
d   |	d |
d   }| ||||ksJ t dt\}}t d|\}}|d d|d   d|d   d }d| |d  |d  d| |d   d|d   d
| |  d }|
||d |d  d!|d   d"|d   d# kstJ d S )$Nx,yr   r   r   r   r   r$      r7   r   r3   r   6   r#   i     r   r   -      i     r'   	x,y,z,u,v   $   r   r
   ir9   i , i! ib i  )r   r   Zdmp_resultantZdmp_prs_resultantZdmp_zz_collins_resultantZdmp_qq_collins_resultantZdmp_LCZdmp_subresultantsdropr   r;   )r   r
   yr   r   r<   r=   rzuvZRtr   ZRxr   r   r   test_dmp_subresultants   s    $P
$
, ^> f$DrR   c                  C   s  t dt\} }| ddks J | |dks2J | |d d|d   d|  d dks`J | d	|d	  |d  d d
ksJ | |d d|d   d|d   d|  d dksJ | d|d  d|d   d|d   |d  d dksJ d S )Nr
   r   r   r   r   r$   r+   pr   r   r      r   r3   r   rG    	BBu)r   r   Zdup_discriminantr!   r   r   r   test_dup_discriminant   s    .&:rW   c                  C   s  t dt\} }| ddks J t dt\} }}| ddksBJ | |dksTJ | |d d|d   d|  d dksJ | d	|d	  |d  d d
ksJ | |d d|d   d|d   d|  d dksJ | d|d  d|d   d|d   |d  d dks"J | |d | d|  d|d  |ksTJ | ||d  d|  dksxJ t dt\} }}}| || | dksJ t dt\} }}}}| |d | ||  | d| | |d  |ksJ t dt\} }}}}}| |d | |d |  ||  | d|d  |d  d| | | |  d| |d   d|d  |  |d |d   |ksJ d S )Nr
   r   rA   r   r   r$   r+   rS   r   rT   r   r   rU   r   r3   r   rG   r   rV   ix,y,zx,y,z,urI   irJ   )r   r   Zdmp_discriminantrL   )r   r
   rM   rO   rP   rQ   r   r   r   test_dmp_discriminant   s&    .&:@2$>(\r[   c                  C   s8	  t dt\} }d\}}| ||| ||  kr:dks@n J d\}}| ||| ||  krldksrn J d\}}| ||| ||  krdksn J d\}}| ||| ||  krd	ksn J d
d| d  }}| ||| ||  krd| d d
dfks$n J d| d d
 }}| ||| ||  krld| d dd
fksrn J d\}}| ||| ||  krdksn J d\}}| ||| ||  krdksn J d\}}| ||| ||  krdksn J d\}}| ||| ||  krDdksJn J |d d|  d d }}| ||| ||  krd|d d|  d dfksn J |d d|  d d }}| ||| ||  kr d|d d|  d dfksn J d|d  d|  d d }}| ||| ||  krbd|d d|  d dfkshn J dd|d  d|  d  }}| ||| ||  krdd|d d|  d fksn J d|d  d|  d |d  }}| ||| ||  kr&|d d| d dfks,n J |d d|d  d|  d  }}| ||| ||  kr|d dd| d fksn J |d | }}| ||| ||  krd||fksn J |d d|d   d|d   d|  d }|d d|d   d|  d }|d d|  d }|d d|  d }|d }| |||||fkshJ | |||||fksJ |d d }|d d|d   d }|d d }|d d }|d d }| |||||fksJ | |||||fksJ |d |d  d|d   d|d   d|d   d|  d }d|d  d|d   d|d   d|  d }d}|}|}| |||||fksJ | |||||fksJ t dt\} }|d |d  d|d   d|d   d|d   d|  d }d|d  d|d   d|d   d|  d }d}|}|}| |||||fks^J | |||||fkszJ t dt\} }d|d   d!|d"   d#|d$   d%|d&   d'|d   d(|d)   d*|d+   d, }d-|d  d.|d)   d/|d+   d, }| || |dd
 |ks*J | || |dd
 |ksLJ t dt\} }tdd|d  | tdd }tdd| tdd }|d }| ||||tddfksJ | ||||tddfksJ t dt\} }d0| d1 }d2| d3 }d2| d3 }d4}d}| |||||fk	s4J d S )5Nr
   r   r   r   r   r   r   r   r   r   r   r1   r   r   r:   r   r   r1   r   r   r:   r   r   r   r   r   r   r   r   r   r1   r   r   r:   r   r   r1   r   r   r:   r1   r1   r   r:   r:      r#   r   r%   rU   r   r4   r   r$   l     p>Z6-(3{ CzVgsR&r,   l       	` %'('@$@9$` V *   l      `%Nwgej^r0cu`ZhD #   l      ]%5u[ov&+/
c>_o],   l    @)-P/'X=vw+U9+; l    _I	,4~XsR`Y?t
U    l   y[p?u;ZW`( r3   l   EAy\^
l     mc@Atsl\o#MkE6w# l    @r/sLxFJGjAl   3sd%u%g%9 i[T l         qRvl        @	l        P\l        `i*  )r   r   Zdup_zz_heu_gcdZdup_rr_prs_gcdr   Zdup_qq_heu_gcdZdup_ff_prs_gcdZdup_diff)r   r
   r   r   r   cffcfgr   r   r   test_dup_gcd  s    ****<<....DDDD"@"@4, @0@0






	


"" ""rs   c               
   C   s
  t dt\} }}d\}}| ||| ||  kr<dksBn J d\}}| ||| ||  krndkstn J d\}}| ||| ||  krdksn J d\}}| ||| ||  krd	ksn J d
d| d  }}| ||| ||  kr d| d d
dfks&n J d| d d
 }}| ||| ||  krnd| d dd
fkstn J d\}}| ||| ||  krdksn J d\}}| ||| ||  krdksn J d\}}| ||| ||  krdksn J d\}}| ||| ||  krFdksLn J |d d|  d d }}| ||| ||  krd|d d|  d dfksn J |d d|  d d }}| ||| ||  krd|d d|  d dfksn J d|d  d|  d d }}| ||| ||  krdd|d d|  d dfksjn J dd|d  d|  d  }}| ||| ||  krdd|d d|  d fksn J d|d  d|  d |d  }}| ||| ||  kr(|d d| d dfks.n J |d d|d  d|  d  }}| ||| ||  kr|d dd| d fksn J t dt\} }}}}|d d|  d d| d  }}| ||| ||  kr|d |d dfksn J |d |d  d|d  |  |d  ||  | |d d|  d  }}|d |d | |d  | |d   }}}	| |||||	fksJ | |||||	fksJ | ||||	|fksJ | ||||	|fksJ t dt\} }}}t| jtdt\}}}| ||\}
}}	|
|krR| |
||krR| |
|	|ksVJ | ||\}
}}	|
|kr| |
||kr| |
|	|ksJ t dt\} }}}}}t| jtdt\}}}| ||\}
}}	|
|kr| |
||kr| |
|	|ksJ t dt\} }}}}}}}t| jtdt\}}}| ||\}
}}	|
|kr~| |
||kr~| |
|	|ksJ t dt\
} }}}}}}}}}t| jtdt\}}}| ||\}
}}	|
|kr| |
||kr| |
|	|ksJ t dt\} }}}t| jtdt\}}}| ||\}
}}	|
|krf| |
||krf| |
|	|ksjJ | ||\}
}}	|
|kr| |
||kr| |
|	|ksJ t| jt	dt\}}}| ||\}
}}	|
|k	r| |
||k	r| |
|	|k	s
J | ||\}
}}	|
|k	rJ| |
||k	rJ| |
|	|k	sNJ t dt\} }}}}}t| jt	dt\}}}| 
||\}
}}	|
|k	r| |
||k	r| |
|	|k	sJ t dt\} }}tdd|d  | tdd }tdd| tdd }|d }| ||||tddfk
s2J | ||||tddfk
sTJ t dt\} }}d| |d  d| |  d|  }d|d   }| ||d| d|d  d|  d d|d  fk
sJ d S )!NrA   r\   r]   r^   r_   r`   ra   rb   rc   r   r   r   r   rd   re   rf   rg   rh   ri   rj   rk   rY   rX   rI   zx,y,z,u,v,a,br   zx,y,z,u,v,a,b,c,dr#   g @g@g      ?r   )r   r   Zdmp_zz_heu_gcdZdmp_rr_prs_gcdmapZ
from_denser   Zdmp_mulr   r	   Zdmp_inner_gcdr   Zdmp_qq_heu_gcdZdmp_ff_prs_gcdr   )r   r
   rM   r   r   rO   rP   r   rq   rr   r   rQ   r<   r=   r>   r?   r   r   r   test_dmp_gcd  s    ****<<....DDDD"@"@"<J, ""$
(ru   c                  C   sZ  t dt\} }| dddks"J | d|d  d| d|d  ksJJ | d|d  d| d|d  ksrJ | |d | ||d | ksJ | |d | d| d|d  d|  ksJ | |d d|  ||d d|  ksJ | d|d  | |d|d  | ks J | d|d  | d| d|d  d|  ksVJ d S )Nr
   r   r   r   r   )r   r   Zdup_lcmr!   r   r   r   test_dup_lcm8  s    (($0,.rv   c                  C   s  t dt\} }}| dddks$J | |||| ks<J | d|d  d| |d  d|d  |d  kstJ | d|d  d| |d  d|d  |d  ksJ | |d | ||d  |d |d  ksJ d| |d  d| |d   d| |d   d| |d   }|d d|d   | }d| |d  d| |d   d| |d   d| |d   d| |d   d| |d   }| |||ksJ |d d|d  |  d| |d   d|d   }|d d|d  |  d	|d  |d   d
| |d   d|d   }|d |d |  d|d  |d   d|d  |d   d| |d   d|d   }| |||ksJ d S )NrA   r   r   r   r   r   r3   r$   r   r7   rJ   2   /   r   )r   r   Zdmp_lcm)r   r
   rM   r   r   r   r   r   r   test_dmp_lcmG  s    880@`4HXry   c            	      C   s   t dt\} }}| ddks"J d|d  d|  d dd  }}}tddD ]}||9 }||| | 7 }qP| |||ksJ t dt\} }}}| tdksJ | tdksJ t d	t\} }}}}| tdksJ d S )
NrA   r1   r   r   r   r   r   rX   x,y,z,t)r   r   Zdmp_contentrangerL   f_4f_5f_6)	r   r
   rM   r   r   FirO   r   r   r   r   test_dmp_content_  s    $r   c            
      C   s4  t dt\} }}| ddks"J | ddks4J d|d  d|  d dd  }}}tddD ]}||9 }||| | 7 }qb| ||||| fksJ t d	t\} }}}| t\}}|dkr|tksJ | t\}}|dkr|tksJ t d
t\} }}}}	| t\}}|dkr,|tks0J d S )NrA   r   r\   r   )r   r   r   r   r   rX   rz   )r   r   Zdmp_primitiver{   rL   r|   r}   r~   )
r   r
   rM   r   r   r   r   rO   contr   r   r   r   test_dmp_primitiveu  s     $ r   c            	      C   s  t dt\} }d|d  d }|d d|  d }d| d }|d }| ||||fks^J | j||dddd||fks~J | d }d| d }|d }d| d }| ||||fksJ | ||||fksJ | d	d	d
ksJ | jd	d	dddksJ | |d	dksJ | j|d	dddks6J | d	|dksLJ | jd	|dddksfJ d	}|}d}| j||dd||fksJ d S )Nr
   r   r   Fincluder   r   rC   r   r\   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   T)r   r   Z
dup_cancel)	r   r
   r   r   pqr   GZoner   r   r   test_dup_cancel  s.     
r   c                  C   s
  t dt\} }}d|d  d }|d d|  d }d| d }|d }| ||||fks`J | j||dddd||fksJ | dddksJ | jdddddksJ | |dd	ksJ | j|dddd
ksJ | d|dksJ | jd|dddksJ d S )NrA   r   r   Fr   r   r\   r   r   r   r   r   )r   r   Z
dmp_cancel)r   r
   rM   r   r   r   r   r   r   r   test_dmp_cancel  s     r   N)#__doc__Zsympy.polys.ringsr   Zsympy.polys.domainsr   r   r   Zsympy.polys.specialpolysr   r   r   r	   Zf_0Zf_1Zf_2Zf_3r|   r}   r~   r    r"   r)   r-   r@   rR   rW   r[   rs   ru   rv   ry   r   r   r   r   r   r   r   r   <module>   s,   #GN  %