a
    s=ic±¡  ã                
   @   s0  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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,„ ƒZ0d-d.„ Z1d/d0„ Z2d1d2„ Z3d3d4„ Z4e
j5 6d5¡e d6gd7d8d9„ ƒƒZ7d:d;„ Z8d<d=„ Z9e!d>gd?d@dAdB„ ƒZ:e!dCgd?d@dDdE„ ƒZ;e!dFgd?d@dGdH„ ƒZ<e!dIgd?d@dJdK„ ƒZ=dLdM„ Z>dNdO„ Z?dPdQ„ Z@dRdS„ ZAdTdU„ ZBdVdW„ ZCe!dXgd?d@dYdZ„ ƒZDd[d\„ ZEe
j5 6d]¡d^d_„ ƒZFe
j5 6d]¡d`da„ ƒZGe
j5 6d]¡dbdc„ ƒZHe!ddgƒdedf„ ƒZIe!dggd?d]dhdidj„ ƒZJdkdl„ ZKdmdn„ ZLdodp„ ZMdqdr„ ZNdsdt„ ZOdudv„ ZPdwdx„ ZQejR Sdydzd{g¡d|d}„ ƒZTejR Sd~d?i fdi fd?eUdd€fdeUdd‚fg¡e d6gd7dƒd„„ ƒƒZVe d6gd7d…d†„ ƒZWd‡dˆ„ ZXd‰dŠ„ ZYd‹dŒ„ ZZddŽ„ Z[dd„ Z\d‘d’„ Z]d“d”„ Z^e
j5 6d]¡ejR Sd•ej_ej`g¡d–d—„ ƒƒZad˜d™„ Zbdšd›„ Zcdœd„ ZddždŸ„ Zed d¡„ Zfd¢d£„ ZgdS )¤é    N)ÚSimpleNamespace)Úassert_array_equalÚassert_array_almost_equal)Ú
CollectionÚLineCollectionÚEventCollectionÚPolyCollectionÚQuadMesh)Ú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.   úr/home/droni/.local/share/virtualenvs/DPS-5Je3_V2c/lib/python3.9/site-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sVJ ‚| ¡ sbJ ‚|d | ¡ ksvJ ‚|d | 	¡ ksŠJ ‚| 
¡ dgksœJ ‚| ¡ g| ¡ ¢D ]}tj ||d ¡ q®d 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_positionsW   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_positionse   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_positionsw   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 ‚| ¡ r4J ‚| ¡ }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s8J ‚| ¡ sDJ ‚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 ‚| ¡ r6J ‚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 ]N\} }}t ƒ \}}}|jf i | |i¤Ž t || ¡|ksXJ ‚| d| › ¡ qd S )Nr   Údashed)r   )ç      @rT   )r   é   rU   zEventCollection: set_)r0   Úsetr$   Zgetpr'   )ÚpropÚvalueÚexpectedr@   r*   r;   r.   r.   r/   Útest__EventCollection__set_propì   s    

ýrZ   ZEventCollection_plot__set_colorc                  C   sX   t ƒ \} }}t g d¢¡}| |¡ | ¡ g| ¡ ¢D ]}tj ||¡ q6|  d¡ d S )N)r   r   r   r   zEventCollection: set_color)	r0   r"   r#   Ú	set_colorr9   r:   r3   r   r'   )r@   r*   r;   Ú	new_colorr   r.   r.   r/   Ú test__EventCollection__set_colorý   s    
r]   c           
      C   sÎ   |   ¡ }| ¡ dks(| ¡ dks(|du r2d}d}n| ¡ dkrHd}d}ntdƒ‚t|ƒD ]p\}}	|	d|f ||d  ks|J ‚|	d|f ||d  ks˜J ‚|	d|f || ks°J ‚|	d|f || ksXJ ‚qXd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pos1Úpos2ÚiÚsegmentr.   r.   r/   r2     s"    
