o
    Gf)                     @   s  d dl Z d dlZd dlZd dlmZmZ d dlmZ	 d dl
mZmZ dd Zdd Zdd	 Zd
d Zejdddgdd Zdd Zdd Zdd Zdd Zedgdd Zejdddgejdddgejdddgejdddgd d! Zejd"ddgejd#ddgd$d% Zd&d' Zd(d) Zejd*dg d+gejd,dd-d.gged/gd0d1d2 Zejd*dg d+gejd,dd-d.gged/gd0d3d4 Zejd5d6d7gd8d9 Zd:d; Z dS )<    N)AxesSubplotBase)check_figures_equalimage_comparisonc           
   	   C   s   t t| t| ttd||gD ]5\\}}\}}\}\}}	||kr$q| d j| |||	||f ksGJ d|||	||f rAdnd|f qdS )z
    x_shared and y_shared are n x n boolean matrices; entry (i, j) indicates
    whether the x (or y) axes of subplots i and j should be shared.
    Zxyr   z,axes %i and %i incorrectly %ssharing %s axisznot  N)	itertoolsproduct	enumeratezipZ_shared_axesZjoined)
axsZx_sharedZy_sharedZi1Zax1Zi2Zax2Zi3nameZshared r   >lib/python3.10/site-packages/matplotlib/tests/test_subplots.pycheck_shared   s   $r   c                 C   s   t t| ||D ]S\}\}}}| |jjg D ]}| |ks*J d| d| q| |jjg D ]}| |ksFJ d| d| q4|sQ| dksQJ |s[|	 dks[J qdS )z<Check that the x and y ticklabel visibility is as specified.zVisibility of x axis #z is incorrectly zVisibility of y axis #r   N)
r	   r
   Zget_xticklabelsxaxisZ
offsetTextget_visibleZget_yticklabelsyaxis
get_xlabel
get_ylabel)r   	x_visible	y_visibleiaxZvxZvylr   r   r   check_ticklabel_visible   s   r   c                 C   sp   t | |D ]\}}|j D ]}|j |ksJ qqt | |D ]\}}|j D ]}|j |ks4J q)q dS )z
    Check that the x and y tick visibility is as specified.

    Note: This only checks the tick1line, i.e. bottom / left ticks.
    N)r
   r   Zget_major_ticksZ	tick1liner   r   )r   r   r   r   visibleZtickr   r   r   check_tick1_visible,   s   r   c               
   C   s  d} t j| d d tdt j| d d tdt g dg dg dg dgt g dg dg dg dgd}g d	g d	d
gd d
gd d
gd g d	dg dd
gd g dd
gd d
gd g ddd}|d |d< |d |d
< tdd\}\\}}\}}||||g}t||d |d  t| g d}	|	D ];}
|	D ]6}tjdd|
|d\}\\}}\}}||||g}t|||
 ||  t	||d |
 |d |  t| qqd S )N)   r      r   )Zdtype)FTFF)TFFF)FFFT)FFTF)allnonerowcolFFTTTr   )r   r"   r!   r    FTTFTF)xyr    Fr   )FTr   r    r!   r"   r      sharexshareyr%   r&   )
npZonesboolZzerosZarraypltsubplotsr   closer   )ZrdimZsharer   fa1a2a3a4r   opsZxoZyor   r   r   test_shared:   s^   	
"r6   remove_ticksTFc                 C   s   t jddddd\}}|jD ]}|jddd |j| d qt|jg dg d	 | r8t|jg dg d	 d S t|jg d
g d
 d S )Nr   Tr(   foobarZxlabelZylabel)Zremove_inner_ticksr#   r$   )TTTT)r-   r.   Zflatsetlabel_outerr   r   )r7   r0   r   r   r   r   r   test_label_outerp   s   
r=   c                  C   s   t  } | dd}| |dddf }| |dddf }| |d }| |d }| jD ]}|  q1t| jg dg d d S )	N   r   r   r'   )r'   r   )r   r'   )FTFT)TTFF)r-   figureZadd_gridspecadd_subplotaxesr<   r   )figZgsr1   r2   r3   r4   r   r   r   r   test_label_outer_span   s   

rC   c                  C   s(   t d} |   t| gdgdg d S )Nr   r   r'   r'   T)r-   rA   r<   r   )r   r   r   r   test_label_outer_non_gridspec   s   
rE   c                  C   s   t jdddd\} \}}t|gdgdg |j  t|gdgdg t jdddd\} \}}t|gdgdg |j  t|gdgdg d S )Nr'   r   Tr*   Fr)   )r-   r.   r   r   Z	tick_leftr   Ztick_bottom)r0   r1   r2   r   r   r   test_shared_and_moved   s   

