o
    ¡:´aº—  ã                
   @   sò  d dl Z d dlm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 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 d dlmZmZ d dl m!Z! dd	„ Z"ed
gƒdd„ ƒZ#edgƒdd„ ƒZ$edgƒdd„ ƒZ%edgƒdd„ ƒZ&edgƒdd„ ƒZ'edgƒdd„ ƒZ(edgƒdd„ ƒZ)edgƒd d!„ ƒZ*ed"gƒd#d$„ ƒZ+ed%gƒd&d'„ ƒZ,eg d(¢ƒd)d*„ ƒZ-ed+gƒd,d-„ ƒZ.d.d/„ Z/d0d1„ Z0d2d3„ Z1e
j2 3d4¡ed5gd6d7d8„ ƒƒZ4d9d:„ Z5d;d<„ Z6ed=gd>d?d@dA„ ƒZ7edBgd>d?dCdD„ ƒZ8edEgd>d?dFdG„ ƒZ9edHgd>d?dIdJ„ ƒZ:dKdL„ Z;dMdN„ Z<edOgd>d?dPdQ„ ƒZ=dRdS„ Z>e
j2 3dT¡dUdV„ ƒZ?e
j2 3dT¡dWdX„ ƒZ@e
j2 3dT¡dYdZ„ ƒZAed[gƒd\d]„ ƒZBed^gd>dTd_d`da„ ƒZCdbdc„ ZDddde„ ZEdfdg„ ZFdhdi„ ZGdjdk„ ZHdldm„ ZIdndo„ ZJejK Ldpd>i fdqi fd>eMdqdrfdqeMdsdtfg¡ed5gd6dudv„ ƒƒZNed5gd6dwdx„ ƒZOdydz„ ZPd{d|„ ZQd}d~„ ZRdd€„ ZSdd‚„ ZTdƒd„„ ZUd…d†„ ZVe
j2 3dT¡ejK Ld‡ejWejXg¡dˆd‰„ ƒƒZYdŠd‹„ ZZdŒd„ Z[dŽd„ Z\dd‘„ Z]d’d“„ Z^d”d•„ Z_d–d—„ Z`dS )˜é    N)ÚSimpleNamespace)Úassert_array_equalÚassert_array_almost_equal)Ú
MouseEvent)Ú
CollectionÚLineCollectionÚEventCollectionÚPolyCollection)Úcheck_figures_equalÚimage_comparison)ÚMatplotlibDeprecationWarningc               
   C   s®   t  g d¢¡} t  g d¢¡}d}d}d}d}g d¢}d}d	}t| |||||||d
}	t ¡ \}
}| |	¡ | d¡ | ||||||||dœ	}| dd¡ | dd¡ ||	|fS )z,Generate the initial collection and plot it.)ç        ç      ð?ç       @ç      @g      @g       @g      *@g      5@)g      A@g     €K@g     @V@Ú
horizontalé   ç      à?é   ©r   r   r   r   ÚsolidT)ÚorientationÚ
lineoffsetÚ
linelengthÚ	linewidthÚcolorÚ	linestyleÚantialiasedzEventCollection: default)	Ú	positionsÚextra_positionsr   r   r   r   r   r   r   éÿÿÿÿé   r   )	ÚnpÚarrayr   ÚpltÚsubplotsÚadd_collectionÚ	set_titleÚset_xlimÚset_ylim)r   r   r   r   r   r   r   r   r   ÚcollÚfigÚaxÚprops© r.   úC/usr/lib/python3/dist-packages/matplotlib/tests/test_collections.pyÚgenerate_EventCollection_plot   sD   ù


ø

r0   ZEventCollection_plot__defaultc                  C   sÊ   t ƒ \} }}t||d |d |d |d ƒ tj |d | ¡ ¡ |d | ¡ ks+J ‚| ¡ s1J ‚|d | ¡ ks;J ‚|d | 	¡ ksEJ ‚| 
¡ dgksNJ ‚| ¡ g| ¡ ¢D ]}tj ||d ¡ qWd S )Nr   r   r   r   ©r   Nr   )r0   Úcheck_segmentsr"   Útestingr   Úget_positionsÚget_orientationÚis_horizontalÚget_linelengthÚget_lineoffsetZget_linestyleÚ	get_colorÚ
get_colors)Ú_r*   r-   r   r.   r.   r/   Ú test__EventCollection__get_props<   s    üÿr<   Z#EventCollection_plot__set_positionsc                  C   st   t ƒ \} }}t |d |d g¡}| |¡ tj || ¡ ¡ t|||d |d |d ƒ |  d¡ |  	dd¡ d S )	Nr   r   r   r   r   zEventCollection: set_positionsr    éZ   )
r0   r"   ÚhstackZset_positionsr3   r   r4   r2   r'   r(   ©Úspltr*   r-   Únew_positionsr.   r.   r/   Ú$test__EventCollection__set_positionsV   s   
ý
rB   Z#EventCollection_plot__add_positionsc                  C   s   t ƒ \} }}t |d |d d g¡}| ¡  | |d d ¡ | ¡  tj || ¡ ¡ t|||d |d |d ƒ |  	d¡ |  
dd	¡ d S )
Nr   r   r   r   r   r   zEventCollection: add_positionsr    é#   )r0   r"   r>   Úswitch_orientationZadd_positionsr3   r   r4   r2   r'   r(   r?   r.   r.   r/   Ú$test__EventCollection__add_positionsd   s    

