o
    ä¸Gfz  ã                   @   sv  d Z ddlZddlmZmZ ddlZddl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 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&Z&e&j'dkZ(d	d
„ Z)dd„ Z*dd„ Z+dd„ Z,edgddd„ ƒZ-edgddd„ ƒZ.dd„ Z/edgƒdd„ ƒZ0edgdddd „ ƒZ1ed!gddd"d#„ ƒZ2ej3 4d$¡d%d&„ ƒZ5ed'gddd(d)„ ƒZ6d*d+„ Z7edgdd,d-„ ƒZ8d.d/„ Z9ed0gde(rÏd1ndd2d3d4„ ƒZ:d5d6„ Z;ed7gdd$d8d9d:„ ƒZ<ed;gƒd<d=„ ƒZ=ed>gd?dd@dAdB„ ƒZ>edgddCdD„ ƒZ?dEdF„ Z@dGdH„ ZAdIdJ„ ZBdKdL„ ZCedgddMdN„ ƒZDdOdP„ ZEdQdR„ ZFedSgd?dTdUdV„ ƒZGedWgd?dTdXdY„ ƒZHdZd[„ ZIejJ Kd\d]¡d^d_„ ƒZLed`gdgdadbdc„ ƒZMed`gdgdaddde„ ƒZNed`gdgdadfdg„ ƒZOdhdi„ ZPejJ Kdjdk¡dldm„ ƒZQdndo„ ZRdpdq„ ZSdrds„ ZTdtdu„ ZUdvdw„ ZVedxgddygd?ddzd{d|„ ƒZWeg d}¢dd~d„ ƒZXeg d}¢dd€d„ ƒZYdS )‚z'
Tests specific to the patches module.
é    N)Úassert_almost_equalÚassert_array_equal)	ÚAnnulusÚEllipseÚPatchÚPolygonÚ	RectangleÚFancyArrowPatchÚ
FancyArrowÚBoxStyleÚArc)Úimage_comparisonÚcheck_figures_equal)ÚBbox)ÚcollectionsÚcolorsÚpatchesÚpathÚ
transformsÚrcParamsÚwin32c                  C   s  ddgddgddgg} | ddgg }t | dd}| ¡ sJ ‚t| ¡ |ƒ | | ¡ t| ¡ |ƒ t |dd}t| ¡ | ƒ | |¡ t| ¡ | ƒ t | dd}| ¡ rVJ ‚t| ¡ | ƒ | | ¡ t| ¡ | ƒ t |dd}t| ¡ |ƒ | |¡ t| ¡ |ƒ d S )Nr   é   T©ÚclosedF)r   Z
get_closedr   Zget_xyZset_xy)ÚxyZxyclosedÚp© r   ú=lib/python3.10/site-packages/matplotlib/tests/test_patches.pyÚtest_Polygon_close   s(   



r   c            	      C   sV  ddg} d}d}d}t | ||ƒ}t| ¡ |ƒ t| ¡ dƒ d}| d¡ t| ¡ |ƒ t| ¡ d	ƒ d
}t ¡ jg | ¢t 	|¡‘R Ž }| 
|¡}| |¡ t| ¡ |ƒ | d |d  | d |d  g} t| ||ƒ}t| ¡ |ƒ d}| d¡ t| ¡ |ƒ t| ¡ | ƒ d
}t ¡ jg | ¢t 	|¡‘R Ž }| 
|¡}| |¡ t| ¡ |ƒ d S )Né
   é   r   é   )©r   r    )é   r    )r#   é   )r   r$   )g      %@é   )r"   )r   r%   )é   r%   )r&   r    éZ   )é	   ç     €4@é!   r   ))ç      '@r)   )r+   ç     €5@)ç      #@r,   )r-   r)   )r   r   Zget_cornersZ
get_centerÚ	set_angleÚmtransformsZAffine2DZrotate_aroundÚnpZdeg2radÚ	transformr   r   )	ÚlocÚwidthÚheightZcornersÚrectZcorners_rotZthetaÚtÚellipser   r   r   Útest_corner_center;   s<   


ÿ


