o
    8Vab                  
   @   s  d 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 ddlmZmZmZmZmZ ddlmZmZmZm Z m!Z!m"Z"m#Z#m$Z$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/m0Z0 dd
l1m2Z2 ddl3Z3ed\
Z4Z5Z6Z7Z8Z9Z:Z;Z<Z=dd Z>dd Z?dd Z@dd ZAdd ZBdd ZCdd ZDdd ZEdd ZFdd  ZGd!d" ZHd#d$ ZId%d& ZJd'd( ZKd)d* ZLd+d, ZMd-d. ZNd/d0 ZOd1d2 ZPd3d4 ZQd5d6 ZRd7d8 ZSd9d: ZTd;d< ZUe0d=d> ZVd?d@ ZWdAdB ZXdCdD ZYdS )EzBTests for algorithms for computing symbolic roots of polynomials.     )SsymbolsSymbolWildRationalsqrtpowsimpsincospiIIntervalreimexpZZ	Piecewiseacosroot	conjugate)Polycyclotomic_poly	intervalsnrootsrootof)	root_factorsroots_linearroots_quadraticroots_cubicroots_quarticroots_cyclotomicroots_binomialpreprocess_rootsroots)legendre_poly)PolynomialError)_nsort)cartes)raisesslow)verify_numericallyNza,b,c,d,e,q,t,x,y,zc                 C   s   t dd | D }tt| d | t| d | ksJ t|t| dD ]}| |d  | | ks@| |d  t| | ks@ dS q%dS )Nc                 S   s   g | ]	}|j r	d ndqS )   r   is_real.0i r1   B/usr/lib/python3/dist-packages/sympy/polys/tests/test_polyroots.py
<listcomp>   s    z_check.<locals>.<listcomp>   r+   FT)sumlistsortedrangelenr   )r#   ZnrealZixr1   r1   r2   _check   s   (r:   c                   C   s*   t tdt d ttddgksJ d S )Nr4   r+   )r   r   xr   r1   r1   r1   r2   test_roots_linear(   s   *r=   c                  C   s  t tdtd  tddgksJ t tdtd  dt  ttdddgks)J t tdtd  d tt td d ttd d gksIJ t tdtd  dt  d tdttd d  dttd d  gkspJ ttdtd  dt  d t  td dt t	 dt
 t	  tt
  t  tt tt	d   t
t	d   tt
   } t t| tt	 tt
  tt
  ttt t
t  tt  tt
  dt t
 t	d   tt
   t	 tt
  tt
  ttt t
t  tt  tt
  dt t
 t	d   tt
   gksJ tttd  dt  dt  t} t | tdtd  d  t dt  tdtd  d t dt  gksFJ ttd td  d t  td  d t} t | dtd d gkskJ ttdtd  d t} t | }|t|ksJ td	td  d
t  d } dd | jddD dd | jddD ksJ tdddD ]!\}}}t|td  |t  | } t | }|t|ksJ qd S )Nr4   r            r;   r+   i   i  c                 S      g | ]}| d qS r4   nr/   wr1   r1   r2   r3   F       z(test_roots_quadratic.<locals>.<listcomp>T)Zradicalsc                 S   rC   rD   rE   rG   r1   r1   r2   r3   G   rI   F)r4   )r   r;   )r   r   r<   r   r   r   r:   	all_rootsaecdbyr&   r'   )frZ_aZ_bZ_cr#   r1   r1   r2   test_roots_quadratic,   s>   "0@N&TTT
"@
,