ÿÿr2   c                  C   s4   t  g ¡} |  t ¡ ¡}t| ¡ tj ¡  ¡ ƒ d S ©N)	ÚmcollectionsÚPathCollectionÚget_datalimÚmtransformsÚIdentityTransformr   Ú
get_pointsÚBboxÚnull)ÚcolZcol_data_limr.   r.   r/   Útest_null_collection_datalim!  s
    
ÿrq   c                  C   sR   t  ¡ } t t ddg¡g¡}|  |¡ | t 	¡ ¡}t
| ¡ tj ¡  ¡ ƒ d S )N©r   r   )r   r   )r$   Úaxesrh   ri   ÚmpathÚPathr&   rj   rk   rl   r   rm   rn   ro   )r,   r*   Zcoll_data_limr.   r.   r/   Útest_no_offsets_datalim(  s    
ÿrv   c                  C   sL   t  ¡  t  ¡ } |  ddgddg¡ | jj}|  g g ¡ | jj|ksHJ ‚d S )Nr   r   )r$   Úfigurers   ÚscatterÚdataLimÚbounds)r,   rz   r.   r.   r/   Útest_add_collection3  s    r{   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marginsrx   Zplot)Úfig_testÚfig_refZx_valsZy_valsÚxÚyZax_testZax_refr.   r.   r/   Útest_collection_log_datalim>  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sàJ ‚d S )Né   é
   r   éP   )r   r   g      @g      "@éûÿÿÿrN   éþÿÿÿé   é   é    ©Ú	transform)g      4@g      >@g      .@rT   )r$   rs   r"   ÚarangeÚlinspaceÚreshapeZquiverrj   Ú	transDatarz   rw   rƒ   rk   ÚAffine2DÚ	translateÚsinÚcosry   )r,   r‡   rˆ   ÚuÚvÚqÚtransr.   r.   r/   Útest_quiver_limitsX  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$   rs   r"   r•   rƒ   rk   r˜   r™   r—   Zbarbsrš   r›   r   ry   rz   )r,   r‡   rˆ   rŸ   r.   r.   r/   Útest_barb_limitsi  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Úoffset_transformÚ
facecolors)r$   r%   r"   r”   rƒ   ZvstackÚravelÚTZ	ones_likerh   ÚEllipseCollectionr—   r&   Úautoscale_view)r+   r,   r‡   rˆ   ÚXÚYZXYZwwÚhhÚaaÚecr.   r.   r/   Útest_EllipseCollectionw  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 ]0\}	}
| |	gt	|ƒ ¡ | |
gt	|ƒ ¡ qØ| |¡ |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   ç      Ð?©r   gffffffæ?rˆ   )ÚzsZzdirr   r§   )Zmpl_toolkits.mplot3dr¶   r$   rw   Zadd_axesÚlistÚrangerh   r   ÚlenÚ	set_alphaÚzipÚextendr[   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	transposer„   r•   ÚpirÁ   r$   r%   rÃ   rh   ÚRegularPolyCollectionr—   r&   r¯   )	ÚxxÚyyZ	xy_pointsZ	rotationsr+   r,   ÚxyÚalpharp   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@)
rs   rw   ÚdpiZbboxÚwidthZviewLimÚheightrk   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ä   rr   r   )rË   r©   rª   TrÍ   )r    r   r    r   )	rh   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}| |¡\}}|sZJ ‚t	|d	 dgƒ d S )
Nr   iè  T)Zpicker)rÛ   iE  éð   )r‡   rˆ   Úind)
r$   r%   rx   ZsavefigÚioÚBytesIOrÛ   r   Úcontainsr   )r+   r,   rp   Úmouse_eventÚfoundÚindicesr.   r.   r/   Útest_pickingÜ  s    rï   c                  C   sô   t  d¡} | d d …d f | d d d …f  }t ¡ \}}| |¡}| ¡  d\}}| ¡  ||f¡\} }t||| |d}| 	|¡\}	}
|	sŒJ ‚t
|
d dgƒ d\}}| ¡  ||f¡\} }t||| |d}| 	|¡\}	}
|	sàJ ‚t
|
d dgƒ d S )Nr   ©r   r   ©ÚxdataÚydatar‡   rˆ   rè   r   ©ç      ø?rõ   rU   )r"   r”   r$   r%   Ú
pcolormeshÚdraw_without_renderingrß   r“   r   rë   r   )r‡   r°   r+   r,   Úmeshrò   ró   rˆ   rì   rí   rî   r.   r.   r/   Útest_quadmesh_containsæ  s"    
 