r8   c               	   C   sÜ  t ddddd} t|  ¡ ddgƒ t|  ¡ ddgƒ t ddddd} t|  ¡ | jd | jd t d	¡  | jd | jd  f| jd | jd t d	¡  | jd | jd  fgƒ t|  ¡ | jd | jd  | jd | jd t d	¡  f| jd | jd  | jd | jd t d	¡  fgƒ t 	|  ¡ ¡\}}tj
 || d | j¡ t 	|  ¡ ¡\}}tj
 || d | j¡ t d
dddd} t 	|  ¡ ¡\}}tj
 || d | j¡ t 	|  ¡ ¡\}}tj
 || d | j¡ d S )N©r   r   r   ©r   r3   r4   Úangle©ç        r=   r!   r   é   é   é   )gj¼t“@g+‡ÙÎ·%Àg…ëQ¸@g®Gáz®ÿ?gR¸…ë1Q@)r   r   Zget_verticesZget_co_verticesÚcenterr3   r0   Úsqrtr4   ÚarrayÚtesting)r7   Zv1Zv2r   r   r   Útest_ellipse_verticesk   sN   þþþþûþþþûþrE   c            	      C   s    t  ddg¡} d}d}d}t| |||d}t| ||ƒ}t j| d }t  t  |¡t  |¡ gt  |¡t  |¡gg¡}t  || ¡ |  ¡j	|  }t
| ¡ |ƒ d S )Nç      ð?g       @r!   r@   g      >@©r;   ç     €f@)r0   Úasarrayr   ZpirC   ZcosZsinÚinnerÚ	get_vertsÚTr   )	r2   r3   r4   r;   Zrect1Zrect2Z	angle_radZrotation_matrixZ	new_vertsr   r   r   Útest_rotate_rectž   s   ÿrM   Úpng)Ú
extensionsc           
      C   sŽ   |   ¡ }|  ¡ }d}d\}}d}t||||d}| |¡ | ¡ |ks%J ‚t|||ƒ}	|	 ¡ dks3J ‚| |	¡ |	 |¡ |	 ¡ |ksEJ ‚d S )Nr9   ©r   r   r>   rG   r   )Úadd_subplotr   Ú	add_patchZ	get_angler.   )
Úfig_testÚfig_refÚax_testÚax_refr2   r3   r4   r;   Úrect_refÚ	rect_testr   r   r   Útest_rotate_rect_draw¶   s   


rY   c              	   C   s  |   ¡ }|  ¡ }d}d\}}t|||dddddgfd}t|||dddg d	¢fd}| ¡ dddgfks6J ‚| ¡ dg d	¢fksBJ ‚| |¡ | |¡ t|||dddddgfd}	t|||dddddgfd}
|	 ¡ dddgfkstJ ‚|
 ¡ dddgfks€J ‚| |	¡ | |
¡ d S )
N©çš™™™™™¹?r[   )çš™™™™™é?r\   r@   Úbr   é   )Ú	linewidthÚ	edgecolorÚ	linestyleÚr)r   r^   r^   r   )rQ   r   Úget_linestylerR   )rS   rT   rU   rV   r2   r3   r4   rW   Z	rect_ref2rX   Z
rect_test2r   r   r   Útest_dash_offset_patch_drawË   s0   
ÿ
ÿ