rT   c                  C   s   t td t td  t t} t| ttd tdt d  dttd t d td  dttd tdt d   dttd t d td   diksSJ d S )NrA   r4      r+   )r   r<   r   r#   r   eqr1   r1   r2   test_issue_7724N   s    rX   c                     s   t dtddgt  tt  tt} tddttdd  fdd| D }t|ttt  ttks;J t	 fdd	|D sIJ d S )
Nr+   rJ   r?   r4      c                    s   g | ]}| t qS r1   )subsrQ   r/   rS   )zr1   r2   r3   [   s    z#test_issue_8438.<locals>.<listcomp>c                 3   s0    | ]}  tt|ijd dddkV  qdS )r4   TZchopr   N)rZ   rQ   r<   rF   r.   pr\   r1   r2   	<genexpr>_   s   . z"test_issue_8438.<locals>.<genexpr>)
r   rQ   r<   Zas_exprr   r   r   setrZ   all)r#   Zpostr1   r^   r2   test_issue_8438W   s    rc   c                     s   t dtd  d tt td d   } t| sJ t td dtd   d t  fddtdD }t td dtd   d t } | |ksLJ t| sRJ t dtd  d  } t| sdJ tt dtd	  d  d	ksvJ d S )
NrA      r+   r4   rU   r@   c                       g | ]}t  |qS r1   r   r.   rR   r1   r2   r3   f   rI   z#test_issue_8285.<locals>.<listcomp>
   )r   r<   rK   r:   r8   r9   )r#   ror1   rg   r2   test_issue_8285b   s   *"(rj   c                  C   s   t td d t td d   } t| sJ t td dtd   d t } t| s/J t td t d  } t| sAJ t td dtd   d t } t| sXJ d S )Nr4   rA   r@   r>   r+   )r   r<   rK   r:   r#   r1   r1   r2   test_issue_8289q   s   $""rl   c                     s   t td d d td d d  td   ddt dt dtdt  dtdt  gks1J td dtd   d   fddtdD } t   | ksRJ t|  d S )Nr+   r4   rA   rh   c                    re   r1   rf   r.   r_   r1   r2   r3      rI   z$test_issue_14291.<locals>.<listcomp>)r   r<   rK   r   r   r8   r:   )ansr1   rm   r2   test_issue_14291}   s   *0ro   c                  C   s>   t td ttt  t tdd} t| }t|dksJ d S )Nr>   EXdomain)r   rQ   r   r<   r#   r9   )rW   Zroots_dr1   r1   r2   test_issue_13340   s   "rs   c                     sx   t td td ddt    td ddt    tdd	t    d
 dt  t t } t fdd| D s:J d S )NrA   r>          r4   ii  ii  i
  i  c                 3   s    | ]	} |d kV  qdS r   Nr1   r[   rV   r1   r2   r`          z#test_issue_14522.<locals>.<genexpr>)r   r<   r   r#   rb   )roots_eqr1   rV   r2   test_issue_14522   s   Rry   c                  C   s@   t ttd dtd   tt  d t} | d tsJ d S )NrA   r@   r4   r>   r   )r   r   tr<   Zhas)solr1   r1   r2   test_issue_15076   s   *r|   c                  C   sb   t td dtd td   dtd   dtd td   dt  t} t| }d|v s/J d S )NrA   rd   r4   r>   @   i   r   )r   r<   r   r#   )rW   rx   r1   r1   r2   test_issue_16589   s   Jr~   c               	   C   sl  t tdtd  tg dksJ t ttd dtd   dt  d tg dks,J ttd} t ttd t t| | tj tdt d   | tj tdt d   gks[J t ttd d tdtjttd d  tjttd d  gksJ t tdtd  dtd   dt  d td tjdt	dd d  dt	dd d  ksJ td  dtd   dt  d }t
|ddd	t t|tdd
  kr1t	dddtd ttdtd d d  d  dtd ttdtd d  d td   d t	dd dtd ttdtd d  d td   d t	dd gks4J  J d S )Nr4   r>   )r   r   r   r+   r+   r+   r+   r;   r   T)trigmultiple)r      rd      rJ   r@   )r   r   r<   r   rQ   r   Halfr   r   r   r#   r
   r   r	   r   )rS   rW   r1   r1   r2   test_roots_cubic   s,   "6

,0("
4>>r   c                     sb  t ttd tg dksJ t ttd td  tg dg dg dg dfv s,J t ttd td  tg dg d	g d
g dfv sIJ t ttd t t} tjttd d  tjttd d  tjtj g}t	| t
dt	|t
dks}J tg dD ]e\}\}}}}|dkr| |d td |td   }n|dkr|||d tdd |td   |td   }td |td   |td   |t  |  t t t}t fdd|D sJ qttt td  td  td  dtd   tdd t t  }t fdd|D sJ tdddtd dtd   dtd   td   d  t t t}	t fdd|	D sMJ tttd  td  t  t t  }tdd |D snJ ttddtdddttddtdddttddd df}
|
D ]t t t}tfd!dt||D sJ qd S )"NrA   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+   r4   key))r+   r4   r>   r   )r>   i	   r+   r4   r>   rA   r   )r   r?   r>   )r?   rU   r   )r@   ir?   rd      rt   c                 3   s(    | ]}  t|jd ddkV  qdS )Tr]   r   N)rZ   r<   rF   )r/   ZairV   r1   r2   r`      s   & z%test_roots_quartic.<locals>.<genexpr>r+   c                 3   s"    | ]}t  t|d V  qdS rv   r*   rZ   r<   r.   rV   r1   r2   r`      s     r\   T)negative   rU   c                    s(   g | ]}t  t|fd ffdqS )r;   r   r   r.   )rW   r\   r1   r2   r3      s   ( z&test_roots_quartic.<locals>.<listcomp>c                 s   s    | ]	}t |tkV  qd S N)typer   r.   r1   r1   r2   r`      rw   r;   )rQ   r\   rJ   c                    s$   g | ]\}}t | | d qS )r   )r*   rZ   )r/   rH   s)repr1   r2   r3      s   $ )r   r   r<   r   r   r   r   ZeroOner7   hash	enumerater   rb   qr   rQ   dictrZ   zip)ZlhsZrhsr0   rL   rP   rN   rO   rn   r{   ZzansZrepsr1   )rW   r   r\   r2   test_roots_quartic   sT   

6$2,<0"&r   c                	   C   sX   t dd tttd td ddt    dt dt   d dt  tD r*J d S )	Nc                 s   s    | ]}t |tV  qd S r   )
isinstancer   r.   r1   r1   r2   r`      s    z#test_issue_21287.<locals>.<genexpr>rA   r4   r>   rU   r;   r+   )anyr   r   r<   r   r1   r1   r1   r2   test_issue_21287   s   
<r   c                   C   s  t tdtdddgksJ t tdtdddgksJ t tdtddtddttd d  tddttd d  gksAJ t tdtddt tgksQJ t tdtddtjttd d  tjttd d  gksrJ t td	tddtt	d	  tt
t	d	   tt	d	  tt
t	d	   tt	tdd	  tt
t	tdd	   tt	tdd	  tt
t	tdd	   tt	tdd	 tt
t	tdd	   tt	tdd	 tt
t	tdd	   gksJ t td
tddtd d ttd d  td d ttd d  tdd ttd d  tdd ttd d  gks-J t tdtddtd d td  td d td  tdd td  tdd td  gksaJ t tdtdddddgksrJ t tdtdddddgksJ t tdtddddtdd dtdd gksJ t tdtddddt tgksJ t tdtddddtdd tddd  tddd dtddd  tdd tddd  gksJ t tdtdddddtdd tddgksJ d S )Nr+   TZpolysr4   r;   r>   rA   r@   rY   rd      )ZfactorrU   )r    r   r<   r   r   r   r   r   r
   r   r	   r   r1   r1   r1   r2   test_roots_cyclotomic   sn   2 *((&&
	



N
r   c               	   C   s:  t tdt tdgksJ t tdtd  tg dksJ t tdt d ttddgks2J dtdd d } t tdtd  d t|  | t  |  | t  | | t  | | t  gksbJ tt ttd	 d  td
dd}tddd}tt|td  | t}t t|td  | t}t|d t|d ksJ t|d t|d ksJ t	ddddD ]'\}}}}||kr|dkrqt|t|  ||  }	t |	}
|
t
|
ksJ qttdtd  dtd   tdt tddtdt d   ddt ddt tddtdt d   diksJ d S )NrU   r   rA   r   r4   rJ   rh   r>   rd   a1T)Znonnegativeb1r+   )r+   r4   )r;   r+   )r4   r>   rA   rU   rt   r;   )r!   r   r<   r   r   r:   r   r   r   r'   r&   r#   rQ   r   )Ar   r   Zr0r1rL   rP   r   rF   r_   rn   r1   r1   r2   test_roots_binomial#  s2   "&. ""r   c                  C   s`  t t td  t t } tt| t\}}|dksJ |tt t td  t t tks.J td td  td td   tt  t  } tt| t\}}|dt ksUJ |ttd td  t t  tkshJ td td  td td   t  } tt| t\}}|dt ksJ |ttd td  t  tksJ td td  tt  t  } tt| t\}}|dt ksJ |ttd t t  tksJ td td  t  } tt| t\}}|dt ksJ |ttd t  tksJ td\}}}}d|d  |d  |d  d| t |d	  |d	  |d
   d|d  |d  |d  td  |d   d|d  |d  |d  td  |d   d|d  |d  |d  td  |d   d|d  |d  |d  td  |d   d|d  |d  |d  td  d|d    d| | |d	  td	  d|d    d|d  td  d  } tt| t\}}|d| | ||d   ksJ |dtd  dtd	   dtd   dtd   dtd   dtd   dtd   dt  d  ksJ ttd  td tt  tt	tttf d!} ttd  tt tt	tt d!}t| t|fks.J d S )"Nr4   r+   r>   E,F,J,L [r|)s2^ rd   rt       83ll8rY         ]$=,y r@   r      /@:rU   rh      D!^ rA   q 
    P   y   q    id i B i߰l   ul   /1g&l   g l   FW&k rq   )