rù   c                  C   s¦   ddgddgg} ddgddgg}t  ¡ \}}| | |dgg¡}| ¡  g d¢}|D ]N}|\}}}	| ¡  ||f¡\} }t||| |d}
| |
¡\}}||	u sRJ ‚qRd S )Nr   r    r   ))ç      à¿r¼   T)r   r¼   F)r   r¼   T)r   g      Ð¿Trñ   )r$   r%   rö   r÷   rß   r“   r   rë   )r‡   rˆ   r+   r,   rø   ZpointsÚpointrò   ró   rY   rì   rí   rî   r.   r.   r/   Útest_quadmesh_contains_concaveü  s    
rü   c            	      C   s¶   t  d¡} | d d …d f | d d d …f  }t ¡ \}}| |¡}d |_| ¡  d\}}| ¡  ||f¡\} }t	||| |d}| 
|¡d u sŽJ ‚| t  |j¡¡ t| 
|¡dgƒ d S )Nr   rð   rñ   r   )r"   r”   r$   r%   rö   Z_Ar÷   rß   r“   r   Úget_cursor_dataÚ	set_arrayÚonesÚshaper   )	r‡   r°   r+   r,   rø   rò   ró   rˆ   rì   r.   r.   r/   Útest_quadmesh_cursor_data  s    
 
r  c                  C   sx   g d¢} t  ¡ \}}| | | t d¡¡}| ¡  d\}}| ¡  ||f¡\} }t||| |d}t	| 
|¡t d¡ƒ d S )N)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/   Ú)test_quadmesh_cursor_data_multiple_points%  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$   rx   Údrawr.   r.   r.   r/   Útest_linestyle_single_dashes1  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%   rh   r®   r—   r&   r(   r)   )r+   r,   ÚwidthsZheightsZanglesÚcoordsÚer.   r.   r/   Útest_size_in_xy6  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)é   é   é   )ÚredÚblueÚgreen)Úindex©r   r   r§   )r   rS   Zdashdot)TFT)Ú
edgecolors)r«   )Ú
linewidths)Z
linestyles)Zantialiaseds)ZSeriesr   )Úpdr  r´   ZfcZlwr‚   r³   r.   r.   r/   Útest_pandas_indexingG  s    