ÿ
ÿ
rd   c                  C   sH   t dddƒ ¡ d d… } t dddƒ ¡ d d… }tt |dd¡| ƒ d S )	N)éýÿÿÿéþÿÿÿr@   r!   éÿÿÿÿr9   re   rf   r   )r   rK   r   r0   Zroll)Zpos_verticesZneg_verticesr   r   r   Útest_negative_rectí   s   rh   Úclip_to_bboxc            	      C   sú   t  ¡ \} }| ddg¡ | ddg¡ tj d¡ ¡ }| jddg9  _| jddg8  _tj 	¡  ¡ }| jddg9  _| jdd	g7  _tj 
||¡}tj|d
ddd}| |¡ t ddgddgg¡}| |¡}tj|d
dddd}| |¡ d S )Niîÿÿÿr    ijÿÿÿéd   r&   r   é   é   içÿÿÿç      à?ZcoralÚnone)ÚalphaÚ	facecolorr`   iôÿÿÿg     `SÀé2   i’ÿÿÿZgreenr?   Úblack)ro   rp   Úlwr`   )ÚpltÚsubplotsÚset_xlimÚset_ylimÚmpathÚPathÚunit_regular_starZdeepcopyÚverticesÚunit_circleZmake_compound_pathÚmpatchesÚ	PathPatchrR   r/   r   ri   )	ÚfigÚaxr   Zpath2ZcombinedÚpatchÚbboxZresult_pathZresult_patchr   r   r   Útest_clip_to_bboxõ   s(   ÿ


ÿrƒ   Zpatch_alpha_coloringT)Úremove_textc            	      C   sÂ   t j d¡} t j ¡ }t |j| jddd… g¡}t |j| jg¡}t  ||¡}t  |d |¡}t 	¡ }t
j|gddddd	}| |¡ tj|ddddd
}| |¡ | dd¡ | dd¡ dS )z†
    Test checks that the patch and collection are rendered with the specified
    alpha values in their facecolor and edgecolor.
    r^   Nrg   r   rk   Údashdot©r   r   r   rm   ©r   r   r   g      è?©r_   Ú
linestylesrp   r`   ©r_   ra   rp   r`   r!   ©rx   ry   rz   r|   r0   Úconcatenater{   Úcodesrt   ÚaxesÚmcollectionsZPathCollectionÚadd_collectionr}   r~   rR   rv   rw   ©	ÚstarÚcircleÚvertsr   Z	cut_star1Z	cut_star2r€   Úcolr   r   r   r   Útest_patch_alpha_coloring  s*   
ý
ý
r–   Zpatch_alpha_overridec            	      C   sÆ   t j d¡} t j ¡ }t |j| jd d d… g¡}t |j| jg¡}t  ||¡}t  |d |¡}t 	¡ }t
j|gdddddd	}| |¡ tj|dddddd
}| |¡ | dd¡ | dd¡ d S )Nr^   rg   r   rk   r…   ç      Ð?r†   r‡   )r_   r‰   ro   rp   r`   )r_   ra   ro   rp   r`   r!   r‹   r‘   r   r   r   Útest_patch_alpha_override0  s.   
ü
ü
r˜   Údefaultc                  C   s*   t jddddd} |  ¡ d dksJ ‚d S )Nr9   r   rn   )rp   ro   r   )rt   ÚCircleÚget_facecolor)Úcr   r   r   Útest_patch_color_noneP  s   r   Zpatch_custom_linestylec            	      C   sÄ   t j d¡} t j ¡ }t |j| jd d d… g¡}t |j| jg¡}t  ||¡}t  |d |¡}t 	¡ }t
j|gddgddd}| |¡ tj|ddddd	}| |¡ | dd
¡ | dd
¡ d S )Nr^   rg   r   rk   )r   )rk   é   r   rž   ©r   r   r   ©r   r   r   rˆ   rŠ   r!   r‹   r‘   r   r   r   Útest_patch_custom_linestyleX  s*   
ý
ý
r¡   c            
      C   sÊ   t j d¡} t j ¡ }t |j| jd d d… g¡}t |j| jg¡}g d¢}t 	¡ \}}t
|ƒD ]\}}t  || |¡} tj| d|ddd}	| |	¡ q0| d|d g¡ | d|d g¡ |j ¡  d S )	Nr^   rg   )ú-ú--z-.ú:ÚsolidZdashedr…   Zdottedr@   rŸ   r    rŠ   r   )rx   ry   rz   r|   r0   rŒ   r{   r   rt   ru   Ú	enumerater}   r~   rR   rv   rw   ZcanvasZdraw)
r’   r“   r”   r   r‰   r   r€   ÚiÚlsr   r   r   r   Útest_patch_linestyle_accentsu  s"   
ýr©   c           	      C   sÌ   t j ¡ }|  ¡ }| ¡ }tg d¢ƒD ],\}}t  |j| |j¡}tj|d|ddd}| 	|¡ tj|ddddd}| 	|¡ q| 
d|d	 g¡ | d|d	 g¡ | 
d|d	 g¡ | d|d	 g¡ d S )
N)rn   ÚNoneú Ú r@   rŸ   r    rŠ   r¢   rn   rg   r   )rx   ry   r|   rQ   r¦   r{   r   r}   r~   rR   rv   rw   )	rS   rT   r“   rU   rV   r§   r¨   r   r   r   r   r   Útest_patch_linestyle_none  s*   
ý
ýr­   c                  C   s€   ddddddœ} dd„ |   ¡ D ƒ}tjd	i |¤Ž}|   ¡ D ] \}\}}}t||ƒ|ks-J ‚t||ƒ|ƒ t||ƒ|ks=J ‚qd S )
N)r9   rP   Z
set_center)rk   r&   Z
set_radius)r!   r@   Ú	set_width)r   r>   Z
set_theta1)é-   rq   Z
set_theta2)rA   rb   r3   Útheta1Útheta2c                 S   s   i | ]	\}}||d  “qS )r   r   )Ú.0ÚkÚvr   r   r   Ú
<dictcomp>°  s    z'test_wedge_movement.<locals>.<dictcomp>r   )Úitemsr}   ÚWedgeÚgetattr)Z
param_dictZ	init_argsÚwÚattrZold_vZnew_vÚfuncr   r   r   Útest_wedge_movement©  s   üýr¼   Zwedge_rangegffffffú?)r„   Ztolc            	   
   C   sº   t  ¡ } d}ddgddg||d gddgd	d
gddgddgddgddgg	}t|ƒD ]%\}\}}|d }|d }tj|d |d fd||dddd}|  |¡ q)|  dd¡ |  dd¡ d S )NgÁoÛàÍ‚@gœ‚Þ,(J@g§ 7
m@gü¶Þ,(J@g¿mƒ7
m@rH   r   éh  r'   iÂ  iLÿÿÿé´   i|  r¯   é.   r@   r   rn   r³   )rp   r`   rs   rf   r&   r(   )rt   rŽ   r¦   r}   r·   Ú
add_artistrv   rw   )	r€   Út1Úargsr§   r°   r±   ÚxÚyZwedger   r   r   Útest_wedge_rangeº  s*   
ø
ÿrÅ   c                  C   s6  t jddd} t| ƒdksJ ‚t jddddd} t| ƒdks J ‚t jddddd} t| ƒd	ks1J ‚t jddddd
d} t| ƒdksCJ ‚t jddddd
dd} d}t| ƒ|ksXJ ‚t jddddd} d}t| ƒ|kskJ ‚t jdddd} t| ƒdks{J ‚t j	dddd} t| ƒdks‹J ‚t j
dddd} t| ƒdks›J ‚tjg d¢dd}t  |¡} t| ƒdks±J ‚t  t d ¡¡} t| ƒd!ksÁJ ‚ddgddgddgg}t  |¡} t| ƒd"ksÙJ ‚t j|d#} t| ƒd$d%… d&ksëJ ‚t  dd¡} t| ƒd'ksùJ ‚t  ddd(¡} t| ƒd)ks	J ‚t  | dd¡}t|ƒd*ksJ ‚d$S )+z©
    Check that patches have nice and working `str` representation.

    Note that the logic is that `__str__` is defined such that:
    str(eval(str(p))) == str(p)
    ©r   r!   r@   )r   ÚradiuszCircle(xy=(1, 2), radius=3)r?   rk   r:   z.Ellipse(xy=(1, 2), width=3, height=4, angle=5)z0Rectangle(xy=(1, 2), width=3, height=4, angle=5)r^   )rA   rb   r°   r±   r3   z6Wedge(center=(1, 2), r=3, theta1=4, theta2=5, width=6)rž   )r   r3   r4   r;   r°   r±   z>Arc(xy=(1, 2), width=3, height=4, angle=5, theta1=6, theta2=7))r@   r?   r   r!   )r   rb   r3   r;   z.Annulus(xy=(1, 2), r=(3, 4), width=1, angle=2)r    )rÇ   z3RegularPolygon((1, 2), 20, radius=5, orientation=0))r   rÇ   Z
