U
    	Ç-eë  ã                   @   sÌ   d 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 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mZm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 )zETests for efficient functions for generating orthogonal polynomials. é    )ÚRational)ÚS)Úsymbols)ÚPoly)Úraises)	Újacobi_polyÚgegenbauer_polyÚchebyshevt_polyÚchebyshevu_polyÚhermite_polyÚhermite_prob_polyÚlegendre_polyÚlaguerre_polyÚspherical_bessel_fn)ÚxÚaÚbc                   C   sÊ  t tdd„ ƒ tdtttddttd td  d t td  td  tddksVt‚td	tttƒdkslt‚tdtttƒtd td  ttd td  d   ks¦t‚tdtttƒtd d
 tt d  td
  td d
  td
  td td d
 tt d  ttdd
ƒ  td d
  ttdd
ƒ  tddƒ   ttd d ttddƒ  td d  ttddƒ    t	j
 ks~t‚tdttddttd td  d t td  td  tddksÆt‚d S )Nc                   S   s   t dtttƒS ©Néÿÿÿÿ)r   r   r   r   © r   r   úb/var/www/html/Darija-Ai-Train/env/lib/python3.8/site-packages/sympy/polys/tests/test_orthopolys.pyÚ<lambda>   ó    z"test_jacobi_poly.<locals>.<lambda>é   T©Zpolysé   zZZ(a,b)©Údomainr   é   é   é   é   )r   Ú
ValueErrorr   r   r   r   r   ÚAssertionErrorÚQr   ÚHalfr   r   r   r   Útest_jacobi_poly   s<    &  ÿ:>6ÿÿÿÿ
ÿÿþý&  ÿr&   c                   C   s:  t tdd„ ƒ tdttddtdt t tddks8t‚td	ttƒdksLt‚tdttƒdt t ksht‚tdttƒt td dtd  dt    ksšt‚td
ttƒtd
 dtd
  d
 dtd   ttdd
ƒ   tdtd  dt    ksôt‚tdtj	ƒ 
t¡st‚tdtddtdt t tddks6t‚d S )Nc                   S   s   t dttƒS r   )r   r   r   r   r   r   r   r   *   r   z&test_gegenbauer_poly.<locals>.<lambda>r   Tr   r   zZZ(a)r   r   r!   r   r   éþÿÿÿ)r   r"   r   r   r   r   r#   r$   r   r%   Údummy_eqr   r   r   r   Útest_gegenbauer_poly)   s*       ÿÿ2  ÿHÿr)   c                   C   sN  t tdd„ ƒ tdtddttƒks(t‚tdtƒdks:t‚tdtƒtksLt‚tdtƒdtd  d ksjt‚tdtƒd	td  dt  ksŒt‚td	tƒd
td	  d
td   d ks¶t‚tdtƒdtd  dtd   dt  ksät‚tdtƒdtd  dtd	   dtd   d kst‚tdƒ t¡s0t‚tdddttƒksJt‚d S )Nc                   S   s
   t dtƒS r   )r	   r   r   r   r   r   r   :   r   z&test_chebyshevt_poly.<locals>.<lambda>r   Tr   r   r   r!   r   r   é   é   é   é   é    é0   é   )r   r"   r	   r   r   r#   r(   r   r   r   r   Útest_chebyshevt_poly9   s    "*.8r1   c                   C   s^  t tdd„ ƒ tdtddtdt ƒks,t‚tdtƒdks>t‚tdtƒdt ksTt‚tdtƒdtd  d ksrt‚td	tƒd
td	  dt  ks”t‚tdtƒdtd  dtd   d ks¾t‚tdtƒdtd  dtd	   dt  ksìt‚tdtƒdtd  dtd   dtd   d ks$t‚tdƒ dt ¡s<t‚tdddtdt ƒksZt‚d S )Nc                   S   s
   t dtƒS r   )r
   r   r   r   r   r   r   K   r   z&test_chebyshevu_poly.<locals>.<lambda>r   Tr   r   r   r   r!   r   r+   é   r*   r.   r-   é@   éP   é   )r   r"   r
   r   r   r#   r(   r   r   r   r   Útest_chebyshevu_polyJ   s    "*.8r6   c                   C   s^  t tdd„ ƒ tdtddtdt ƒks,t‚tdtƒdks>t‚tdtƒdt ksTt‚tdtƒdtd  d ksrt‚td	tƒd