r  Údefaultc                  C   s”   t  g ¡} |  ddg¡ |  g d¢¡ |  ¡ dgd ks<J ‚|  ¡ g d¢d ksTJ ‚|  g d¢¡ |  ¡ dgd ksxJ ‚|  ¡ g d¢k ¡ sJ ‚d S )Nú-r  r1   r¢   r   )r  r  r  r§   )rh   ri   Zset_linestylesZset_linewidthsZget_linestylesZget_linewidthsÚall©rp   r.   r.   r/   Útest_lslw_bcastX  s    
r  c                  C   s<   t jg dd} |  ¡ dksJ ‚|  d¡ |  ¡ dks8J ‚d S )NÚround)ZcapstyleZbutt)rh   ri   Zget_capstyleÚset_capstyler  r.   r.   r/   Útest_capstylef  s    
r   c                  C   s<   t jg dd} |  ¡ dksJ ‚|  d¡ |  ¡ dks8J ‚d S )Nr  )Z	joinstyleÚmiter)rh   ri   Zget_joinstyleÚset_joinstyler  r.   r.   r/   Útest_joinstylen  s    
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 )Nrú   rõ   ç      @)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_imagev  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È   r}   )r$   r%   rx   rÀ   rÂ   )r+   r,   Úscr.   r.   r/   Útest_scatter_post_alphaŠ  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%   rx   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s’J ‚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jetr   )rÈ   ÚsÚcmapr   r  z{x:g})Úfmtc                 S   s   g | ]}|  ¡ ‘qS r.   )r9   ©Ú.0Úliner.   r.   r/   Ú
<listcomp>¼  ó    z7test_pathcollection_legend_elements.<locals>.<listcomp>r   r   )Úlocr  )ÚnumrË   r   r  )rW   rÓ   r   c                 S   s   g | ]}|  ¡ ‘qS r.   )Z	get_alphar4  r.   r.   r/   r7  Æ  r8  c                 S   s   g | ]}|  ¡ ‘qS r.   )Zget_markerfacecolorr4  r.   r.   r/   r7  È  r8  z{x:.2f}c                 S   s   d|  S )Nr   r.   )r‡   r.   r.   r/   Ú<lambda>Í  r8  z5test_pathcollection_legend_elements.<locals>.<lambda>)rW   r:  r3  Úfuncc                 S   s   g | ]}|  ¡ ‘qS r.   ©Zget_markersizer4  r.   r.   r/   r7  Î  r8  r§   rŠ   )r   r   r$  r§   rU   r¢   rŠ   r‹   )ZnbinsZmin_n_ticksZsteps)r    r   g33333³K@i  )r:  rW   r3  )r"   ÚrandomÚseedZrandÚrandintr$   r%   rx   Úlegend_elementsrÁ   r   r#   ZastypeÚfloatr”   r2  ÚlegendÚsqrtr   ÚmplZtickerZMaxNLocatorZ
add_artistÚcanvasr  )r‡   rˆ   rÈ   r1  r+   r,   r(  ÚhÚlrÅ   Zcolors2Úl1Zh2Zlab2Úl2rÓ   r   Úl3ZactsizesZlabeledsizesÚl4r9  Zh5Zlab5ÚlevelsZh6Zlab6r.   r.   r/   Ú#test_pathcollection_legend_elements¯  sR    



ÿ


ÿrN  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    rO  c                  C   s  t jdt jd ddd¡} t| ƒ}tt| ƒƒ}t|jƒt|jƒksFJ ‚t|j|jƒD ]0\}}t  	|j
|j
¡spJ ‚t  	|j|j¡sTJ ‚qTt jdtd}dd„ | D ƒ|d d …< t|ƒ}t|jƒt|jƒksÊJ ‚t|j|jƒD ]0\}}t  	|j
|j
¡sôJ ‚t  	|j|j¡sØJ ‚qØd S )NrŒ   )Zdtyper‹   r   r   c                 S   s   g | ]}t d d„ |D ƒƒ‘qS )c                 s   s   | ]}t |ƒV  qd S rg   ©Útuple)r5  rˆ   r.   r.   r/   Ú	<genexpr>ó  r8  z=test_collection_set_verts_array.<locals>.<listcomp>.<genexpr>rP  ©r5  r‡   r.   r.   r/   r7  ó  r8  z3test_collection_set_verts_array.<locals>.<listcomp>)r"   r”   Údoubler–   r   r¿   rÁ   Ú_pathsrÃ   Úarray_equalÚ	_verticesÚ_codesÚemptyÚobject)ZvertsZcol_arrZcol_listÚapZlpZverts_tupleZcol_arr_tupleZatpr.   r.   r/   Útest_collection_set_verts_arrayé  s    r\  c                  C   sx   g t dƒ¢} tƒ }| | ¡ tjtdd | d¡ W d   ƒ n1 sJ0    Y  d| d< t | | ¡ ¡ 	¡ stJ ‚d S )Nr‹   z^Image data of dtype©ÚmatchZwrong_inputé-   rU   )
rÀ   r   rþ   ÚpytestÚraisesÚ	TypeErrorr"   Ú	not_equalÚ	get_arrayÚany)ÚvalsrÈ   r.   r.   r/   Útest_collection_set_arrayû  s    
(rg  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%   rk   Zblended_transform_factoryr—   Ú	transAxesr&   r   r¯   r3   Úassert_allcloseÚget_xlim)ÚarÝ   Zxy_pairsZ	line_segsÚfr,   rŸ   r.   r.   r/   Útest_blended_collection_autolim  s    &rp  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%   rx   r"   r3   rl  Úget_ylimrm  )r+   r,   r.   r.   r/   Útest_singleton_autolim  s    rr  ztransform, expected)r—   )rú   g      @)rk  )gffffff@gš™™™™™	@c                 C   sV   t  ¡ \}}|jddt|| ƒd | dd¡ tj | ¡ |¡ tj | ¡ |¡ d S )Nr   r’   r§   )	r$   r%   rx   Úgetattrr"   r3   rl  rq  rm  )r“   rY   r+   r,   r.   r.   r/   Útest_autolim_with_zeros   s
    	rt  zflat_ref, kwargsF)r   Z__initialization_delayed__r’   c                 C   sŽ  g d¢}g d¢}t  ||¡\}}|d| 7 }t j||gdd}|jdksLJ ‚t  ddd	¡ dd