resolutionz.CirclePolygon((1, 2), radius=5, resolution=20))r3   r4   z)FancyBboxPatch((1, 2), width=3, height=4))rÆ   ©r!   r!   rÆ   Tr   zPathPatch3((1, 2) ...)©r   r!   z
Polygon0()zPolygon3((1, 2) ...))r   Né   zFancyArrowPatch(Path(array(zFancyArrowPatch((1, 2)->(3, 4))ÚdatazConnectionPatch((1, 2), (3, 4))z'Shadow(ConnectionPatch((1, 2), (3, 4))))r}   rš   Ústrr   r   r·   r   r   ZRegularPolygonZCirclePolygonZFancyBboxPatchrx   ry   r~   r   r0   Úemptyr	   ÚConnectionPatchÚShadow)r   Úexpectedr   rË   Úsr   r   r   Útest_patch_str×  sH   

rÒ   Zmulti_color_hatch)r„   Ústylec               	   C   sÖ   t  ¡ \} }| tdƒtddƒ¡}t|ƒD ]\}}| d¡ | d|› ¡ | d¡ q| ¡  | 	d¡ tdƒD ]/}t
j dd|› i¡ t|d	 dfd
dddd}W d   ƒ n1 s^w   Y  | |¡ q9d S )Nrk   r   r^   rn   ÚCú/Fzhatch.colorgš™™™™™Ù?r\   z//)ÚhatchÚfc)rt   ru   ZbarÚranger¦   Zset_facecolorZset_edgecolorZ	set_hatchZautoscale_viewÚ	autoscaleÚmplrÓ   Úcontextr   rR   )r   r€   Zrectsr§   r5   rb   r   r   r   Útest_multi_color_hatch  s   