ÿü
rE   Z&EventCollection_plot__append_positionsc                  C   s€   t ƒ \} }}t |d |d d g¡}| |d d ¡ tj || ¡ ¡ t|||d |d |d ƒ |  d¡ |  	dd	¡ d S )
Nr   r   r   r   r   r   z!EventCollection: append_positionsr    r=   )
r0   r"   r>   Zappend_positionsr3   r   r4   r2   r'   r(   r?   r.   r.   r/   Ú'test__EventCollection__append_positionsv   s   

ÿü
rF   Z&EventCollection_plot__extend_positionsc                  C   sˆ   t ƒ \} }}t |d |d dd … g¡}| |d dd … ¡ tj || ¡ ¡ t|||d |d |d ƒ |  d¡ |  	dd	¡ d S )
Nr   r   r   r   r   r   z!EventCollection: extend_positionsr    r=   )
r0   r"   r>   Zextend_positionsr3   r   r4   r2   r'   r(   r?   r.   r.   r/   Ú'test__EventCollection__extend_positions†   s   
ÿü
rG   Z(EventCollection_plot__switch_orientationc                  C   sz   t ƒ \} }}d}| ¡  || ¡ ksJ ‚| ¡ rJ ‚| ¡ }t|||d |d |ƒ |  d¡ |  dd¡ |  dd¡ d S )	NÚverticalr   r   z#EventCollection: switch_orientationr    r!   r   r   )	r0   rD   r5   r6   r4   r2   r'   r)   r(   )r@   r*   r-   Únew_orientationrA   r.   r.   r/   Ú)test__EventCollection__switch_orientation–   s   ý
rJ   Z,EventCollection_plot__switch_orientation__2xc                  C   s€   t ƒ \} }}| ¡  | ¡  | ¡ }|d | ¡ ksJ ‚| ¡ s"J ‚tj |d |¡ t|||d |d |d ƒ |  	d¡ dS )zc
    Check that calling switch_orientation twice sets the orientation back to
    the default.
    r   r   r   r   z&EventCollection: switch_orientation 2xN)
r0   rD   r4   r5   r6   r"   r3   r   r2   r'   r?   r.   r.   r/   Ú,test__EventCollection__switch_orientation_2x§   s   ürK   Z%EventCollection_plot__set_orientationc                  C   sx   t ƒ \} }}d}| |¡ || ¡ ksJ ‚| ¡ rJ ‚t||d |d |d |ƒ |  d¡ |  dd¡ |  dd	¡ d S )
NrH   r   r   r   z EventCollection: set_orientationr    r!   r   r   )r0   Zset_orientationr5   r6   r2   r'   r)   r(   )r@   r*   r-   rI   r.   r.   r/   Ú&test__EventCollection__set_orientation¼   s   
ü
rL   Z$EventCollection_plot__set_linelengthc                  C   s`   t ƒ \} }}d}| |¡ || ¡ ksJ ‚t||d ||d |d ƒ |  d¡ |  dd¡ d S )Né   r   r   r   zEventCollection: set_linelengthiìÿÿÿé   )r0   Zset_linelengthr7   r2   r'   r)   )r@   r*   r-   Znew_linelengthr.   r.   r/   Ú%test__EventCollection__set_linelengthÍ   s   
ü
rO   Z$EventCollection_plot__set_lineoffsetc                  C   s`   t ƒ \} }}d}| |¡ || ¡ ksJ ‚t||d |d ||d ƒ |  d¡ |  dd¡ d S )Ng      Àr   r   r   zEventCollection: set_lineoffsetiúÿÿÿéüÿÿÿ)r0   Zset_lineoffsetr8   r2   r'   r)   )r@   r*   r-   Znew_lineoffsetr.   r.   r/   Ú%test__EventCollection__set_lineoffsetÜ   s   
ü
rQ   )Ú#EventCollection_plot__set_linestylerR   Z#EventCollection_plot__set_linewidthc                  C   sn   dddgfdddgfdfD ]'\} }}t ƒ \}}}|jdi | |i¤Ž t || ¡|ks,J ‚| d| › ¡ qd S )Nr   Údashed)r   )ç      @rT   )r   é   rU   zEventCollection: set_r.   )r0   Úsetr$   Zgetpr'   )ÚpropÚvalueZexpectedr@   r*   r;   r.   r.   r/   Útest__EventCollection__set_propë   s   

ýørY   ZEventCollection_plot__set_colorc                  C   sX   t ƒ \} }}t g d¢¡}| |¡ | ¡ g| ¡ ¢D ]	}tj ||¡ q|  d¡ d S )N)r   r   r   r   zEventCollection: set_color)	r0   r"   r#   Ú	set_colorr9   r:   r3   r   r'   )r@   r*   r;   Z	new_colorr   r.   r.   r/   Ú test__EventCollection__set_colorü   s   
r[   c           
      C   sÎ   |   ¡ }| ¡ dks| ¡ dks|du rd}d}n| ¡ dkr$d}d}ntdƒ‚t|ƒD ]8\}}	|	d|f ||d  ks>J ‚|	d|f ||d  ksLJ ‚|	d|f || ksXJ ‚|	d|f || ksdJ ‚q,dS )	zp
    Test helper checking that all values in the segment are correct, given a
    particular set of inputs.
    r   ÚnoneNr   r   rH   z.orientation must be 'horizontal' or 'vertical'r   )Úget_segmentsÚlowerÚ
ValueErrorÚ	enumerate)
r*   r   r   r   r   ÚsegmentsZpos1Zpos2ÚiZsegmentr.   r.   r/   r2     s$   
ÿÿür2   c                  C   s4   t  g ¡} |  t ¡ ¡}t| ¡ tj ¡  ¡ ƒ d S ©N)	ÚmcollectionsÚPathCollectionÚget_datalimÚmtransformsÚIdentityTransformr   Z
get_pointsZBboxÚnull)ÚcolZcol_data_limr.   r.   r/   Útest_null_collection_datalim   s
   