¡}	|  ¡ }
|
jddd d|v r˜t 	¡  
d¡|
j |d< t|fi |¤Ž}| |	¡ |
 |¡ |jdksÊJ ‚| ¡ }
|
jddd d|v rt 	¡  
d¡|
j |d< t t¡: td
d|r*| ¡  dd¡n|fi |¤Ž}W d   ƒ n1 sN0    Y  | |rj|	 ¡ n|	¡ |
 |¡ |jdksŠJ ‚d S )N©r   r   r   r   ©r   r   r   rh  r    ©rå   ©r§   r   r   r   r   r¢   r§   ©r   rU   ©r   r   ©ZxlimZylimr“   g333333ó?Zflat)r"   rƒ   Ústackr   r•   r–   Úadd_subplotrV   rk   r˜   rÞ   r—   r	   rþ   r&   Z_shadingr`  Úwarnsr   Úcopyr„   )r…   r†   Zflat_refrØ   r‡   rˆ   r°   r±   r
  ÚCr,   Úqmeshr.   r.   r/   Ú"test_quadmesh_deprecated_signature0  s8    


ÿþ&
r‚  c                 C   s  ddl m} g d¢}g d¢}t ||¡\}}|d| 7 }tj||gdd}|jdksXJ ‚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ø0    Y  |
 
|¡ |	 |
¡ d S )Nr   )r	   ru  rv  rh  r    rw  rx  r   r  r§   r   ry  rz  r{  FÚgouraud)r   Úshading)Úmatplotlib.collectionsr	   r"   rƒ   r|  r   r•   r–   r}  rV   rþ   r&   r`  r~  r   r  )r…   r†   r	   r‡   rˆ   r°   r±   r
  r€  r,   r  r.   r.   r/   Ú#test_quadmesh_deprecated_positionalY  s*    

ÿ"
r†  c                  C   s<  t  d¡} t  d¡}t j d¡}t ¡ \}}| | ||¡}t t¡" | 	| 
dd¡¡ W d   ƒ n1 sl0    Y  t  d¡ 
d¡}tjtdd	 | 	|¡ W d   ƒ n1 s´0    Y  tjtd
d	 | 	| ¡ ¡ W d   ƒ n1 sð0    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\)r]  zEDimensions of A \(54,\) are incompatible with X \(11\) and/or Y \(8\)rƒ  ©r„  )r"   r”   r>  r$   r%   rö   r`  r~  r   rþ   r–   ra  rb  r¬   ©r‡   rˆ   rÇ   r+   r,   r*   r.   r.   r/   Ú"test_quadmesh_set_array_validationw  s"    