ÿýrÜ   zunits_rectangle.pngc                  C   s’   dd l m  m}  |  ¡  t d| j d| j fd| j d| j ¡}t ¡ \}}| 	|¡ | 
d| j d| j g¡ | d| j d| j g¡ d S )	Nr   rk   r^   r   r!   r?   rž   r(   )Zmatplotlib.testing.jpl_unitsrD   Z	jpl_unitsÚregisterr}   r   Zkmrt   ru   rR   rv   rw   )ÚUr   r   r€   r   r   r   Útest_units_rectangle*  s   *
rß   zconnection_patch.pngZmpl20)rÓ   r„   c               	   C   sl   t  dd¡\} \}}tjdddd||dd}| |¡ d}d	}d
}| ¡ }tj||||dd}| |¡ d S )Nr   r!   rZ   )çÍÌÌÌÌÌì?rà   rË   ú->)ÚxyAÚxyBÚcoordsAÚcoordsBÚaxesAZaxesBÚ
arrowstyle)g333333ã?rF   )r=   çš™™™™™É?zaxes fractionr¢   )râ   rã   rä   rå   rç   )rt   ru   r}   rÎ   rÀ   Zget_yaxis_transform)r   Úax1Úax2Úconrâ   rã   rä   rå   r   r   r   Útest_connection_patch7  s   ý

ÿrì   c              	   C   sŽ   |   dd¡\}}tjdd|ddddd	}|  |¡ |  dd¡\}}|j}tjd
 tjd< tjdd||jd |jd fdddd	}| |¡ d S )Nr   r!   )ç333333Ó?rè   rË   )iâÿÿÿiìÿÿÿzfigure pixelsrá   rk   )râ   rä   ræ   rã   rå   rç   ZshrinkBz