rL   rQ   r<   rP   r"   r   rN   r   r   r   )rR   ZcoeffZpolyEFJLgr1   r1   r2   test_roots_preprocessingD  sh   &,&$""****.&
"<

0$r   c                  C   s
  t dti ks	J t tttjdiksJ t td ttjdiks#J t td td  td   ttd dtddtddiksEJ t dt d ttdddiksWJ t dt d d ttdddikskJ t dt d d ttdddiksJ t dt d d ttdddiksJ t td d ttdtjdtj dt diksJ t td d d ttdtjdtj dt diksJ t dt d d  ttdddiksJ t dt d d  ttd	ddiksJ t dt d d  ttdddiks
J t dt d d  ttd	ddiks!J t dt d d  ttdddiks8J t dt d d  ttd	ddiksOJ t tt t	 d  tt	t dikseJ t tt t	 d  tt	 t diks|J t td t d t  t ttdtjdiksJ t td dtd   d ttjdtj
diksJ t td
 dtd   dtd   td  ttjddtd dtjddtd diksJ t td d ttdd ttd d  dtdd ttd d  dtd d ttd d  dtd d ttd d  dtjdtj dtdt diks2J dtd  dtd   dtd   dtd   dtd
   dtd   dtd   dtd   } t | tjdtd dtddtdddtd	ddtdddtdddiksJ t tt	 t t tt	 t t  ttt	 t t tt	 t  diksJ t td td  t d tddi ksJ t td td  td   tddtd dtddtddiksJ t td td  td  td   tddtd dtddtddtddiksJ t td dtd   dt  d ttd ddt ddt diks>J t td dtd   dt  d tdddt ddt dtd dikseJ t td t td dtd   dt  d  ttjdtjdtd ddt ddt diksJ tjtdd}}dtd d | }d| d }|d }tdt d }|| }| | }t td td  t d tdd| | | d| | ||  | d| | ||  | diksJ td dt  d tdtd  dt  tdt d } dd dD \}	}
