U
    L?h                     @   s  d dl Z d dlmZ d dl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 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 d d	l m!Z!m"Z"m#Z#m$Z$m%Z% d d
l&m'Z' d dl(m)Z) dd Z*dd Z+dd Z,dd Z-dd Z.dd Z/dS )    N)Float)
DerivativeFunction)S)Symbol)expcossintancoshsinh)sqrt)PointPoint2DLinePolygonSegmentconvex_hullintersectioncentroidPoint3DLine3DRayEllipse)idiffclosest_pointsfarthest_points_ordered_pointsare_coplanar)solve)raisesc                     s*  t dddt ddd} t ddd}td}td}d | d  d	 }d
 d | d  d  | d  }|t|| dkstt|| d|t|| gdkstt|| d|kstd td  d	 d   || t|| d  std fddt|| D ks tt| |  | |gt| d ksNtt|t	| t	  |d t	 t	|  |d  kstt|| t	  || g| t|  t	 kstt|| t	  | |g|  t|t	   ks2tt|| ||gt|ksjt| dt
 d  d  td  dtd    }t|| dt
 t dtd   dt  td d  dt   dt
 d   dd   ks&td S )NxT)realytfg                  r   c                    s   g | ]}| d  qS )r+   )diffequals).0Zsolexplicitr!    P/var/www/html/venv/lib/python3.8/site-packages/sympy/geometry/tests/test_util.py
<listcomp>   s     ztest_idiff.<locals>.<listcomp>i
   i   )r   r   r   AssertionErrorr   subsr   r/   r   r   r	   r
   r   r   r   )r#   r$   r%   r&   circansZfxyr3   r1   r4   
test_idiff   s<    $$ $.\@H8:,

r<   c                  C   s  t tddg kstttdd  t tddtddtddd	d
tddtddgks^tt tddtddtddd	d
tddtddgkstt tddtddtddtdddd	d
tddtddgkstd} t ttddtddt	tdd| ddd	d
d j
}|ttddddj
ks6ttdd} t ttddtddt	tdd| ddd	d
d j
}|ttddddj
kst|d jdkst|d jdkstd S )Nr   c                   S   s   t tdddS Nr   r+   )r   r   r3   r3   r3   r4   <lambda>+       z#test_intersection.<locals>.<lambda>r   r   r'   r   )r   )r*   r   )r   r*   T)pairwiser*   )Zslopeg      @gMbP?rB   g-C6J?g333333g       @)centerZhradiusZvradiusgj6gG?gpF)evaluater(   r-   5   r7   )r   r   r8   r    	TypeErrorr   r   r   r   r   ZcoordinatespytestZapproxr   Z_prec)Rcc2r3   r3   r4   test_intersection)   sz        
  
 

 rL   c                  C   sj   t tdd  dddddg} t| dd	itd
dtddtddtddgtd
dtddgfksftd S )Nc                   S   s   t tdddS r=   )r   r   r3   r3   r3   r4   r>   P   r?   z"test_convex_hull.<locals>.<lambda>r*   rB   r*   r+   rB   rO      ZpolygonFrR   rO   r*   rB   r+   rT   rU   )r    rG   r   r   r8   )pointsr3   r3   r4   test_convex_hullO   s    "rW   c                  C   s   t ddd} | dd}t| |tddd ks4ttdd} tdd	}t| |td
td d ksjtttddtddtddd kstttddtddtddtddd kstd S )Nr@   )r6   r   )r6   r6   r   r7   (   r+   rA   )r'   r'   r*   r'   )r   	translater   r   r8   r   r   )pqr3   r3   r4   test_centroidW   s    

"(r\   c                     sB  ddl m}  ddlm} ttfD ]}|tkr4t nt tt	 fdd t
ddt
ddt
ddg}t
ddt
ddt
ddg}t
ddt
ddt
dd	g}t
ddt
ddt
d
dg}t
ddt
ddt
ddg}t
ddt
ddt
ddt
ddg}tddd}	dd |	df|	d df|	d dffD }
|||||||
fD ]`}|dd |t|dD }t | d  }\}}|||kst|t|ks@tq@t }t|dkr|t
| dd| dd qt|}|dd ||dD }t | d  }\}}|||ks"t|t|ks tq t
ddt
ddt
tjtdd   }}}dd ||||fdD }t||||kstt||||kstdddddg}t| t
ddt
dd
fhkstdd d!d"d#g}t| t
dd$t
dd%fhks
ttdd&t
ddt
ddfhks0ttt	d'd  d S )(Nr   )randint)subsetsc                      s    t ddt ddS )Nr   r   r3   funcr3   r4   r>   l   r?   z5test_farthest_points_closest_points.<locals>.<lambda>r+   r*   r'   r6   r(   rB   r!   T)Zpositivec                 S   s   g | ]}t |qS r3   r_   )r0   ar3   r3   r4   r5   |   s     z7test_farthest_points_closest_points.<locals>.<listcomp>c                 s   s   | ]\}}| |V  qd S Ndistancer0   ijr3   r3   r4   	<genexpr>   s     z6test_farthest_points_closest_points.<locals>.<genexpr>   d   c                 s   s   | ]\}}| |V  qd S rc   rd   rf   r3   r3   r4   ri      s     c                 S   s   h | ]\}}t ||fqS r3   )r   rf   r3   r3   r4   	<setcomp>   s   z6test_farthest_points_closest_points.<locals>.<setcomp>r*   r*   )r*   r'   )r+   r*   )rR   r'   )rT   r(   rR   rT   rM   rN   rP   rQ   rS   rO   rU   r@   c                   S   s   t dS )Nrm   )r   r3   r3   r3   r4   r>      r?   )Zsympy.core.randomr]   Zsympy.utilities.iterablesr^   minmaxr   r   r    
ValueErrorr   r   setlistre   r8   r   lenaddr   ZHalfr   )r]   r^   howp1Zp2Zp3Zp4Zp5dupr!   srV   dr;   rb   brJ   r3   r`   r4   #test_farthest_points_closest_pointsb   sb    $(   
r{   c                  C   s   t tdddtddd} t tdddtddd}t tdddtddd}ttddtdd}t| ||dksxtt| |dkstd S )	Nr-   r   r*   rB   rO   r+   	   F)r   r   r   r   r   r8   )rb   rz   rJ   ry   r3   r3   r4   test_are_coplanar   s    r}   )0rH   Zsympy.core.numbersr   Zsympy.core.functionr   r   Zsympy.core.singletonr   Zsympy.core.symbolr   Zsympy.functionsr   r   r	   r
   r   r   Z(sympy.functions.elementary.miscellaneousr   Zsympy.geometryr   r   r   r   r   r   r   r   r   r   r   r   Zsympy.geometry.utilr   r   r   r   r   Zsympy.solvers.solversr   Zsympy.testing.pytestr    r<   rL   rW   r\   r{   r}   r3   r3   r3   r4   <module>   s     8&A