td	  dt  ks”t‚tdtƒdtd  dtd   d ks¾t‚tdtƒdtd  dtd	   dt  ksìt‚tdtƒdtd  dtd   dtd   d ks$t‚tdƒ dt ¡s<t‚tdddtdt ƒksZt‚d S )Nc                   S   s
   t dtƒS r   )r   r   r   r   r   r   r   \   r   z#test_hermite_poly.<locals>.<lambda>r   Tr   r   r   r   r!   r   r2   r+   r/   r*   r.   é    éx   r-   r3   ià  éÐ  )r   r"   r   r   r   r#   r(   r   r   r   r   Útest_hermite_poly[   s    "*.8r:   c                   C   s:  t tdd„ ƒ tdtddttƒks(t‚tdtƒdks:t‚tdtƒtksLt‚tdtƒtd d ksft‚tdtƒtd dt  ks„t‚td	tƒtd	 d
td   d ksªt‚tdtƒtd dtd   dt  ksÔt‚td
tƒtd
 dtd	   dtd   d kst‚tdƒ t¡st‚tdddttƒks6t‚d S )Nc                   S   s
   t dtƒS r   )r   r   r   r   r   r   r   m   r   z(test_hermite_prob_poly.<locals>.<lambda>r   Tr   r   r   r!   r   r-   r*   é
   é   é-   )r   r"   r   r   r   r#   r(   r   r   r   r   Útest_hermite_prob_polyl   s    &*4r>   c                   C   s¨  t tdd„ ƒ tdtddttddks,t‚tdtƒdks>t‚tdtƒtksPt‚td	tƒtd
d	ƒtd	  tdd	ƒ kszt‚td
tƒtdd	ƒtd
  td
d	ƒt  ks¨t‚tdtƒtddƒtd  tddƒtd	   td
dƒ ksät‚tdtƒtddƒtd  tddƒtd
   tddƒt  ks&t‚tdtƒtddƒtd  tddƒtd   tddƒtd	   tddƒ ksvt‚tdƒ t¡sŠt‚tdddttƒks¤t‚d S )Nc                   S   s
   t dtƒS r   )r   r   r   r   r   r   r   ~   r   z$test_legendre_poly.<locals>.<lambda>r   Tr   ÚQQr   r   r   r!   r*   r   é#   r   é   é?   éF   r<   r-   éç   r+   i;  éi   )r   r"   r   r   r   r#   r$   r(   r   r   r   r   Útest_legendre_poly}   s,    *.<B
 ÿÿÿÿÿrF   c                   C   sX  t tdd„ ƒ tdtddtt d ddks2t‚tdtƒdksDt‚tdtƒt d ks\t‚td	tƒtdd	ƒtd	  td
d	ƒt  d ksŽt‚tdtƒtddƒ td  tddƒtd	   tddƒt  d ksÔt‚td
tƒtddƒtd
  tddƒtd   tddƒtd	   tddƒt  d ks,t‚tdtƒtddƒ td  tddƒtd
   tddƒtd   tddƒtd	   tddƒt  d ks˜t‚tdtƒtddƒtd  tddƒtd   tddƒtd
   tddƒtd   tddƒtd	   tddƒt  d kst‚tdttƒdks*t‚tdttƒt t d ksJt‚td	ttƒtd	 d	 t d	 t  td	 d	  ttdd	ƒ  d ks”t‚tdttƒtd  d td	 tdƒd	  td	   td	  d	 ttdd	ƒ  d t  td d  td	  ttddƒ  d kst‚tdƒ t d ¡s4t‚tdddtt d ƒksTt‚d S )Nc                   S   s
   t dtƒS r   )r   r   r   r   r   r   r      r   z$test_laguerre_poly.<locals>.<lambda>r   Tr   r?   r   r   r   r   r!   r-   é	   r0   r5   r+   éH   é`   r*   r8   é   éÈ   iX  r9   é$   iÂ  i`	  i  ià  é   )	r   r"   r   r   r   r#   r$   r   r(   r   r   r   r   Útest_laguerre_poly   sn    $2F
 ÿÿÿÿÿÿ. ÿÿÿÿÿ| Jÿÿÿ"ÿ
ÿÿÿÿrN   c                  C   s    t dƒ\} }td|ƒd|d  ks&t‚td|ƒd| d|d   ksHt‚td|ƒd|d  d|d   ksnt‚td|ƒd| d	|d   d
|d   ksœt‚d S )Nzx zr   r   r   r!   iúÿÿÿr<   r   r=   rE   r*   )r   r   r#   )r   Úzr   r   r   Útest_spherical_bessel_fn¨   s
    "&rP   N)#Ú__doc__Zsympy.core.numbersr   r$   Zsympy.core.singletonr   Zsympy.core.symbolr   Zsympy.polys.polytoolsr   Zsympy.testing.pytestr   Zsympy.polys.orthopolysr   r   r	   r
   r   r   r   r   r   Z	sympy.abcr   r   r   r&   r)   r1   r6   r:   r>   rF   rN   rP   r   r   r   r   Ú<module>   s    ,