td}t | t|	|
tddt |    d|	|
tddt |    d|	|
tddt |    d|	|
tddt |    diksdJ td td  td  t d } dd d D \}}}t | t| |d|   t||d|   |   d| |d|   t||d|   |   d| |d|   t||d|   |   d| |d|   t||d|   |   diksJ td dt td   ddt  dtd   t  t dtd   } t | ttjdtjtjt  tjtddt  td  dtd     dtjtjt  tjtddt  td  dtd     diksEJ t tt	 t td  dtd   dt  d tddi kseJ t tt	 t td  dtd   dt  d tddi ksJ t td d td!d"tjdtj diksJ t td d td#d"tdt diksJ t td td  ttjdtj diksJ t td td  td$d% d&tjdiksJ t td d td!dd'tj tjgksJ t td d td#dd'tt gks	J td(dd)\}}td || d  dt ||   d }t |td*d"d||  diks7J t td tdd+tjtjtjgksKJ t d,tdd+g ksWJ td
 td  td  td  td  t d } t | t ttd  ttd  dt tttdd  tttdd  dt tttdd  tttdd  dtttd  ttd  dttttdd  tttdd  dttttdd  tttdd  diksJ td d | d   }t |t ttd  ttd  dt tttdd  tttdd  dt tttdd  tttdd  dtttd  ttd  dttttdd  tttdd  dttttdd  tttdd  dt dtdikspJ t td d-t  d }d.d |D d/ }d0d