figure.dpiúsavefig.dpir>   r    )	ru   r}   rÎ   rÀ   r‚   rt   r   r3   r4   )rS   rT   ré   rê   rë   Zbbr   r   r   Útest_connection_patch_figJ  s    ý
ýrï   c                  C   sX   ddl m } m} | ddddddƒ}|dd}t |df|d¡}t ¡ \}}| |¡ d S )Nr   )ÚdatetimeÚ	timedeltaéá  r   é   )Zseconds)rð   rñ   r}   r   rt   ru   rR   )rð   rñ   ÚstartZdeltar   r   r€   r   r   r   Útest_datetime_rectanglea  s   
rõ   c                  C   s¨   ddl m }  | ddddddƒ}| dddƒ}t t¡ t |df|d¡ W d   ƒ n1 s.w   Y  t t¡ t d|fd|¡ W d   ƒ d S 1 sMw   Y  d S )Nr   ©rð   rò   r   i²  rk   )rð   ÚpytestÚraisesÚ	TypeErrorr}   r   )rð   rô   Zdt_deltar   r   r   Útest_datetime_datetime_failsm  s   ÿ"ÿrú   c                     sz   t  ddd¡‰ g d¢} ˆ  ¡ ‰ˆ  ¡ ‰ˆ  d ¡‰t ‡‡‡fdd„| D ƒ¡}t ‡ fdd„| D ƒ¡}t ||k¡s;J ‚d S )N©rm   rm   rm   rF   ©)r=   rm   )rè   rm   )r—   rm   rû   c                    s   g | ]	}ˆ   |ˆˆ¡‘qS r   ©Zcontains_point©r²   Úpoint)r   rÇ   r1   r   r   Ú
<listcomp>€  s    þþz'test_contains_point.<locals>.<listcomp>c                    s   g | ]}ˆ   |¡‘qS r   rý   rþ   )Úellr   r   r   ƒ  s    )r}   r   Úget_pathÚget_transformÚ_process_radiusr0   rC   Úall)ÚpointsrÐ   Úresultr   )r  r   rÇ   r1   r   Útest_contains_pointz  s   
þr  c                  C   s^   t  ddd¡} g d¢}|  ¡ }|  ¡ }|  d ¡}| |||¡}|  |¡}t ||k¡s-J ‚d S )Nrû   rm   rF   rü   )r}   r   r  r  r  Zcontains_pointsr0   r  )r  r  r   r1   rÇ   rÐ   r  r   r   r   Útest_contains_points‡  s   

r	  c                 C   sæ   t  ddg¡}t  ddg¡}dtjd< |  ¡ }tj|ddd}tj||d |d	 d
}| |¡ | |¡ | ¡ }tj|ddd}tj||j	d |  ddt  
t | ¡ ¡¡d t  
t | ¡ ¡¡d dd}| |¡ | |¡ d S )Nrè   rí   r[   Zfigurerî   rm   )r   r3   r4   r   r   )ZoxZoyéH   )r   r3   r4   r×   Úecro   )r0   rC   rt   r   ru   r}   r   rÏ   rR   ZdpirI   ÚmcolorsZto_rgbr›   )rS   rT   r   ZdxyZa1r5   ZshadowZa2r   r   r   Útest_shadow“  s$   


ü
r  c                  C   s:   ddl m }  | dddƒ}t ¡ \}}td|fd|fƒ}d S )Nr   rö   iÐ  r   ç{®Gáz„?)rð   rt   ru   r	   )rð   Zdtimer   r€   Úarrowr   r   r   Útest_fancyarrow_units¬  s   r  c                  C   sè   t  ¡ \} }|jdddddddd}t ddgdd	gd
dgddgddgdd
gd	dgddgg¡}t |t |jd¡¡s<J ‚t ddgddgddgddgddgddgddgddgg¡}|jdddddddd t |t |jd¡¡srJ ‚d S )Nr   r   rk   r   rm   )Úhead_lengthÚ
head_widthr3   g®Gáz+@g33333³$@gÍÌÌÌÌL#@g\Âõ(\$@g¤p=
×£#@g
×£p=
Ç?g
×£p=
Ç¿r!   gö(\Âµ0@g®Gáz”.@g\Âõ(\û?gÂõ(\Ò?é   )rÃ   rÄ   ZdxZdyr3   r  r  )	rt   ru   r  r0   rC   ZallcloseÚroundr”   Úset_data)r   r€   r  Z	expected1Z	expected2r   r   r   Útest_fancyarrow_setdata´  s:   ùÿ
ùÿ
ÿr  zlarge_arc.svg)rÓ   c                  C   s”   t  dd¡\} \}}d}d}d}||fD ]}t||f||ddd}| |¡ | ¡  | d¡ q| d	d
¡ | dd¡ | dd¡ | dd¡ d S )Nr   r!   éÒ   i½÷ÿÿi¥  r³   )rs   ÚcolorÚequalrž   r&   rk   r^   iXžÿÿiPF  ià±ÿÿiÈ  )rt   ru   r   rR   Úset_axis_offÚ
set_aspectrv   rw   )r   ré   rê   rÃ   rÄ   Zdiameterr€   Úar   r   r   Útest_large_arcÓ  s   
r  zall_quadrants_arcs.svgc                  C   sT  t jddddd\} }d}d}d}d}t| ¡ |ƒD ]\}\}}d	}	td
d
t d¡ f||fƒD ]I\}
}t||	dD ]:\}\}}t|| |
 || |
 f|| || dd|› d| t t 	||¡¡d d|› d|› d	}| 