rH   c                   C   sz   t t tjdddd W d    n1 sw   Y  t t tjdddd W d    d S 1 s6w   Y  d S )Nr   ZblahrG   rF   )pytestraises
ValueErrorr-   r.   r   r   r   r   test_exceptions   s   "rL   Zsubplots_offset_textc                  C   sz   t ddd} t dddd }tjdddd	d
\}}|d | |  |d | |  |d ||  |d ||  d S )Nr   g    _Bg    eAd   
   g     @r   r"   r   r(   )r   r   )r'   r   )r   r'   )r'   r'   )r+   Zaranger-   r.   Zplot)r%   r&   rB   r   r   r   r   test_subplots_offsettext   s   rO   topbottomleftrightc                 C   s   t | |||d t  jddddd}W d    n1 s w   Y  t|D ]F\\}}}|jjd }|jjd }	|jjd }
|jjd }|| oN|dkksRJ |	|oX|dkks\J |
|ob|dkksfJ ||ol|dkkspJ q*d S )	N)zxtick.labeltopzxtick.labelbottomzytick.labelleftzytick.labelrightr>   Tr(   Zlabel2OnZlabel1Onr   r   )	r-   Z
rc_contextr?   r.   r+   ndenumerater   Z_major_tick_kwr   )rP   rQ   rR   rS   r   r   jr   ZxtopZxbottomZyleftZyrightr   r   r   test_subplots_hide_ticklabels   s   
rV   xlabel_positionylabel_positionc                 C   s   t  jddddd}t|D ]M\\}}}|jddd |j|  |j| |	  t
| | dkr:|dkpA| d	koA|d
kksEJ t
| |dkrR|d
kpY|dkoY|dkks]J qd S )Nr>   Tr(   r8   r9   r:   rQ   r   rP   r   rR   rS   )r-   r?   r.   r+   rT   r;   r   Zset_label_positionr   r<   r,   r   r   )rW   rX   r   r   rU   r   r   r   r   test_subplots_hide_axislabels   s   


rY   c                  C   s(   t  \} }|  | ksJ d S )N)r-   r.   Zget_subplotspecZget_gridspec)rB   r   r   r   r   test_get_gridspec   s   rZ   c                  C   sR   ddi} dddgi}t jdd| |d\}}| ddiksJ |dddgiks'J d S )Nr)   r   width_ratiosr'   r   )
subplot_kwgridspec_kw)r-   r.   )r\   r]   rB   r   r   r   r   test_dont_mutate_kwargs   s   

r^   r[   )r'   r>   r   height_ratiosr'   r   Zpng)
extensionsc                 C   s,   | j dd||d |j dd||dd d S )Nr   r>   r_   r[   r]   )r.   )fig_testfig_refr_   r[   r   r   r   test_width_and_height_ratios   s   
re   c                 C   s8   g dg dg}| j |||d |j |||dd d S )N)ABrg   )rf   CDra   rb   )subplot_mosaic)rc   rd   r_   r[   Zmosaic_specr   r   r   #test_width_and_height_ratios_mosaic   s   rk   zmethod,args)r.   )r   r>   )rj   )zabc;defc                 C   s   t jtdd tt| |ddgdddgid W d    n1 s#w   Y  t jtdd tt| |g ddg did W d    d S 1 sLw   Y  d S )	Nr_   )matchr'   r   )r_   r]   r[   )r'   r   r>   )r[   r]   )rI   rJ   rK   getattrr-   )methodargsr   r   r   test_ratio_overlapping_kws
  s   



"rp   c                  C   sz   t  } t|  tsJ t| jg ddtrJ tt t	| g dg dd W d    d S 1 s6w   Y  d S )NrD   )Zrect)
r-   r?   
isinstancer@   r   Zadd_axesrI   rJ   	TypeErrorr   )rB   r   r   r   test_old_subplot_compat  s   "rs   )!r   Znumpyr+   rI   Zmatplotlib.axesr   r   Zmatplotlib.pyplotZpyplotr-   Zmatplotlib.testing.decoratorsr   r   r   r   r   r6   ZmarkZparametrizer=   rC   rE   rH   rL   rO   rV   rY   rZ   r^   re   rk   rp   rs   r   r   r   r   <module>   sT    6


	
	


	