td1  }|dt|d d d2t|d  ksJ tddtd  td  d3dtd  td   td d t  d td4d5}t |dtd dddtd  dtd d diksJ td6td  d7td td   d8td   d0td td   d9td   d:td td   d;td   d<td td   d=td t  d=t  d> td4d5}t |td d dddtd  ddtd dd?dtd  dd	dtd  diksiJ ttd dtd   d
td td   dtd t  d@t  dA dAtd  td4d5}t |dtd d ddtd d ddtd d diksJ t tttd d d td4d5td tddtj tdt d    dtd tddtj tdt d    dtd tdd dik	sJ d S )BNr+   r   r4   r>   rA   r;   rU   rh   r?   r@   rd   i i  i  i  i     rY   i  r}   r   F)ZcubicsrJ   T!      c                 S      g | ]}t | qS r1   r   r[   r1   r1   r2   r3     s    ztest_roots0.<locals>.<listcomp>))r   r   )r+   r   c                 S   r   r1   r   r[   r1   r1   r2   r3         ))r+   rA   )r+   rd   )rU   rd   Zfilterr   c                 S   s   | j S r   )Zis_positive)rS   r1   r1   r2   <lambda>  s    ztest_roots0.<locals>.<lambda>)Z	predicate)r   r   za, b)realRr   i  (   c                 S   s   g | ]}|j r|qS r1   r,   )r/   Zrxr1   r1   r2   r3     rI   r   l   i2  r   r   rp   rq   )            }   -            r      r   )r#   r<   r   r   expandr   r   r   rL   rP   ZNegativeOner   rN   rO   r   rZ   r\   rQ   r   r	   r   r
   r   r   )rR   Zr1_2Zr1_3Zx0Zx1Zx2Zx3Zx4Zx5Zr13_20Zr1_20s2Zr1_4Zr1_8Zr5_8arbrr_   r   rS   Z	real_rootZcrrW   r1   r1   r2   test_roots0  sX  D$(((26,,....,.44,&
:


(L,
,$
J(
0(

 <
 ****D::@@.*.
,(($(0**((	**((

*P<@

0 D
B ,,r   c                     s  t d\} }}}d | | |  | |  |  }d | |||  |    |  | | || |   | | ||   }tt| ddgksNJ tt| ddgks]J t d\}}}}	}
}}|| ||  ||  |	| |
  |
 |	 | }|| | | |