|¡ q:|d }	q0| | d |d ¡ | | d |d ¡ |jd	dd |jd	dd | ¡  | d¡ qd S )Nr!   F)r   r   )ZsqueezeÚfigsizei€–˜ ))rg   rg   )rg   r   rP   )r   rg   ))r   r   )r   r   )r   rg   )rg   r   )rÈ   )r!   r[   )r!   r  )r!   gü©ñÒMbP?r   g§èH.ÿï?)rô   r?   rÔ   r   r½   zbig )rs   r  Zzorderr;   ZlabelÚgidi   r³   )r  r  )rt   ru   ÚzipZravelr0   rB   r¦   r   Zrad2degZarctan2rR   rv   rw   ZaxhlineZaxvliner  r  )r   Zax_arrZscaleZdiag_centersZon_axis_centersZskewsr€   ZsxZsyr³   ZprescaleZcentersÚjZx_signZy_signr  r   r   r   Útest_rotated_arcsç  sB   ÿ

ÿö
çr"  c                   C   sF   t jtdd tdddddd W d   ƒ d S 1 sw   Y  d S )NzGot unknown shape: 'foo'©Úmatchr   rè   Úfoo)Úshape)r÷   rø   Ú
ValueErrorr
   r   r   r   r   Útest_fancyarrow_shape_error  s   "ÿr(  z
fmt, match))r%  zUnknown style: 'foo')z	Round,fooz%Incorrect style argument: 'Round,foo'c                 C   s<   t jt|d t| ƒ W d   ƒ d S 1 sw   Y  d S )Nr#  )r÷   rø   r'  r   )Zfmtr$  r   r   r   Útest_boxstyle_errors  s   
"ÿr)  Zannulus)Zbaseline_imagesrO   c               
   C   sV   t  ¡ \} }tddddd}tddddd	d
ddd}| |¡ | |¡ | d¡ d S )Nrû   rè   çš™™™™™©?Úg©r×   ©rm   rí   r[   r¯   Úmr]   rm   Úxxx©r×   r  ro   rÖ   r  )rt   ru   r   rR   r  ©r   r€   Zcirr  r   r   r   Útest_annulus  s   
ÿ

r2  c               
   C   s€   t  ¡ \} }tddddd}tddddd	d
ddd}| |¡ | |¡ | d¡ d|_d|_d|_d|_d|_d|_d|_d S )Nr<   rè   r  r+  r,  rÆ   r[   r   r.  r]   rm   r/  r0  r  rû   r*  r-  r¯   )	rt   ru   r   rR   r  rA   Úradiir3   r;   r1  r   r   r   Útest_annulus_setters&  s   
ÿ



r4  c               
   C   s¸   t  ¡ \} }tddddd}tddddd	d
ddd}| |¡ | |¡ | d¡ d|_| d¡ | d¡ |jdks=J ‚d|_	d|_| d¡ | d¡ |jdksTJ ‚d|_	d|_
d S )Nr<   rè   r  r+  r,  rÆ   r[   r   r.  r]   rm   r/  r0  r  rû   )rè   rè   r*  rí   r-  r¯   )rt   ru   r   rR   r  rA   Zset_semimajorZset_semiminorr3  r3   r;   r1  r   r   r   Útest_annulus_setters2;  s&   
ÿ