0(,

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   )r   )	r"   rÿ   rƒ   r$   rö   r|  r­   r   Zget_coordinates)r‡   rˆ   rÇ   rÐ   rÑ   r*   r
  r.   r.   r/   Útest_quadmesh_get_coordinates‘  s    rŒ  c                  C   s<  t  d¡} t  d¡}t  d¡ d¡}t ¡ \}}| | |t  |j¡¡}| |¡ |j	 
¡  t  | ¡ |¡snJ ‚| t  d¡¡ |j	 
¡  t  | ¡ t  d¡¡s¢J ‚t  d¡ d¡}t ¡ \}}|j| |t  |j¡dd}| |¡ |j	 
¡  t  | ¡ |¡sJ ‚| t  d¡¡ |j	 
¡  t  | ¡ t  d¡¡s8J ‚d S )Nr   r  r  é   )r   r   rƒ  r‰  )r"   r”   r–   r$   r%   rö   rÿ   r   rþ   rF  r  rV  rd  rŠ  r.   r.   r/   Útest_quadmesh_set_array  s(    







rŽ  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ƒƒ¡slJ ‚d\|_|_| j ¡  t	 
| ¡ dd d …f ||dƒƒ¡sªJ ‚d S )NZplasmar   r   )ÚvminÚvmax)r2  Únorm)r   r   )r$   r%   rE  Z	colormapsrÅ   Z	Normalizerö   rF  r  r"   rV  r+  r  r  )r+   r,   r2  r‘  r*   r.   r.   r/   Útest_quadmesh_vmin_vmax»  s    

(
r’  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  r  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_arrayË  s&    



r”  c                  C   sj   t  ¡ \} }| t d¡ d¡¡}tjtdd& | 	ddg¡ | 
¡  W d   ƒ n1 s\0    Y  d S )Nr  )r§   r   z^Data array shaper]  r   ç333333ã?)r$   r%   rö   r"   r”   r–   r`  ra  ra   rÂ   Úupdate_scalarmappable)r+   r,   Úpcr.   r.   r/   Útest_alpha_validationã  s
    r˜  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   )rh  gš™™™™™Ù?r•  gš™™™™™é?©r1  rË   c                 S   s   d|  S )NrU   r.   rš  r.   r.   r/   r;  ý  r8  z=test_legend_inverse_size_label_relationship.<locals>.<lambda>)rW   r:  r<  c                 S   s   g | ]}|  ¡ ‘qS r.   r=  rS  r.   r.   r/   r7    r8  z?test_legend_inverse_size_label_relationship.<locals>.<listcomp>c                 S   s   g | ]}d |d  ‘qS )rU   r   r.   rS  r.   r.   r/   r7    r8  r£   N)r"   r>  r?  r$   r%   rx   rA  r   )r°   r±   r€  ÚSZlegend_sizesr+   r,   r(  ZhandlesÚlabelsZhandle_sizesr.   r.   r/   Ú+test_legend_inverse_size_label_relationshipì  s    