||  |
  |	|	 ||   }tt|| | g dksJ d dd   d  tt  }tdd	  fd
d|D D rJ dS )z6Just test that calculating these roots does not hang. z	a,b,c,d,xr4   r+   zzz,yy,xx,zy,zx,yx,kr   r>   rd   c                 s   s    | ]}|V  qd S r   r1   r.   r1   r1   r2   r`   @  s    z"test_roots_slow.<locals>.<genexpr>c                    s    g | ]}  |jd dqS )Tr]   )rZ   rF   )r/   ZrirR   r<   r1   r2   r3   @  s     z#test_roots_slow.<locals>.<listcomp>N)r   r6   r#   valueskeysr   )rL   rP   rN   rO   f1f2ZzzZyyZxxZzyZzxZyxkZe1Ze2r   r1   r   r2   test_roots_slow,  s   $H00"*r   c                  C   s   t td t d tdd} t td t d tdd}t| |D ]\}}t|| dk s-J qtd dtd	 td
   ddtd  td   ddtd d   }t |dd} d}t| |D ]\}}t|| dk smJ q_d S )Nr4   r+   Tr   g      ?g-q=rA   g      @g       @r>   g     S@g      8@g      b@g      "@)g؋~)g)cg3!	@g
 @绽|=)r#   r<   r   absr   )R1R2r   r2rR   r1   r1   r2   test_roots_inexactC  s   2r   c                  C   s  t d\} }}}d| d  |d  |d  d| t | d  |d  |d   d| d	  |d
  |d	  td
  |d   d| d  |d  |d  td  |d   d| d  |d  |d  td  |d   d| d  |d  |d  td  |d	   d| d
  |d	  |d
  td	  d|d    d|  | |d  td  d|d
    d|d  td  d  }t|ti ksJ t| tdd}g d}td}||  | ||d
   }t|t|ksJ t||D ]\}	}
|	|}|d urt|| |
 dk sJ qd S )Nr   r   rd   rt   r   rY   r   r   r@   r4   r   r   rU   r>   rh   r   rA   r   r   r   r   r   r   Tr   )g?|YcgOXLzGX@g'I^g@g|۰n@gdZw@g5`e@gS$Ȫ@gJm@rH   r   )	r   r<   r#   evalfr   r9   r   matchr   )r   r   r   r   rR   r   r   rH   r_   r   r   r   r1   r1   r2   test_roots_preprocessedU  s8   "****.&

&r   c            	      C   s   ddt   dt d   dt d   dt d   } t| d	d
\}}t| }t| d	d}dd |D }dd |D }|| }dd |D }t|dd d}t|dd d}||fD ]"}t||D ]\}}|jrl||v skJ q^t|t|f|v sxJ q^qWd S )Nipi  i  r4   i
  r>   1   rA   T)rb   r   c                 S   s   g | ]\\}}}t ||qS r1   )r   r/   rL   rP   _r1   r1   r2   r3   y  s    z$test_roots_mixed.<locals>.<listcomp>c                 S   s8   g | ]\\}}}t t|t|t t|t| qS r1   )r   r   r   r   r1   r1   r2   r3   z  s    (c                 S   s   g | ]}|  qS r1   )r   r[   r1   r1   r2   r3   ~  r   c                 S      |   S r   Zsort_keyr<   r1   r1   r2   r         z"test_roots_mixed.<locals>.<lambda>r   c                 S   r   r   r   r   r1   r1   r2   r     r   )	r<   r   r   r#   r7   r   r-   r   r   )	rR   _reZ_imZ_nrootsZ_srootsZ
_intervalsZ_rootsr0   rS   r1   r1   r2   test_roots_mixedr  s&   0r   c                
   C   s  t tdttdtgksJ t ttttttgksJ t td d ttd td gks1J t td t tttt ttt gksHJ t td d d td td td td tt tt tt tt gksnJ t ttd d tddttd tttd tttd d tgksJ t dtd  dtd   dtd   td  td	dtttd dtd   dtd   d gksJ d S )