r5  c                  C   s8   ddg} t | | gƒj}t t| gƒ ¡ j|k¡sJ ‚d S )Nr   )r   Zextentsr0   r  r   Zget_extents)rÿ   Zcorrect_extentsr   r   r   Útest_degenerate_polygonT  s   "r6  Úkwarg)r`   rp   c                 C   sJ   t jtdd tdddi| di¤Ž W d   ƒ d S 1 sw   Y  d S )NzQSetting the 'color' property will override the edgecolor or facecolor properties.r#  r  rr   r   )r÷   ZwarnsÚUserWarningr   )r7  r   r   r   Útest_color_override_warningZ  s
   ÿ"ýr9  c                  C   s"   t t d¡ƒ} |  ¡ g ksJ ‚d S )NrÉ   )r   r0   ZzerosrK   )Zpolyr   r   r   Útest_empty_vertsb  s   r:  c                  C   sN   t ƒ } |  td  ¡ |  ¡ td  ksJ ‚|  d ¡ |  ¡ td ks%J ‚d S )Nzpatch.antialiased)r   Zset_antialiasedr   Zget_antialiased©r   r   r   r   Útest_default_antialiasedg  s
   
r<  c                  C   s.   t ƒ } |  d¡ |  d ¡ |  ¡ dksJ ‚d S )Nr£   r¥   )r   Zset_linestylerc   r;  r   r   r   Útest_default_linestyleq  s   

r=  c                  C   ó   t ƒ } |  ¡ dksJ ‚d S )NZbutt)r   Zget_capstyler;  r   r   r   Útest_default_capstylex  ó   r?  c                  C   r>  )NZmiter)r   Zget_joinstyler;  r   r   r   Útest_default_joinstyle}  r@  rA  Zautoscale_arcÚsvg)rO   rÓ   r„   c                  C   s²   t jdddd\} }tddddddgtd	d
ddddg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gf}t||ƒD ]\}}|D ]}| |¡ qJ| ¡  qDd S )Nr   r@   )r?   r   )r  r9   r   r'   )r°   r±   rû   ç      ø?rm   r   r    g      @én   éx   g      @r  éÜ   g      @i6  i@  )rt   ru   r   r   rR   rÙ   )r   ZaxsZ	arc_listsr€   ZarcsZarcr   r   r   Útest_autoscale_arc‚  s   ýý
ýrG  )rN   rB  ZpdfZepsc                 C   sb   t ddgdddddd}t ddgdddddd}tj|gddd	}| ¡  |¡ |  ¡  |¡ d S )
Nrm   r   r   é<   r    ©r°   r±   r;   rn   r³   )r   Z
facecolorsZ
edgecolors)r   r   ZPatchCollectionru   rR   r   )rS   rT   Úarc1Úarc2r•   r   r   r   Útest_arc_in_collection”  s   
ÿrL  c                 C   sd   t ddgdddddd}t ddgdddddd}| ¡  |¡ |  ¡  |¡ | d¡ | d¡ d S )	Nrm   r   r   rH  r    rI  rC  r   )r   ru   rR   r®   r.   )rS   rT   rJ  rK  r   r   r   Útest_modifying_arcž  s   
rM  )ZÚ__doc__Znumpyr0   Znumpy.testingr   r   r÷   Z
matplotlibrÚ   Zmatplotlib.patchesr   r   r   r   r   r	   r
   r   r   Zmatplotlib.testing.decoratorsr   r   Zmatplotlib.transformsr   Zmatplotlib.pyplotZpyplotrt   r   r   r   r  r   r}   r   rx   r   r/   r   ÚsysÚplatformZon_winr   r8   rE   rM   rY   rd   rh   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(  ZmarkZparametrizer)  r2  r4  r5  r6  r9  r:  r<  r=  r?  rA  rG  rL  rM  r   r   r   r   Ú<module>   s¦    , 
%03



!








@








$





ÿ

	