ÿrk   c                  C   sV   t  ¡  t  ¡ } |  ddgddg¡}|  |¡ | jj}|  g g ¡}| jj|ks)J ‚d S )Nr   r   )r$   ÚfigureÚaxesÚscatterr&   ÚdataLimÚbounds)r,   r*   rp   r.   r.   r/   Útest_add_collection'  s   
rq   Zmpl20Zpng)Ú
extensionsc                 C   s   g d¢}g d¢}t  ||¡\}}| ¡ }| ¡ }|  ¡ }| d¡ | d¡ d|_| ||¡ | ¡ }| d¡ | d¡ |j||ddd d S )N)g¥+ócÒ>gë®`8F×>gq[€;uÝ>gƒy7½/¤â>gÖÿ9Ì—ç>gWÇ!Üí>gÄ-–Iåò>g\p5ê÷>gd‘jDþ>g—y¹´K'?gÈ~Í+»=?gFEAL ®?g|™0j?gÇ÷GKe’?gÞ´=B?)r   çš™™™™™¹?g²ï§ÆKÇ?gsh‘í|?Õ?g‡ÙÎ÷Sã?gš™™™™™ñ?r   g…ëQ¸@gÂõ(\@g333333(@g      6@gÍÌÌÌÌÌC@g33333ÓQ@Úlogr   ÚoÚ )ÚmarkerÚls)	r"   ÚmeshgridÚflattenr%   Z
set_xscaleZ
set_yscaleZmarginsrn   Zplot)Úfig_testÚfig_refZx_valsZy_valsÚxÚyZax_testZax_refr.   r.   r/   Útest_collection_log_datalim3  s   



r   c                  C   sä   t  ¡ } t d¡t d¡}}t ddd¡ dd¡ }}t  ||||¡}| | j¡j	dks/J ‚t  
¡  t  ¡ } t ddd¡}t dd	d¡}t ||¡\}}t ¡  d
d¡| j }t j||t |¡t |¡|d | jj	dkspJ ‚d S )Né   é
   r   éP   )r   r   g      @g      "@éûÿÿÿrN   éþÿÿÿé   é   é    ©Ú	transform)g      4@g      >@g      .@rT   )r$   rm   r"   ÚarangeÚlinspaceÚreshapeZquiverrf   Ú	transDatarp   rl   ry   rg   ÚAffine2DÚ	translateÚsinÚcosro   )r,   r}   r~   ÚuÚvÚqÚtransr.   r.   r/   Útest_quiver_limitsM  s    r–   c                  C   s€   t  ¡ } t ddd¡}t ddd¡}t ||¡\}}t ¡  dd¡| j }t j	||t 
|¡t |¡|d t| jjd	d
d d S )Nrƒ   r   rN   r„   r…   r†   r‡   rˆ   )rN   é   rM   é   r   ©Údecimal)r$   rm   r"   r‹   ry   rg   rŽ   r   r   Zbarbsr   r‘   r   ro   rp   )r,   r}   r~   r•   r.   r.   r/   Útest_barb_limits^  s    

ÿr›   z EllipseCollection_test_image.pngT)Úremove_textc               	   C   sž   t  ¡ \} }t d¡}t d¡}t ||¡\}}t | ¡ | ¡ f¡j}||d  }||d  }t |¡d }	t	j
|||	d||jdd}
| |
¡ | ¡  d S )Nr…   é   r    rN   r}   r\   )ÚunitsÚoffsetsÚtransOffsetÚ
facecolors)r$   r%   r"   rŠ   ry   ZvstackÚravelÚTZ	ones_likerd   ÚEllipseCollectionr   r&   Úautoscale_view)r+   r,   r}   r~   ÚXÚYZXYZwwZhhÚaaÚecr.   r.   r/   Útest_EllipseCollectionl  s    


ü
rª   zpolycollection_close.pngc                  C   sL  ddl m}  ddgddgddgddggddgddgddgddggddgddgddgddggddgddgddgddggg}t ¡ }| | |dd	¡}g d
¢}ttdƒƒ}tj|t	|ƒ dd}| 
d¡ g }g }t||ƒD ]\}	}
| |	gt	|ƒ ¡ | |
gt	|ƒ ¡ ql| |¡ |j||dd | dd¡ | dd¡ | dd¡ d S )Nr   )ÚAxes3Dr   r   r   r   ç      @F)Zauto_add_to_figure)ÚrÚgÚbr~   ÚkrU   g      Ð?©r   gffffffæ?r~   )ÚzsZzdirr…   r   )Zmpl_toolkits.mplot3dr«   r$   rl   Zadd_axesÚlistÚrangerd   r	   ÚlenÚ	set_alphaÚzipÚextendrZ   Zadd_collection3dZ
set_xlim3dZ
set_zlim3dZ
set_ylim3d)r«   Z	vertsQuadr+   r,   ÚcolorsZzposZpolyr²   ÚcsÚzÚcr.   r.   r/   Útest_polycollection_close‚  s0   üÿ

r½   z regularpolycollection_rotate.pngc            	      C   sš   t jd d…d d…f \} }t  |  ¡ | ¡ g¡}t  ddt j t|ƒ¡}t ¡ \}}t	||ƒD ]\}}t
jdd||g|jd}|j|dd q/| ¡  d S )	Nr   r   r   r…   )éd   )ÚsizesÚrotationrŸ   r    T©Zautolim)r"   ZmgridZ	transposerz   r‹   Úpirµ   r$   r%   r·   rd   ÚRegularPolyCollectionr   r&   r¥   )	ÚxxÚyyZ	xy_pointsZ	rotationsr+   r,   ÚxyÚalpharj   r.   r.   r/   Ú!test_regularpolycollection_rotate§  s   þrÈ   zregularpolycollection_scale.pngc                  C   s`   G dd„ dt jƒ} t ¡ \}}dg}tjd g}| |||jd}|j|dd | g d¢¡ d S )	Nc                       s$   e Zd Z‡ fdd„Zdd„ Z‡  ZS )z:test_regularpolycollection_scale.<locals>.SquareCollectionc                    s    t ƒ jddtjd i|¤Ž d S )Nr…   rÀ   r¬   )r…   )ÚsuperÚ__init__r"   rÂ   )ÚselfÚkwargs©Ú	__class__r.   r/   rÊ   »  s    zCtest_regularpolycollection_scale.<locals>.SquareCollection.__init__c                 S   sJ   | j }d|jj }||jj |jj }||jj |jj }t ¡  	||¡S )z4Return transform scaling circle areas to data space.g      R@)
rm   rl   ÚdpiZbboxÚwidthZviewLimÚheightrg   rŽ   Úscale)rË   r,   Z
pts2pixelsZscale_xZscale_yr.   r.   r/   Úget_transform¾  s
   zHtest_regularpolycollection_scale.<locals>.SquareCollection.get_transform)Ú__name__Ú