Nr+   r4   rA   r   r   rd   r   r@   Q)r   r   r<   rQ   r   r   r1   r1   r1   r2   test_root_factors  s   &.2*4(r   c                     sR   d} t | tdd ttjj fdd  jdd}dd	 |D g d
ks'J d S )Nr}   Tr   c                      s    j dddS )Nr>   rU   )rF   Zmaxsteps)r   r1   rm   r1   r2   r     s    ztest_nroots1.<locals>.<lambda>r>   rE   c                 S      g | ]}t |qS r1   strr[   r1   r1   r2   r3     r   z test_nroots1.<locals>.<listcomp>)@z-0.999z-0.996z-0.991z-0.983z-0.973z-0.961z-0.946z-0.930z-0.911z-0.889z-0.866z-0.841z-0.813z-0.784z-0.753z-0.720z-0.685z-0.649z-0.611z-0.572z-0.531z-0.489z-0.446z-0.402z-0.357z-0.311z-0.265z-0.217z-0.170z-0.121z-0.0730z-0.0243z0.0243z0.0730z0.121z0.170z0.217z0.265z0.311z0.357z0.402z0.446z0.489z0.531z0.572z0.611z0.649z0.685z0.720z0.753z0.784z0.813z0.841z0.866z0.889z0.911z0.930z0.946z0.961z0.973z0.983z0.991z0.996z0.999)r$   r<   r(   mpmathZmpZNoConvergencer   )rF   r#   r1   rm   r2   test_nroots1  s   r   c                  C   sj   t td dt  d t} | jdd}dd |D g dks J | jdd}dd |D g d	ks3J d S )
NrU   r>   r+   rE   c                 S   r   r1   r   r[   r1   r1   r2   r3     r   z test_nroots2.<locals>.<listcomp>)z-0.332z-0.839 - 0.944*Iz-0.839 + 0.944*Iz1.01 - 0.937*Iz1.01 + 0.937*Ic                 S   r   r1   r   r[   r1   r1   r2   r3     r   )z-0.33199z-0.83907 - 0.94385*Iz-0.83907 + 0.94385*Iz1.0051 - 0.93726*Iz1.0051 + 0.93726*I)r   r<   r   )r_   r#   r1   r1   r2   test_nroots2  s   r   c                   C   s>   t tttd td tt  t t tdddksJ d S )Nr>   r4   T)Z	composite)r9   r#   r   rQ   r   r<   r1   r1   r1   r2   test_roots_composite  s   >r   c                      s.   t td t t d  tt fdd d S )Nr>   r+   c                      s   t  S r   rk   r1   rV   r1   r2   r     r   z"test_issue_19113.<locals>.<lambda>)r
   r<   r(   r%   r1   r1   rV   r2   test_issue_19113  s   r   )Z__doc__Zsympyr   r   r   r   r   r   r   r	   r
   r   r   r   r   r   r   r   r   r   r   r   Zsympy.polysr   r   r   r   r   Zsympy.polys.polyrootsr   r   r   r   r   r    r!   r"   r#   Zsympy.polys.orthopolysr$   Zsympy.polys.polyerrorsr%   Zsympy.polys.polyutilsr&   Zsympy.utilities.iterablesr'   Zsympy.testing.pytestr(   r)   Zsympy.testing.randtestr*   r   rL   rP   rN   rO   rM   r   rz   r<   rQ   r\   r:   r=   rT   rX   rc   rj   rl   ro   rs   ry   r|   r~   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r1   r1   r1   r2   <module>   sT    X,"		:0!< -