ÿ
r  Úpcfuncc                 C   sn  t  d¡ dd¡}| |ddd}| ¡  t | ¡ ¡}| ¡ | | 	¡ ¡ƒ}t 
| ¡ d¡s`J ‚| |ƒ}| d¡ | d¡ | ¡  t 
| ¡ d¡s˜J ‚t 
| ¡ g d¢g¡s²J ‚| d¡ | ¡  t 
| ¡ g d	¢g¡sÞJ ‚| d ¡ | ¡  t 
| ¡ g d¢g¡sJ ‚| d ¡ | ¡  t 
| ¡ |¡s4J ‚| d ¡ | ¡  t 
| ¡ |¡s\J ‚t 
| ¡ d¡srJ ‚| 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 
| ¡ |¡slJ ‚t 
| ¡ g d¢g¡sˆJ ‚| d ¡ | ¡  t 
| ¡ t  d¡¡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¡¡sNJ ‚t 
| ¡ g d¢g¡sjJ ‚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–   r–  ÚmcolorsZto_rgba_arrayZ_get_default_facecolorZget_cmapr‘  r¬   Ú
same_colorÚget_edgecolorZset_facecolorZset_edgecolorÚget_facecolorrÂ   rþ   rÿ   )rž  rÇ   r—  Zface_defaultÚmappedr.   r.   r/   Útest_color_logic  sj    








r¤  c                  C   sŒ   t d dddg d¢d} |  ¡ d dks*J ‚t |  ¡ d¡s>J ‚|  ¡ dksNJ ‚t |  ¡ g d¢g¡shJ ‚t d d d} t |  ¡ d¡sˆJ ‚d S )	Ngš™™™™™@r¸   r§   )r   r   r   r   )r   Z	edgecolorZzorderr«   r   )Z	facecolorr^   )r   Zget_linewidthrŸ  r   r¡  Z
get_zorderr¢  )Úlcr.   r.   r/   Útest_LineCollection_argsM  s    ÿr¦  c                  C   s|   t  d¡ dd¡} t | ¡}tjtdd" | | ¡ | 	¡  W d   ƒ n1 sR0    Y  t 
| ¡}| | ¡ | 	¡  d S )Nr  r§   r   z^Collections can only mapr]  )r"   r”   r–   r$   Úpcolorr`  ra  ra   rþ   r–  rö   )rÇ   r—  r.   r.   r/   Útest_array_wrong_dimensions[  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"   rj  r•   r­   r   r_   r  )rc   r¥  Zreadbackr.   r.   r/   Útest_get_segmentsf  s    

rª  c                  C   s~   t  ¡ } dg}tj|d}tj|dd}tj|d}| d¡ | | ¡j}| | ¡j}| | ¡j}||ksnJ ‚||kszJ ‚d S )Nr   )rË   r  )rË   r©   )rk   rl   rh   ZCircleCollectionÚset_offsetsrj   rz   )ÚidentityrË   ro   ÚinitÚlateZnull_boundsZinit_boundsZlate_boundsr.   r.   r/   Útest_set_offsets_lateo  s    
r¯  c                  C   sT   t  ¡  dd¡} tj| d}t ¡ }| | ¡ | | ¡   krJ| ¡ ksPn J ‚d S )Nr   )rª   )rk   r˜   Úskewrh   r   Zset_offset_transformZget_offset_transform)r°  r­  r®  r.   r.   r/   Útest_set_offset_transform„  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   é   rG  z
2021-11-29)r"   r•   rš   Ztimedelta64Z
datetime64r$   rx   Zget_offsetsr«  r¿   rÃ   r3   rl  r%   )r‡   rˆ   Údr(  Zoff0r+   r,   r.   r.   r/   Útest_set_offset_unitsŽ  s    
r´  )hré   Útypesr   Únumpyr"   Znumpy.testingr   r   r`  Z
matplotlibrE  Zmatplotlib.pyplotZpyplotr$   r…  Úcollectionsrh   Zmatplotlib.colorsrÅ   rŸ  Zmatplotlib.pathÚpathrt   Zmatplotlib.transformsZ
transformsrk   r   r   r   r   r	   Zmatplotlib.testing.decoratorsr
   r   Zmatplotlib._api.deprecationr   r0   r<   rB   rE   rF   rG   rJ   rK   rL   rO   rQ   rZ   r]   r2   rq   rv   r{   r&  Úcontextr‰   r    r¥   rµ   rÉ   rÔ   ræ   rï   rù   rü   r  r  r  r  r  r  r   r#  r%  r)  r.  rN  rO  r\  rg  rp  rr  ÚmarkZparametrizert  Údictr‚  r†  r‹  rŒ  rŽ  r’  r”  r˜  r  r§  rö   r¤  r¦  r¨  rª  r¯  r±  r´  r.   r.   r.   r/   Ú<module>   sä   (












	



$










ÿ
3þ
ü
"

	
D	