__module__Ú__qualname__rÊ   rÓ   Ú__classcell__r.   r.   rÍ   r/   ÚSquareCollectionº  s    rØ   )r   r   r   )r¿   rŸ   r    TrÁ   )r    r   r    r   )	rd   rÃ   r$   r%   r"   rÂ   r   r&   Úaxis)rØ   r+   r,   rÆ   Zcircle_areasZsquaresr.   r.   r/   Ú test_regularpolycollection_scale¶  s   ÿrÚ   c                  C   sn   t  ¡ \} }|jdgdgdgdd}| jt ¡ | jd tddd}| |¡\}}|s-J ‚t	|d	 dgƒ d S )
Nr   iè  T)Zpicker)rÏ   iE  éð   )r}   r~   Zind)
r$   r%   rn   ZsavefigÚioÚBytesIOrÏ   r   Úcontainsr   )r+   r,   rj   Zmouse_eventÚfoundÚindicesr.   r.   r/   Útest_pickingÓ  s   rá   c                   C   s,   t jg d¢g d¢dddgfd t  ¡  d S )N©r   r   r   r   r   )r   )r$   rn   Údrawr.   r.   r.   r/   Útest_linestyle_single_dashesÝ  s    rä   zsize_in_xy.pngc                  C   s`   t  ¡ \} }d\}}}d}ddg}tj|||d||jd}| |¡ | dd¡ | dd¡ d S )N)©r   r   r   r   rå   )rM   rM   rÆ   )rž   rŸ   r    r   r—   )r$   r%   rd   r¤   r   r&   r(   r)   )r+   r,   ZwidthsZheightsZanglesÚcoordsÚer.   r.   r/   Útest_size_in_xyâ  s   
ü
rè   c                 C   sŠ   g d¢}| j g d¢|d }}| j g d¢|d}| j g d¢|d}| j g d¢|d}t|d t|d t|d	 t|d
 t|d d S )N)é   é   é   )ÚredZblueZgreen)Úindex©r   r   r   )r   rS   Zdashdot)TFT)Ú
edgecolors)r¡   )Ú
linewidths)Z
linestyles)Zantialiaseds)ZSeriesr   )Úpdrí   r©   ZfcZlwrx   r¨   r.   r.   r/   Útest_pandas_indexingõ  s   



rò   Údefaultc                  C   s”   t  g ¡} |  ddg¡ |  g d¢¡ |  ¡ dgd ksJ ‚|  ¡ g d¢d ks*J ‚|  g d¢¡ |  ¡ dgd ks<J ‚|  ¡ g d¢k ¡ sHJ ‚d S )Nú-rî   r1   r˜   r   )rô   rô   rô   r   )rd   re   Zset_linestylesZset_linewidthsZget_linestylesZget_linewidthsÚall©rj   r.   r.   r/   Útest_lslw_bcast  s   
r÷   c                  C   ó<   t jg dd} |  ¡ dksJ ‚|  d¡ |  ¡ dksJ ‚d S )NÚround)ZcapstyleZbutt)rd   re   Zget_capstyleÚset_capstylerö   r.   r.   r/   Útest_capstyle  ó   
rû   c                  C   rø   )Nrù   )Z	joinstyleÚmiter)rd   re   Zget_joinstyleÚset_joinstylerö   r.   r.   r/   Útest_joinstyle  rü   rÿ   zcap_and_joinstyle.pngc                  C   sÎ   t  ¡ \} }| ddg¡ | ddg¡ t g d¢¡}t dgdgdgg¡t g d¢g¡ }t d	¡}||d d …d d …d
f< ||d d …d d …df< t|g d¢d}| d¡ | 	d¡ | 
|¡ | d¡ d S )Ng      à¿g      ø?ç      @)r   r   r   r   r   r   )r   r   r   )r   r   r   r   r   )r   rM   rN   r±   rù   rý   z2Line collection with customized caps and joinstyle)r$   r%   r(   r)   r"   r#   Zzerosr   rú   rþ   r&   r'   )r+   r,   r}   ZysZsegsZline_segmentsr.   r.   r/   Útest_cap_and_joinstyle_image$  s   &



r  zscatter_post_alpha.png)rœ   Ústylec                  C   s6   t  ¡ \} }|jtdƒtdƒtdƒd}| d¡ d S )NrU   ©r¼   rs   )r$   r%   rn   r´   r¶   )r+   r,   Úscr.   r.   r/   Útest_scatter_post_alpha8  s   r  c                  C   sŒ  t  d¡} | d }t d¡\}\}}|j| | | |d}|j| | | d}| |¡ t ¡  t| ¡ d d …df |ƒ t| ¡ d d …df |ƒ t d¡\}\}}|j| | g d¢|d}|j| | d|d}t ¡  t| ¡ d d …df |ƒ t| ¡ d d …df |ƒ t d¡\}\}}|j| | g d¢d	}| |¡ |j| | dd	}| |¡ t ¡  t| ¡ d d …df |ƒ t| ¡ d d …df |ƒ d S )
NrU   r   )r¼   rÇ   r  r    )r­   r®   r¯   r¼   Úm)r   rÇ   r­   )r   )	r"   rŠ   r$   r%   rn   r¶   rã   r   Úget_facecolors)r}   rÇ   r+   Úax0Úax1Zsc0Zsc1r.   r.   r/   Útest_scatter_alpha_array@  s.   



r
  c               	   C   s~  t j d¡ t j dd¡\} }t j d¡}t jjdddd}t jjdddd}t ¡ \}}|j| |||dd	dd
}|jdd\}}t	|ƒdksIJ ‚t
t  |¡ t¡t  d¡ƒ t  dd„ |D ƒ¡}	| t  d¡d ¡}
t
|	|
ƒ |j||dd}|jdd\}}t	|ƒdksˆJ ‚|j||dd}|jdddd\}}t  dd„ |D ƒ¡}t
|dƒ t  dd„ |D ƒ¡}t
|dƒ |j||dd}|jddddd„ d\}}dd„ |D ƒ}t  t  |¡ t¡d ¡}t||ƒ |j||dd}tjjdd g d!¢d"}|j|d\}}t	|ƒt	|ƒksJ ‚g d#¢}|j|ddd$\}}t
t  |¡ t¡|dd … ƒ ||||fD ]}| |¡ q/|j ¡  d S )%Né!N,r   r   r   rU   )Úsizei,  Zjetru   )r¼   ÚsÚcmaprw   rð   z{x:g})Úfmtc                 S   ó   g | ]}|  ¡ ‘qS r.   )r9   ©Ú.0Úliner.   r.   r/   Ú
<listcomp>j  ó    z7test_pathcollection_legend_elements.<locals>.<listcomp>r…   r   )Úlocé	   )Únumr¿   r   rì   )rW   rÇ   r   c                 S   r  r.   )Z	get_alphar  r.   r.   r/   r  t  r  c                 S   r  r.   )Zget_markerfacecolorr  r.   r.   r/   r  v  r  z{x:.2f}c                 S   s   d|  S )Nr   r.   )r}   r.   r.   r/   Ú<lambda>{  ó    z5test_pathcollection_legend_elements.<locals>.<lambda>)rW   r  r  Úfuncc                 S   r  r.   ©Zget_markersizer  r.   r.   r/   r  |  r  r   r€   )r   r   r   r   rU   r˜   r€   r   )ZnbinsZmin_n_ticksZsteps)r    r   g33333³K@i  )r  rW   r  )r"   ÚrandomÚseedZrandZrandintr$   r%   rn   Úlegend_elementsrµ   r   r#   ZastypeÚfloatrŠ   r  ZlegendZsqrtr   ÚmplZtickerZMaxNLocatorZ
add_artistÚcanvasrã   )r}   r~   r¼   r  r+   r,   r  ÚhÚlr¹   Zcolors2Úl1Zh2Zlab2Úl2rÇ   r   Úl3ZactsizesZlabeledsizesÚl4r  Zh5Zlab5ZlevelsZh6Zlab6r.   r.   r/   Ú#test_pathcollection_legend_elements]  sR   




ÿ

ÿr)  c                  C   s2   t  g d¢¡} t| ƒ}t j | t  g d¢¡¡ d S )N)r   r   r   r   )r"   r#   r   r3   r   )Zarrr*   r.   r.   r/   Útest_EventCollection_nosort  s   r*  c                  C   s  t jdt jd ddd¡} t| ƒ}tt| ƒƒ}t|jƒt|jƒks#J ‚t|j|jƒD ]\}}t  	|j
|j
¡s8J ‚t  	|j|j¡sBJ ‚q*t jdtd}dd„ | D ƒ|d d …< t|ƒ}t|jƒt|jƒkseJ ‚t|j|jƒD ]\}}t  	|j
|j
¡szJ ‚t  	|j|j¡s„J ‚qld S )Nr‚   )Zdtyper   r…   r   c                 S   s   g | ]}t d d„ |D ƒƒ‘qS )c                 s   s    | ]}t |ƒV  qd S rc   ©Útuple)r  r~   r.   r.   r/   Ú	<genexpr>¡  s   € z=test_collection_set_verts_array.<locals>.<listcomp>.<genexpr>r+  ©r  r}   r.   r.   r/   r  ¡  s    z3test_collection_set_verts_array.<locals>.<listcomp>)r"   rŠ   ZdoublerŒ   r	   r³   rµ   Z_pathsr·   Úarray_equalZ	_verticesZ_codesÚemptyÚobject)ZvertsZcol_arrZcol_listZapZlpZverts_tupleZcol_arr_tupleZatpr.   r.   r/   Útest_collection_set_verts_array—  s   þr2  c                  C   sx   g t dƒ¢} tƒ }| | ¡ tjtdd | d¡ W d   ƒ n1 s%w   Y  d| d< t | | ¡ ¡ 	¡ s:J ‚d S )Nr   z^Image data of dtype©ÚmatchZwrong_inputé-   rU   )
r´   r   Ú	set_arrayÚpytestÚraisesÚ	TypeErrorr"   Z	not_equalÚ	get_arrayÚany)Zvalsr¼   r.   r.   r/   Útest_collection_set_array©  s   
ÿr<  c                  C   sœ   g d¢} d}t  t  | d¡t  d|gt| ƒ¡g¡}| t| ƒddg¡}t ¡ \}}t 	|j
|j¡}| t||d¡ |jddd t j | ¡ d	d
g¡ d S )N)r   r   r…   çš™™™™™É?r   r   rˆ   TF)ZscalexZscaleyr   r¬   )r"   Zcolumn_stackÚrepeatÚtilerµ   rŒ   r$   r%   rg   Zblended_transform_factoryr   Z	transAxesr&   r   r¥   r3   Úassert_allcloseÚget_xlim)ÚarÑ   Zxy_pairsZ	line_segsÚfr,   r•   r.   r.   r/   Útest_blended_collection_autolim¹  s   &rD  c                  C   sH   t  ¡ \} }| dd¡ tj | ¡ ddg¡ tj | ¡ ddg¡ d S )Nr   g¸…ëQ¸®¿g¸…ëQ¸®?)r$   r%   rn   r"   r3   r@  Zget_ylimrA  )r+   r,   r.   r.   r/   Útest_singleton_autolimÇ  s   rE  zflat_ref, kwargsF)r   Z__initialization_delayed__rˆ   c                 C   s  ddl m} g d¢}g d¢}t ||¡\}}|d| 7 }tj||gdd}	|	jdks,J ‚t dd	d
¡ d	d¡}
|  ¡ }|j	ddd d|v rRt
 ¡  d¡|j |d< ||	fi |¤Ž}| |
¡ | |¡ |jdkskJ ‚| ¡ }|j	ddd d|v r†t
 ¡  d¡|j |d< t t¡ |dd	|r™|	 ¡  dd	¡n|	fi |¤Ž}W d   ƒ n1 sªw   Y  | |r·|
 ¡ n|
¡ | |¡ |jdksÆJ ‚d S )Nr   ©ÚQuadMesh©r   r   r   r   ©r   r   r   r=  r    ©rÙ   ©r   r…   r   r   r˜   r   ©r   rU   ©r   r…   ©ZxlimZylimr‰   g333333ó?Zflat)Úmatplotlib.collectionsrG  r"   ry   ÚstackÚshaper‹   rŒ   Úadd_subplotrV   rg   rŽ   rÒ   r   r6  r&   Z_shadingr7  Úwarnsr   Úcopyrz   )r{   r|   Zflat_refrÌ   rG  r}   r~   r¦   r§   ræ   ÚCr,   Úqmeshr.   r.   r/   Ú"test_quadmesh_deprecated_signatureÎ  s<   

ÿþÿ
rW  c                 C   s*  ddl m} g d¢}g d¢}t ||¡\}}|d| 7 }tj||gdd}|jdks,J ‚| ¡  dd	¡}t dd	d
¡ dd¡}	|  	¡ }
|
j
ddd ||ddd}| |	¡ |
 |¡ | 	¡ }
|
j
ddd t t¡ |dd	| ¡  dd	¡ddƒ}W d   ƒ n1 s„w   Y  | |	¡ |
 |¡ d S )Nr   rF  rH  rI  r=  r    rJ  rK  r   rê   r   r…   rL  rM  rN  FÚgouraud)r   Úshading)rO  rG  r"   ry   rP  rQ  rT  rŒ   r‹   rR  rV   r6  r&   r7  rS  r   )r{   r|   rG  r}   r~   r¦   r§   ræ   Zcoords_flatrU  r,   rV  r.   r.   r/   Ú#test_quadmesh_deprecated_positionalù  s.   

ÿÿ
rZ  c                  C   s<  t  d¡} t  d¡}t j d¡}t ¡ \}}| | ||¡}t t¡ | 	| 
dd¡¡ W d   ƒ n1 s6w   Y  t  d¡ 
d¡}tjtdd	 | 	|¡ W d   ƒ n1 sZw   Y  tjtd
d	 | 	| ¡ ¡ W d   ƒ n1 sxw   Y  t  d¡} t  d¡}t j d¡}t ¡ \}}|j| ||dd}d S )Nré   r€   )é   r   r   r[  é6   )r˜   r  zFDimensions of A \(6, 9\) are incompatible with X \(11\) and/or Y \(8\)r3  zEDimensions of A \(54,\) are incompatible with X \(11\) and/or Y \(8\)rX  ©rY  )r"   rŠ   r  r$   r%   Ú
pcolormeshr7  rS  r   r6  rŒ   r8  r9  r¢   ©r}   r~   r»   r+   r,   r*   r.   r.   r/   Ú"test_quadmesh_set_array_validation  s(   

ÿþþ

r`  c                  C   s`   g d¢} g d¢}t jdd}t  | |¡\}}t |||¡}t  |j|jg¡j}t| ¡ |ƒ d S )Nrâ   )r   r…   r˜   )r   r   )rQ  )	r"   Úonesry   r$   r^  rP  r£   r   Zget_coordinates)r}   r~   r»   rÄ   rÅ   r*   ræ   r.   r.   r/   Útest_quadmesh_get_coordinates2  s   rb  c                  C   s8  t  d¡} t  d¡}t  d¡ d¡}t ¡ \}}| | |t  |j¡¡}| |¡ |j	 
¡  t  | ¡ |¡s7J ‚| t  d¡¡ |j	 
¡  t  | ¡ t  d¡¡sQJ ‚t  d¡ d¡}t ¡ \}}|j| |t  |j¡dd}| |¡ |j	 
¡  t  | ¡ |¡s€J ‚| t  d¡¡ |j	 
¡  t  | ¡ t  d¡¡sšJ ‚d S )Nr…   r  ©r   r   é   )r…   r…   rX  r]  )r"   rŠ   rŒ   r$   r%   r^  ra  rQ  r6  r"  rã   r/  r:  r_  r.   r.   r/   Útest_quadmesh_set_array>  s(   







re  c                  C   s°   t  ¡ \} }tj d¡}tjjddd}|jdgg||d}| j 	¡  t
 | ¡ dd d …f ||dƒƒ¡s7J ‚d\|_|_| j 	¡  t
 | ¡ dd d …f ||dƒƒ¡sVJ ‚d S )NZplasmar   r   )ÚvminÚvmax)r  Únorm)r   r   )r$   r%   r!  ÚcmÚget_cmapr¹   Z	Normalizer^  r"  rã   r"   r/  r  rf  rg  )r+   r,   r  rh  r*   r.   r.   r/   Útest_quadmesh_vmin_vmax\  s   
(
,rk  c            
      C   s,  t  d¡} t  d¡}t  d¡ d¡}|| ¡  }| ¡ }t d¡\}\}}|j| |||d}| | ||¡}	|	 |¡ t 	¡  t
| ¡ d d …df |ƒ t
|	 ¡ d d …df |ƒ t d¡\}\}}|j| |||d}| | ||¡}	|	 |¡ t 	¡  t
| ¡ d d …df |ƒ t
|	 ¡ d d …df |ƒ d S )Nr…   r  rc  r   )rÇ   r    )r"   rŠ   rŒ   Úmaxr¢   r$   r%   r^  r¶   rã   r   r  )
r}   r~   r»   rÇ   Z
alpha_flatr+   r  r	  Zcoll1Zcoll2r.   r.   r/   Útest_quadmesh_alpha_arrayl  s&   



rm  c                  C   sl   t  ¡ \} }| t d¡ d¡¡}tjtdd | 	ddg¡ | 
¡  W d   ƒ d S 1 s/w   Y  d S )Nrê   )r   r…   z^Data array shaper3  r   ç333333ã?)r$   r%   r^  r"   rŠ   rŒ   r7  r8  r_   r¶   Úupdate_scalarmappable)r+   r,   Úpcr.   r.   r/   Útest_alpha_validation„  s   
"þrq  c                  C   s¦   t j d¡ t j d¡} t j d¡}dt j d¡ }d| }g d¢}t ¡ \}}|j| ||d}|jd|dd	„ d
\}}	dd„ |D ƒ}
dd„ |
D ƒ}
t|
|dd dS )z|
    Ensure legend markers scale appropriately when label and size are
    inversely related.
    Here label = 5 / size
    r  é2   r   rU   )r=  gš™™™™™Ù?rn  gš™™™™™é?©r  r¿   c                 S   s   d|  S )NrU   r.   rs  r.   r.   r/   r  ž  r  z=test_legend_inverse_size_label_relationship.<locals>.<lambda>)rW   r  r  c                 S   r  r.   r  r.  r.   r.   r/   r  ¢  r  z?test_legend_inverse_size_label_relationship.<locals>.<listcomp>c                 S   s   g | ]}d |d  ‘qS )rU   r   r.   r.  r.   r.   r/   r  £  s    r™   N)r"   r  r  r$   r%   rn   r  r   )r¦   r§   rU  ÚSZlegend_sizesr+   r,   r  ZhandlesÚlabelsZhandle_sizesr.   r.   r/   Ú+test_legend_inverse_size_label_relationship  s   

ÿrv  Úpcfuncc                 C   s^  t  d¡ dd¡}| |ddd}| ¡  t | ¡ ¡}| ¡ | | 	¡ ¡ƒ}t 
| ¡ d¡s0J ‚| |ƒ}| d¡ | d¡ | ¡  t 
| ¡ d¡sLJ ‚t 
| ¡ g d¢g¡sYJ ‚| d¡ | ¡  t 
| ¡ g d	¢g¡soJ ‚| d ¡ | ¡  t 
| ¡ g d¢g¡s…J ‚| d ¡ | ¡  t 
| ¡ |¡s˜J ‚| d ¡ | ¡  t 
| ¡ |¡s«J ‚t 
| ¡ d¡sµJ ‚| d ¡ | ¡  t 
| ¡ d¡sÈJ ‚t 
| ¡ |¡sÒJ ‚| | 	¡ ¡ | ¡  t 
| ¡ |¡sçJ ‚t 
| ¡ d¡sñJ ‚| |d
dd}| ¡  t 
| ¡ |¡sJ ‚t 
| ¡ g d¢g¡sJ ‚| |d
t  d¡d}| ¡  t 
| ¡ |¡s.J ‚t 
| ¡ g d¢g¡s<J ‚| d ¡ | ¡  t 
| ¡ t  d¡¡sSJ ‚t 
| ¡ g d¢g¡saJ ‚| |d
t  d¡d}| ¡  t 
| ¡ |¡szJ ‚t 
| ¡ g d¢g¡sˆJ ‚| d ¡ | ¡  t 
| ¡ t  d¡¡sŸJ ‚t 
| ¡ g d¢g¡s­J ‚d S )Nrê   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Œ   ro  ÚmcolorsZto_rgba_arrayZ_get_default_facecolorrj  rh  r¢   Ú
same_colorÚget_edgecolorZset_facecolorZset_edgecolorÚget_facecolorr¶   r6  ra  )rw  r»   rp  Zface_defaultZmappedr.   r.   r/   Útest_color_logic¨  sj   








 r|  c                  C   s¶   t  t¡< td dddg d¢d} |  ¡ d dksJ ‚t |  ¡ d¡s%J ‚|  ¡ dks-J ‚t |  	¡ g d¢g¡s:J ‚W d   ƒ n1 sDw   Y  td d d} t |  	¡ d¡sYJ ‚d S )	Ngš™™™™™@r­   r   )r   r   r   r   )Zzorderr¡   r   )Z	facecolorr\   )
r7  rS  r   r   Zget_linewidthrx  ry  rz  Z
get_zorderr{  )Úlcr.   r.   r/   Útest_LineCollection_argsî  s   û	r~  c                  C   s|   t  d¡ dd¡} t | ¡}tjtdd | | ¡ | 	¡  W d   ƒ n1 s)w   Y  t 
| ¡}| | ¡ | 	¡  d S )Nrê   r   r…   z^Collections can only mapr3  )r"   rŠ   rŒ   r$   Úpcolorr7  r8  r_   r6  ro  r^  )r»   rp  r.   r.   r/   Útest_array_wrong_dimensionsü  s   


þ

r€  c                  C   s°   t  ¡ \} }| t d¡d dt d¡d  ¡^ }}|j ddg¡\}}td| j||ƒ}| 	|¡dks6J ‚dD ]}|j d	dg¡\}}td| j||ƒ}| 	|¡d u sUJ ‚q8d S )
Nré   r   r¾   r   ée   Zmotion_notify_eventr…   r.   r    )
r$   r%   Zhist2dr"   rŠ   r   r‰   r   r"  Zget_cursor_data)r+   r,   r;   Zqmr}   r~   ZeventZ
out_xydatar.   r.   r/   Útest_quadmesh_cursor_data  s   
ÿýr‚  c                  C   sB   t  t  ddd¡d¡j} t| gƒ}| ¡ \}t  | |k¡sJ ‚d S )Nr   r   é   )r   r   )r"   r?  r‹   r£   r   r]   rõ   )ra   r}  Zreadbackr.   r.   r/   Útest_get_segments  s   

r„  c                  C   s~   t  ¡ } dg}tj|d}tj|dd}tj|d}| d¡ | | ¡j}| | ¡j}| | ¡j}||ks7J ‚||ks=J ‚d S )Nr   )r¿   rå   )r¿   rŸ   )rg   rh   rd   ZCircleCollectionÚset_offsetsrf   rp   )Úidentityr¿   ri   ÚinitÚlateZnull_boundsZinit_boundsZlate_boundsr.   r.   r/   Útest_set_offsets_late  s   
r‰  c                  C   sœ   t jtdd tjg t ¡ d W d   ƒ n1 sw   Y  t ¡  dd¡} tjg g | d}t g ¡}| 	| ¡ | | 
¡   krI| 
¡ ksLJ ‚ J ‚d S )Nz-.transOffset. without .offsets. has no effectr3  )r    r   )rŸ   r    )r7  rS  r   rd   r   rg   rh   rŽ   ÚskewZset_offset_transformZget_offset_transform)rŠ  r‡  rˆ  r.   r.   r/   Útest_set_offset_transform2  s   ÿÿþ

(r‹  c                  C   s¶   t  ddd¡} t  | ¡}| t  dd¡ t  d¡ }t ||¡}| ¡ }| t	t
||ƒƒ¡ t j || ¡ ¡ t ¡ \}}| ||¡}| ¡ }| t	t
||ƒƒ¡ t j || ¡ ¡ d S )Nr   r   rU   é   r#  z
2021-11-29)r"   r‹   r   Ztimedelta64Z
datetime64r$   rn   Zget_offsetsr…  r³   r·   r3   r@  r%   )r}   r~   Údr  Zoff0r+   r,   r.   r.   r/   Útest_set_offset_unitsA  s   
rŽ  )arÜ   Útypesr   Znumpyr"   Znumpy.testingr   r   r7  Z
matplotlibr!  Zmatplotlib.pyplotZpyplotr$   Zmatplotlib.backend_basesr   rO  Úcollectionsrd   Zmatplotlib.colorsr¹   rx  Zmatplotlib.transformsZ
transformsrg   r   r   r   r	   Zmatplotlib.testing.decoratorsr
   r   Zmatplotlib._api.deprecationr   r0   r<   rB   rE   rF   rG   rJ   rK   rL   rO   rQ   rY   r[   r2   rk   rq   r  Úcontextr   r–   r›   rª   r½   rÈ   rÚ   rá   rä   rè   rò   r÷   rû   rÿ   r  r  r
  r)  r*  r2  r<  rD  rE  ZmarkZparametrizeÚdictrW  rZ  r`  rb  re  rk  rm  rq  rv  r  r^  r|  r~  r€  r‚  r„  r‰  r‹  rŽ  r.   r.   r.   r/   Ú<module>   sÔ    (












	



$










ÿ
3ü

$
	
D	