o
    ÞÁg£  ã                
   @   s|  d dl mZ d dlmZ d dlZd dlZd dlmZ d dlZd dlZd dl	Z
d dl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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%m&Z&m'Z' d dl(m)Z* d dl+Z+e#dgdddd„ ƒZ,e#dgdddd„ ƒZ-e#dgddgdddd„ ƒZ.e+j/ 0dddg¡e#dgddgdd d!„ ƒƒZ1d"d#„ Z2e+j/ 0d$g d%¢¡e"dgdd&d'„ ƒƒZ3e"dgdd(d)„ ƒZ4e"ƒ d*d+„ ƒZ5d,d-„ Z6d.d/„ Z7e+j/ 0d0g d1¢¡d2d3„ ƒZ8e+j/ 0d0g d4¢¡d5d6„ ƒZ9d7d8„ Z:d9d:„ Z;d;d<„ Z<e#d=gddd>d?„ ƒZ=d@dA„ Z>e+j/ 0dBdCdDggdEdFfdGdHggdIdIfg¡dJdK„ ƒZ?e#dLgdddMdN„ ƒZ@e#dOgdddPdQ„ ƒZAe#dRgdddSdTdU„ ƒZBe"dgddVdW„ ƒZCdXdY„ ZDdZd[„ ZEe#d\gddd]d^„ ƒZFe#d_gdddgd`dadb„ ƒZGdcdd„ ZHe#degdddSdfdg„ ƒZIe#dhgdddidj„ ƒZJe#dkgddgdddldmdn„ ƒZKe#dogdddSdpdq„ ƒZLdrds„ ZMe#dtgdddSdudv„ ƒZNdwdx„ ZOdydz„ ZPd{d|„ ZQd}d~„ ZRdd€„ ZSdd‚„ ZTe+j/ 0dƒee Ud„¡e Ud…¡e Ud†¡ Vd‡¡fe e Ud„¡e Ud…¡e Udˆ¡ Vd‰¡fg¡dŠd‹„ ƒZWdŒd„ ZXdŽd„ ZYe#dgddd‘d’„ ƒZZe#d“gdd”d•d–d—„ ƒZ[d˜d™„ Z\dšd›„ Z]e#dœgddd•dždŸ„ ƒZ^e#d gddd¡d¢„ ƒZ_d£d¤„ Z`e#d¥gddd¦d§„ ƒZae#d¨ge b¡ d©kr[d ndªddd«d¬d­„ ƒZcd®d¯„ Zde+j/ 0d°d±d²„ d³ e¡ D ƒ¡d´dµ„ ƒZfe#d¶gdddSd·d¸„ ƒZge#d¹gdddSdºd»„ ƒZhe#d¼gdddSd½d¾„ ƒZie+j/ 0d¿ejjejkdÀdÁ„ dÂdÁ„ g¡dÃdÄ„ ƒZldÅdÆ„ ZmdÇdÈ„ ZndÉdÊ„ Zoe+j/ 0dËdÌdÍg¡e+j/ 0dÎdÏdÐg¡dÑdÒ„ ƒƒZpdÓdÔ„ ZqdÕdÖ„ Zrd×dØ„ ZsdÙdÚ„ Zte"ƒ dÛdÜ„ ƒZudÝdÞ„ Zve+j/ d¡dßdà„ ƒZwe+j/jxe+j/jydádâ„ ƒƒZzG dãdä„ däej{ƒZ|dådæ„ Z}dçdè„ Z~e"dgddédê„ ƒZe+j/ 0dëdìdíg¡e"dgddîdï„ ƒƒZ€e"ƒ dðdñ„ ƒZdS )òé    )Ú	ExitStack)ÚcopyN)ÚPath)Úassert_array_equal)ÚImage)Ú_apiÚcolorsÚimageÚpatchesÚpyplotÚstyleÚrcParams)Ú	AxesImageÚ	BboxImageÚFigureImageÚNonUniformImageÚPcolorImage)Úcheck_figures_equalÚimage_comparison)ÚBboxÚAffine2DÚTransformedBboxÚimage_interpsÚmpl20)r   c                  C   s†   dt jd< t d¡ dd¡} t  d¡\}\}}}|j| dd | d	¡ | d¡ |j| d
d | d
¡ |j| dd | d¡ dS )z5Make the basic nearest, bilinear and bicubic interps.é   ztext.kerning_factoréd   é   é   é   Únearest©Úinterpolationzthree interpolationsÚbilinearÚbicubicN)	Úpltr   ÚnpÚarangeÚreshapeÚsubplotsÚimshowÚ	set_titleÚ
set_ylabel)ÚXÚfigÚax1Úax2Úax3© r1   úY/home/ubuntu/cloudmapper/venv/lib/python3.10/site-packages/matplotlib/tests/test_image.pyÚtest_image_interps   s   



r3   zinterp_alpha.pngT)Úremove_textc                  C   sf   t  dd¡\} \}}t d¡}t d¡|d< t tjdtjd¡|d< |j|dd	 |j|d
d	 dS )z:Test the interpolation of the alpha channel on RGBA imagesé   é   )r   r   é   ©r   r   ).r5   ©Údtype©.r   Únoner    r"   N)r$   r(   r%   ÚzerosÚonesÚtrilÚuint8r)   )r-   ÚaxlÚaxrÚimgr1   r1   r2   Útest_alpha_interp-   s   
rD   Úinterp_nearest_vs_noneÚpdfÚsvg)Ú
extensionsr4   c                  C   s|   dt d< tjg d¢g d¢gg d¢g d¢ggtjd} t dd	¡\}\}}|j| d
d | d¡ |j| dd | d¡ dS )z5Test the effect of "nearest" and "none" interpolationr   úsavefig.dpi)éÚ   é¥   é    )éz   ég   éî   )é   éÿ   r   )rQ   éc   éG   r9   r5   r6   r<   r    zinterpolation noner   zinterpolation nearestN)r   r%   Úarrayr@   r$   r(   r)   r*   )r,   r-   r.   r/   r1   r1   r2   Útest_interp_nearest_vs_none:   s   ÿÿ
rU   ÚsuppressCompositeFÚfigimageÚpng)rH   c                 C   s  t jddd}| |_t t d¡d t d¡d ¡\}}t |d |d  ||  ¡}t d|d  d|d   ¡}||d  }|j|d	d	d
d |j|d d d…d d …f d	dd
d |j|d d …d d d…f dd	d
d |j|d d d…d d d…f ddd
d d S )N©r6   r6   r   ©ÚfigsizeÚdpig      Y@r6   r   é2   r   r   Úlower)ÚxoÚyoÚoriginéÿÿÿÿ)r$   ÚfigurerV   r%   Úix_r&   ÚsinrW   )rV   r-   ÚxÚyÚzÚcrC   r1   r1   r2   Útest_figimageL   s   $$$*rj   c                  C   sD   t  ¡ \} }| g d¢¡ t ¡ }|  |¡ | d¡ t  |¡ d S )N)r5   r6   r   r   )r$   r(   ÚplotÚioÚBytesIOÚsavefigÚseekÚimread)r-   ÚaxÚbufferr1   r1   r2   Útest_image_python_io\   s   

rs   z!img_size, fig_size, interpolation))r   r6   Úhanning)r   r   r   )r   é
   r   )r   ç333333@rt   )r   g333333"@r   c           	      C   sš   t j d¡ tjd }t j t|| ƒt|| ƒ¡}| |fD ]}| ||¡ q|  ¡ }| 	g d¢¡ |j
|dd | ¡ }| 	g d¢¡ |j
||d d S )Né!N,rI   ©r   r   r5   r5   Úantialiasedr    )r%   ÚrandomÚseedr$   r   ÚrandÚintÚset_size_inchesr(   Úset_positionr)   )	Úfig_testÚfig_refÚimg_sizeÚfig_sizer!   r\   ÚAr-   Úaxsr1   r1   r2   Útest_imshow_antialiasede   s   
r†   c                 C   s¶   t j d¡ tjd }t j t|d ƒt|d ƒ¡}| |fD ]}| dd¡ q|  ¡ }|j	|dd | 
ddg¡ | ddg¡ | ¡ }|j	|d	d | 
ddg¡ | ddg¡ d S )
Nrw   rI   r   rv   ry   r    ru   r   r   )r%   rz   r{   r$   r   r|   r}   r~   r(   r)   Úset_xlimÚset_ylim)r€   r   r\   r„   r-   r…   r1   r1   r2   Útest_imshow_zoom}   s   
r‰   c                 C   sŽ   t  d¡ ttƒjd }ttƒjd }|  d¡}|d  t |¡¡ |d  t |¡¡ | d¡}|d  t	 
|¡¡ |d  t	 
|¡¡ d S )NÚdefaultú%baseline_images/pngsuite/basn3p04.pngú%baseline_images/test_image/uint16.tifr6   r   r5   )r   Úuser   Ú__file__Úparentr(   r)   r   Úopenr$   rp   )r€   r   Úpng_pathÚ	tiff_pathr…   r1   r1   r2   Útest_imshow_pil   s   


r“   c                  C   sF   t  tj tj t¡ddd¡¡} | jtj	ksJ ‚t 
| ¡dks!J ‚d S )NÚbaseline_imagesÚ
test_imagez
uint16.tifé €ÿ)r$   rp   ÚosÚpathÚjoinÚdirnamerŽ   r:   r%   Úuint16Úsum©rC   r1   r1   r2   Útest_imread_pil_uint16œ   s
   ÿrž   c                  C   s:   t  ttƒjd ¡} | jtjksJ ‚t | ¡dksJ ‚d S )NrŒ   r–   )	r$   rp   r   rŽ   r   r:   r%   r›   rœ   r   r1   r1   r2   Útest_imread_fspath£   s
   ÿrŸ   Úfmt)rX   ÚjpgÚjpegÚtiffc                 C   sÄ   | dv}t j d¡ t j dd¡}t ¡ }tj||| dd t ¡ }tj||| dd | d¡ tj	|| d}| d¡ tj	|| d}|j
ddd	| fksOJ ‚|j
ddd	| fks[J ‚t||ƒ d S )
N)r¡   r¢   r5   i@  r6   )Úformatr\   r   r   ©r¤   r   )r%   rz   r{   r|   rl   rm   r$   Úimsavero   rp   Úshaper   )r    Ú	has_alphaÚdataÚ	buff_dpi1Úbuff_dpi100Úarr_dpi1Ú
arr_dpi100r1   r1   r2   Útest_imsaveª   s   	

r®   )rX   rF   ÚpsÚepsrG   c                 C   s&   t jttjƒt ddgg¡| d d S )Nr   r5   r¥   )r$   r¦   r   r—   Údevnullr%   rT   )r    r1   r1   r2   Útest_imsave_fspathÍ   s   &r²   c                  C   s”   t j d¡ dD ]?} t j ddd¡}t ¡ }tj||| dd | d¡ t 	|¡}d|  
d	¡}| d
kr;|d d d… }d|  
d	¡}t||ƒ qd S )Nr5   )r^   Úupperé   r7   rX   )ra   r¤   r   rQ   r@   r^   rb   )r%   rz   r{   r|   rl   rm   r$   r¦   ro   rp   Úastyper   )ra   r©   ÚbuffÚarr_bufr1   r1   r2   Útest_imsave_color_alphaÒ   s   

ðr¸   c                  C   sh   ddl m}  t ¡ }| ƒ }| dd¡ tj|ddgddggdd	|id
 t |¡}|j	d dks2J ‚d S )Nr   )ÚPngInfoÚSoftwareÚtestr5   r6   r   rX   Úpnginfo©r¤   Ú
pil_kwargs)
ÚPIL.PngImagePluginr¹   rl   rm   Úadd_textr$   r¦   r   r   Úinfo)r¹   Úbufr¼   Úimr1   r1   r2   Útest_imsave_pil_kwargs_pngë   s   ÿ
rÄ   c                     sp   ddl m‰  t ¡ } ddi}tj| ddgddggd|d	 t | ¡}‡ fd
d„|j 	¡ D ƒ}|d dks6J ‚d S )Nr   )ÚTAGS_V2Údescriptionz
test imager5   r6   r   r£   r½   c                    s   i | ]
\}}ˆ | j |“qS r1   )Úname)Ú.0ÚkÚv©ÚTAGSr1   r2   Ú
<dictcomp>ü   ó    z/test_imsave_pil_kwargs_tiff.<locals>.<dictcomp>ÚImageDescription)
ÚPIL.TiffTagsrÅ   rl   rm   r$   r¦   r   r   Útag_v2Úitems)rÂ   r¾   rÃ   Útagsr1   rË   r2   Útest_imsave_pil_kwargs_tiffö   s   
rÔ   Úimage_alphac                  C   sd   t j d¡ t j dd¡} t dd¡\}\}}}|j| ddd |j| ddd |j| dd	d d S )
Nr   r   r5   r   ç      ð?r<   )Úalphar!   ç      à?r   )r%   rz   r{   r|   r$   r(   r)   )ÚZr-   r.   r/   r0   r1   r1   r2   Útest_image_alpha   s   rÚ   c            
      C   sp  ddl m}  t ¡ \}}|jt d¡ dd¡dd}d\}}|j 	||g¡\}}| d|j
||ƒ}| |¡d	ks9J ‚d
\}}|j 	||g¡\}}| d|j
||ƒ}| |¡d u sXJ ‚| ¡  |jt d¡ dd¡dd}d\}}|j 	||g¡\}}| d|j
||ƒ}| |¡d	ks‰J ‚t ¡ \}}|jt d¡ dd¡g d¢d}d\}}|j 	||g¡\}}| d|j
||ƒ}| |¡dks¾J ‚d\}}|j 	||g¡\}}| d|j
||ƒ}| |¡d u sÝJ ‚d\}}|j 	||g¡\}}| d|j
||ƒ}| |¡d u süJ ‚tƒ  d¡ d¡}	|jt d¡ dd¡|	|j d}d\}}|j 	||g¡\}}| d|j
||ƒ}| |¡d	ks6J ‚d S )Nr   ©Ú
MouseEventr   ru   r³   )ra   ©r7   r7   Úmotion_notify_eventé,   )g333333$@r7   r^   )r   rØ   r   rØ   ©Úextent)ç      Ð?râ   é7   )ç      è?râ   )ç{®Gáz„?g{®Gáz„¿r6   rØ   )Ú	transform)r   ru   )Úmatplotlib.backend_basesrÜ   r$   r(   r)   r%   r&   r'   Ú	transDataræ   ÚcanvasÚget_cursor_dataÚclearr   ÚscaleÚrotate)
rÜ   r-   rq   rÃ   rf   rg   ÚxdispÚydispÚeventÚtransr1   r1   r2   Útest_cursor_data  sN   
 ÿrò   z/data, text_without_colorbar, text_with_colorbari'  i'  z[1e+04]z[10001]g°rh‘í|¿?g/Ý$•ï?z[0.123]c           
      C   sÂ   ddl m} t ¡ \}}| | ¡}|j ddg¡\}}|d|j||ƒ}	| |	¡| d d ks0J ‚| 	| |	¡¡|ks<J ‚| 
|¡ |j ¡  | |	¡| d d ksSJ ‚| 	| |	¡¡|ks_J ‚d S )Nr   rÛ   rÞ   )rç   rÜ   r$   r(   r)   rè   ræ   ré   rê   Úformat_cursor_dataÚcolorbarÚdraw)
r©   Útext_without_colorbarÚtext_with_colorbarrÜ   r-   rq   rÃ   rî   rï   rð   r1   r1   r2   Útest_format_cursor_dataR  s   
ÿ

ÿrø   Ú
image_clipc                  C   sF   ddgddgg} t  ¡ \}}| | ¡}tjdd|jd}| |¡ d S )Nr5   r6   r   r7   ©r   r   )Úradiusræ   )r$   r(   r)   r
   ÚCirclerè   Úset_clip_path)Údr-   rq   rÃ   Úpatchr1   r1   r2   Útest_image_clipk  s
   
r   Úimage_cliprectc                  C   sN   t  ¡ \} }ddgddgg}|j|dd}tjddd|jjd}| |¡ d S )	Nr5   r6   r   r7   ©r   r   r   r   rà   ©r5   r5   )ÚxyÚwidthÚheightræ   )r$   r(   r)   r
   Ú	RectangleÚaxesrè   rý   )r-   rq   rþ   rÃ   Úrectr1   r1   r2   Útest_image_cliprectu  s   ÿr
  r)   )r4   r   c                  C   sH   t  ¡ \} }t d¡ d¡}|j|ddd | dd¡ | dd¡ d S )Nr   ©ru   ru   r"   ©r5   r6   r5   r6   ©r!   rá   r   r   )r$   r(   r%   r&   r'   r)   r‡   rˆ   ©r-   rq   Úarrr1   r1   r2   Útest_imshow  s
   r  c                 C   s†   t  d¡ d¡}| ¡ }|j|d d …d d …df ddd | dd¡ | dd¡ |  ¡ }|j|ddd | dd¡ | dd¡ d S )Nr   )ru   ru   r5   r   r"   r  r  r   )r%   r&   r'   r(   r)   r‡   rˆ   )r€   r   r  rq   r1   r1   r2   Útest_imshow_10_10_1Š  s   "r  c                  C   óV   t  ¡ \} }t d¡ d¡}t t¡ | |¡ W d   ƒ d S 1 s$w   Y  d S )NéÈ   )ru   ru   r6   ©	r$   r(   r%   r&   r'   ÚpytestÚraisesÚ	TypeErrorr)   r  r1   r1   r2   Útest_imshow_10_10_2™  ó
   "ÿr  c                  C   r  )Niô  )ru   ru   r   r  r  r1   r1   r2   Útest_imshow_10_10_5   r  r  Úno_interpolation_originc                  C   sP   t  d¡\} }|d jt d¡ d¡ddd |d jt d¡ d¡dd	 d S )
Nr6   r   r   )r6   r]   r^   r<   )ra   r!   r5   r    )r$   r(   r)   r%   r&   r'   )r-   r…   r1   r1   r2   Útest_no_interpolation_origin§  s
   ÿ"r  Úimage_shift)r4   rH   c                  C   sT   dd„ t ddƒD ƒ} d}d}t ¡ \}}|j| t ¡ d||ddfd | d	¡ d S )
Nc                    s$   g | ]‰ ‡ fd d„t ddƒD ƒ‘qS )c                    s   g | ]
}d | d ˆ   ‘qS )r5   r1   )rÈ   rf   ©rg   r1   r2   Ú
<listcomp>±  rÎ   z/test_image_shift.<locals>.<listcomp>.<listcomp>r5   r   )Úrange)rÈ   r1   r  r2   r  ±  s   $ z$test_image_shift.<locals>.<listcomp>r5   r   gMòãûk&Ag˜Šäûk&Ar<   )Únormr!   rá   Úauto)r   r$   r(   r)   r   ÚLogNormÚ
set_aspect)ÚimgDataÚtMinÚtMaxr-   rq   r1   r1   r2   Útest_image_shift¯  s   
ÿr(  c                  C   s  t jddgd} | jg d¢dd}t t d¡d¡ dd	¡}|j|d
g d¢ddd}d }}| | |g¡ | 	| |g¡ | 
g ¡ | g ¡ t ¡ }| j|dd | d¡ t  |¡}t|d d …df ƒ\}}}	}
t|d d …df ƒ\}}}	}
|dksJ dƒ‚d S )Nr5   ©r[   rx   F)Úframeoné   é   r   é	   r³   ©éöÿÿÿru   r/  ru   r<   Úgray)ra   rá   r!   Úcmapr6   )r   r5   r   )Ú	facecolorr   rb   r   z.Expected a non-green edge - but sadly, it was.)r$   rc   Úadd_axesr%   Útiler&   r'   r)   r‡   rˆ   Ú
set_xticksÚ
set_yticksrl   rm   rn   ro   rp   rœ   )r-   rq   r©   rÃ   rf   rg   rÂ   ÚrÚgÚbÚar1   r1   r2   Útest_image_edges»  s$   ÿ



r;  Úimage_composite_backgroundc                  C   s^   t  ¡ \} }t d¡ dd¡}|j|g d¢d |j|g d¢d | d¡ | ddg¡ d S )	Nr+  r7   r   )r   r6   r,  r   rà   )r7   r   r,  r   )r5   r   r   rØ   r   )r$   r(   r%   r&   r'   r)   Úset_facecolorr‡   r  r1   r1   r2   Útest_image_composite_background×  s   
r>  Úimage_composite_alphac                  C   sŠ  t  ¡ \} }t d¡}d|dd…dd…df< t t ddd¡t ddd¡ddd… f¡|dd…dd…df< t d	¡}d|dd…dd…df< d|dd…dd…df< t t ddd¡t ddd¡ddd… f¡dd…tjf |dd…dd…df< |j|g d
¢dd |j|g d¢dd |j|g d¢d |j|g d¢d |j|g d¢dd |j|g d¢dd | d¡ | 	ddg¡ | 
ddg¡ dS )z{
    Tests that the alpha value is recognized and correctly applied in the
    process of compositing images together.
    )é   é   r7   r5   Nr   gš™™™™™ñ?çš™™™™™¹?rb   r   )rA  r@  r7   )r5   r6   r   r   ç333333Ó?)rá   r×   )r6   r   r   r   ç333333ã?)r   r7   r   r   rà   )r   r   r5   r6   )r   r   r6   r   )r   r   r   r7   )r   rØ   r   r5   r   )r$   r(   r%   r=   Úconcatenater&   Únewaxisr)   r=  r‡   rˆ   )r-   rq   r  Úarr2r1   r1   r2   Útest_image_composite_alphaâ  s.   
$ÿ
$ÿÿ
rH  Úrasterize_10dpi)rH   r4   r   c                  C   sÔ   t  ddgddgg¡} tjdddd\}}|d  | ¡ |d jddgddgdd	d
 |d jddd |d jddgddgdd |d jddd |D ]}| g ¡ | g ¡ |j	d d …  
d¡ qMdtd< d S )Nr5   r6   r   r7   )r   r5   r)  r   g      4@T)Ú	linewidthÚ
rasterized©r   r5   )rb   r6   ©ÚxlimÚylim)rJ  Fru   rI   )r%   Úasarrayr$   r(   r)   rk   Úsetr5  r6  ÚspinesÚset_visibler   )rC   r-   r…   rq   r1   r1   r2   Útest_rasterize_dpiý  s   	

rT  Úbbox_image_invertedc                  C   sÈ   t  d¡ d¡} t ¡ \}}tttddgddggƒ|jƒdd}| 	| ¡ | 
d¡ | dd¡ | dd¡ | |¡ t  d¡} tttdd	gd
dggƒ|jjƒdd}| 	| ¡ | 
d¡ | |¡ d S )Nr   r  r   r   r    Fru   rB  çš™™™™™É?rC  râ   )r%   r&   r'   r$   r(   r   r   r   rè   Úset_dataÚset_clip_onr‡   rˆ   Ú
add_artistÚidentityrc   ÚtransFigure)r	   r-   rq   Úbbox_imr1   r1   r2   Útest_bbox_image_inverted  s(   þ



ÿþ

r]  c                  C   s¨   t  g d¢g d¢g d¢g d¢g¡} tjddd\}}| g d¢¡ | d	d
¡ | d	d
¡ |j| g d¢dd}|j 	¡  |jj
}| |¡}t| ¡ ddgddggƒ d S )N)râ   rä   rÖ   rä   )rB  gÍÌÌÌÌÌä?rØ   çš™™™™™Ù?)rD  rC  ç        rV  )çffffffæ?çÍÌÌÌÌÌì?r^  rD  r  r   rZ   rx   r   r5   )r^  r`  rV  ra  r   )rá   r!   i  r  i¼  i„  )r%   rT   r$   r(   r   r‡   rˆ   r)   ré   rõ   ÚrendererÚget_window_extentr   Ú
get_points)rÃ   r-   rq   Úim_objrb  Úim_bboxr1   r1   r2   Ú$test_get_window_extent_for_AxisImage5  s   ÿ
ÿ

rg  zzoom_and_clip_upper_origin.pngc                  C   sF   t  d¡} |  d¡} t ¡ \}}| | ¡ | dd¡ | dd¡ d S )Nr   r  ç       @ç      à¿)r%   r&   r'   r$   r(   r)   rˆ   r‡   )r	   r-   rq   r1   r1   r2   Útest_zoom_and_clip_upper_originJ  s   


rj  c                  C   s   t  ¡ } t| ƒ}| d¡ d S )NÚBlues)r$   Úgcar   Úset_cmap©rq   rÃ   r1   r1   r2   Útest_nonuniformimage_setcmapV  s   ro  c                  C   s"   t  ¡ } t| ƒ}| t  ¡ ¡ d S ©N)r$   rl  r   Úset_normÚ	Normalizern  r1   r1   r2   Útest_nonuniformimage_setnorm\  s   rs  c                  C   sn   t jddd} tdƒD ]}t  ddd¡d | |d d …f< qt dd¡}| |  ¡ ¡ t 	¡ \}}| 
|¡ d S )	Nr  r@   r9   ru   r_  rÖ   rQ   ÚL)r%   r>   r   Úlinspacer   ÚnewÚputdataÚflattenr$   r(   r)   )ÚimdÚirÃ   r-   rq   r1   r1   r2   Útest_jpeg_2db  s    r{  c                  C   sª   t jddd tjdtd} t ddd¡| d< t  | ¡ t ¡ }t j	|d	d
dd | 
d¡ t |¡}t| d¡ƒ}d|  krEdksHJ ‚ J ‚| d¡}|dksSJ ‚d S )Nr  é,  rZ   )r|  r|  r7   r9   r_  rÖ   r;   Úredr¡   )r2  r¤   r\   r   é   é¯   é¹   rú   )éþ   r   r   )r$   rc   r%   r=   Úfloatru  rW   rl   rm   rn   ro   r   r   ÚlenÚ	getcolorsÚgetpixel)rÃ   r¶   r	   Ú
num_colorsÚcorner_pixelr1   r1   r2   Útest_jpeg_alpham  s   



rˆ  c                  C   óP   t  ¡ } t| ƒ}tjdtd d¡}| |¡ d|d< |jd dks&J dƒ‚d S ©Nr+  r9   ©r7   r   çÍÌÌÌÌÌ#@rú   r   úvalue changed)	r$   rl  r   r%   r&   r‚  r'   rW  Ú_A)rq   rÃ   rh   r1   r1   r2   Útest_axesimage_setdata…  ó   
r  c                  C   r‰  rŠ  )	r$   Úgcfr   r%   r&   r‚  r'   rW  rŽ  )r-   rÃ   rh   r1   r1   r2   Útest_figureimage_setdataŽ  r  r’  zimage_cls,x,y,aç      @ç      @g      (@r‹  g      @)r   r6   c                 C   sš   t  ¡ }| |ƒ}| |||¡ d |d<  |d< |d< |jd |jd   kr6|jd   kr6dks;J dƒ‚ J dƒ‚| ||| g |j¢d‘R ¡¡ d S )NrŒ  r   rú   r  rb   )r$   rl  rW  rŽ  Ú_AxÚ_Ayr'   r§   )Ú	image_clsrf   rg   r:  rq   rÃ   r1   r1   r2   Útest_setdata_xya—  s   @$r˜  c            
      C   sÞ   ddl m}  tj d¡ tj dd¡}t dd¡\}}|d  |¡}|d  |¡}tj	||d d tj	||d d t
 ¡ }tj|dd t
 | ¡ ¡}|  |¡}d }| d	¡D ]}	|d u rd|	d
 }qY|	d
 |krlJ ‚qYd S )Nr   )ÚElementTreeru   r5   r6   )rq   rG   r¥   r	   r  )Ú	xml.etreer™  r%   rz   r{   r|   r$   r(   Ú
pcolormeshrô   rl   rm   rn   ÚgetvalueÚparseÚiter)
r™  r©   r-   rq   Úp1Úp2r¶   Útreer  r	   r1   r1   r2   Útest_minimized_rasterized§  s(   

ÿür¢  c                  C   sž   t tƒjd } dtjdkrdnd |  ¡  ¡  }t ¡  t	 
|¡ W d   ƒ n1 s,w   Y  tj |¡}t	 
|¡ W d   ƒ d S 1 sHw   Y  d S )Nr‹   zfile:Úwin32z///Ú )r   rŽ   r   ÚsysÚplatformÚresolveÚas_posixr   Ú'suppress_matplotlib_deprecation_warningr$   rp   ÚurllibÚrequestÚurlopen)r˜   ÚurlÚfiler1   r1   r2   Útest_load_from_urlÈ  s   ÿ
þ
ÿ"ÿr¯  Úlog_scale_imagec                  C   sN   t  d¡} d| d d d…< t ¡ \}}|j| g d¢ddddd |jd	d
 d S )Nr  r5   r6   )r5   r   r5   r   Úviridisrb   r"  )rá   r1  ÚvmaxÚvminÚaspectÚlog)Úyscale)r%   r=   r$   r(   r)   rQ  )rÙ   r-   rq   r1   r1   r2   Útest_log_scale_imageÓ  s   
ÿr·  Úrotate_imagegffffffÖ?)r4   Útolc                  C   s,  d} t  dd| ¡ }}t  ||¡\}}t  |d |d   d ¡dt j  }t  |d d d |d d d   d ¡dt j d d  }|| }t dd¡\}}	|	j|dd	d
g d¢dd}
tƒ  	d¡|	j
 }|
 |¡ |
 ¡ \}}}}|	j|||||g|||||gdd|d |	 dd¡ |	 dd¡ d S )Nrâ   ç      Àr“  r6   r5   ç      ø?rØ   r<   r±  r^   )éþÿÿÿr7   éýÿÿÿr6   T)r!   r1  ra   rá   Úclip_oné   zr--r   )Úlwræ   r   r   r7   )r%   r&   ÚmeshgridÚexpÚpir$   r(   r)   r   Ú
rotate_degrè   Úset_transformÚ
get_extentrk   r‡   rˆ   )Údeltarf   rg   r,   ÚYÚZ1ÚZ2rÙ   r-   r.   Úim1Útrans_data2Úx1Úx2Úy1Úy2r1   r1   r2   Útest_rotate_imageâ  s*   &*ÿ
þ
 ÿrÑ  c                  C   sR   t  ¡ } t d¡}tj| |dd |  d¡ t | ¡}|jd d… |jks'J ‚d S )N)iá  iA  rX   r¥   r   r6   )	rl   rm   r%   r=   r$   r¦   ro   rp   r§   )r¶   rÃ   rC   r1   r1   r2   Útest_image_preserve_sizeþ  s   


rÒ  c                  C   sÈ   d} t  | t¡}tj| | fdd}t |g d¢¡}| ¡  | |¡ |j|dddd t	 
¡ }|j|d	d
 | d¡ t |¡}|jdksGJ ‚tt  |d d …d d …df t¡t  | t¡d d d… ƒ d S )Né   F)r[   r*  )r_  r_  rÖ   rÖ   r   r^   r"  )r!   ra   r´  r5   )r\   r   )rÓ  rÓ  r7   rb   )r%   rZ  r‚  r$   rc   ÚAxesÚset_axis_offr3  r)   rl   rm   rn   ro   rp   r§   r   rP  Úbool)Únr©   r-   rq   r¶   rC   r1   r1   r2   Útest_image_preserve_size2
  s   


ÿrØ  zmask_image_over_under.pngrÖ   c               	   C   sl  dt jd< d} t dd| ¡ }}t ||¡\}}t |d |d   d ¡dtj  }t |d d d |d d	 d   d ¡dtj d	 d  }d
||  }t jjj	dddd}tj
 |dk|¡}	t  dd¡\}
\}}|j|	d|tjdddddg d¢d}| d¡ |
j|dd|d
d |j|	d|tjg d¢ddddg d¢d}| d¡ |
j|dd d|d
d! d S )"NFzpcolormesh.snapgš™™™™™™?rº  r“  r6   r5   r»  rØ   ru   r7  r8  r9  ©ÚoverÚunderÚbadg333333ó?r"   g      ð¿rÖ   )r³  r²  Úclipr^   )r½  r   r½  r   )r!   r1  r!  ra   rá   zGreen=low, Red=high, Blue=badÚbothÚ
horizontal)ÚextendÚorientationrq   r´  r   )rb   ri  gš™™™™™É¿r   rV  rØ   r5   r~  )ÚncolorsrÝ  zWith BoundaryNormÚproportional)rà  Úspacingrá  rq   r´  )r$   r   r%   r&   rÁ  rÂ  rÃ  Úcmr0  Úwith_extremesÚmaÚmasked_wherer(   r)   r   rr  r*   rô   ÚBoundaryNorm)rÇ  rf   rg   r,   rÈ  rÉ  rÊ  rÙ   ÚpaletteÚZmr-   r.   r/   rÃ   r1   r1   r2   Útest_mask_image_over_under   s@   
&*ÿý

ÿ
ÿü


ÿrì  Ú
mask_imagec                  C   s   t  dd¡\} \}}t d¡}tj|dd…dd…f< |j|dd tjdtd}d|dd…dd…f< tj 	tjdtj
d|¡}|j|dd d S )Nr5   r6   r8   r   r    r9   T)r$   r(   r%   r>   Únanr)   r=   rÖ  rç  Úmasked_arrayr›   )r-   r.   r/   r„   r1   r1   r2   Útest_mask_imageB  s   
rð  c                  C   s2   t  dt j¡} t ¡ \}}| | ¡ |j ¡  d S )NrY   )r%   Úfullrî  r$   r(   r)   ré   Ú	draw_idle)r©   r-   rq   r1   r1   r2   Útest_mask_image_allT  s   
ró  zimshow_endianess.pngc                  C   s„   t  d¡} t  | | ¡\}}t  |d |d ¡}t dd¡\}\}}tdddd}|j| d	¡fi |¤Ž |j| d
¡fi |¤Ž d S )Nru   r   r5   r6   r^   r   r±  )ra   r!   r1  z<f8z>f8)	r%   r&   rÁ  Úhypotr$   r(   Údictr)   rµ   )rf   r,   rÈ  rÙ   r-   r.   r/   Úkwargsr1   r1   r2   Útest_imshow_endianess\  s   
r÷  Úimshow_masked_interpolationÚx86_64rå   )r¹  r4   r   c            
      C   sð   t  d¡jdddd} d}tjd|| d d	}tj|| td
 ||¡}d|d< d|d< tj	|d< t 
|¡ d¡}d|d< tj ||¡}t  dd¡\}}ttjƒ}| d¡ t|| ¡ ƒD ]\}}	|	 |¡ |	j||| |d |	 d¡ q^d S )Nr±  r7  r9  rÉ   rÙ  r   r   r5   ©r³  r²  r9   rb   r8   g     jø@)r,  r   )r,  r,  rÖ  T)r   r,  r   r   ry   )r!  r1  r!   Úoff)r$   Úget_cmapræ  r   rr  r%   r&   r‚  r'   ÚinfÚ
zeros_likerµ   rç  rï  r(   ÚsortedÚmimageÚ	_interpd_ÚremoveÚzipÚravelr*   r)   Úaxis)
r1  ÚNr×  r©   Úmaskr-   Úax_gridÚinterpsÚinterprq   r1   r1   r2   Ú test_imshow_masked_interpolationj  s$   



ýr  c                   C   s   t  ddgdtjgg¡ d S )Nr5   r6   r   )r$   r)   r%   rî  r1   r1   r1   r2   Útest_imshow_no_warn_invalidŽ  s   r  r:   c                 C   s   g | ]}t  |¡‘qS r1   )r%   r:   )rÈ   Úsr1   r1   r2   r  “  s    r  zu2 u4 i2 i4 i8 f4 f8c                 C   sÐ   t jd| d d¡}| jdkr|d8 }|dk }|dk}| jdkr$|d }t ¡ \}}| |¡ ¡ }|| dk ¡ s;J ‚| jdkrT|| d	k ¡ sJJ ‚|j	jdksRJ ‚d S || dk ¡ s^J ‚|j	t j
ksfJ ‚d S )
Nr|  r9   )ru   ru   r   Úuru   r   rQ   Úfr5   )r%   r&   r'   Úkindr$   r(   r)   Ú	get_arrayÚallr:   r@   )r:   r  Útoo_lowÚtoo_highÚ_rq   Úoutr1   r1   r2   Ú$test_imshow_clips_rgb_to_valid_range’  s   


r  zimshow_flatfield.pngc                  C   s0   t  ¡ \} }|jt d¡dd}| dd¡ d S )Nr8   r   r    rØ   r»  )r$   r(   r)   r%   r>   Úset_clim©r-   rq   rÃ   r1   r1   r2   Útest_imshow_flatfield§  s   r  zimshow_bignumbers.pngc                  C   sJ   dt d< t ¡ \} }tjg d¢g d¢gtjd}| |¡}| dd¡ d S )Nr   úimage.interpolation)r5   r6   g   ¢”mB)r   r5   r7   r9   r   r   )r   r$   r(   r%   rT   Úuint64r)   r  ©r-   rq   rC   Úpcr1   r1   r2   Útest_imshow_bignumbers®  s
   
r  zimshow_bignumbers_real.pngc                  C   sD   dt d< t ¡ \} }t g d¢g d¢g¡}| |¡}| dd¡ d S )Nr   r  )rh  rÖ   g’ÕMÏð€D)r”  rÖ   r“  r   r   )r   r$   r(   r%   rT   r)   r  r  r1   r1   r2   Útest_imshow_bignumbers_real¹  s
   
r   Ú	make_normc                   C   ó
   t  d¡S ©Nr5   )r   Ú
SymLogNormr1   r1   r1   r2   Ú<lambda>É  ó   
 r%  c                   C   r"  r#  )r   Ú	PowerNormr1   r1   r1   r2   r%  Ê  r&  c                 C   s    t  ¡ \}}tjtdd |jg g| ƒ d}W d   ƒ n1 s!w   Y  | g d¢¡ |j ¡  t 	t
¡ | |j¡ W d   ƒ d S 1 sIw   Y  d S )Nz)Attempting to set identical left == right©Úmatch)r!  )éûÿÿÿr   r*  r   )r$   r(   r  ÚwarnsÚUserWarningr)   Ú
set_extentré   rõ   r  ÚRuntimeErrorÚ
make_imageÚ_cachedRenderer)r!  r-   rq   rÃ   r1   r1   r2   Útest_empty_imshowÅ  s   ÿþ
"ÿr1  c                  C   st   t  ¡ \} }| tjdtjd¡ t tjtjd¡rtƒ nt	 
t¡ | j ¡  W d   ƒ d S 1 s3w   Y  d S )N)r   r   r9   Úequiv)r$   r(   r)   r%   r=   Ú
longdoubleÚcan_castÚfloat64r   r  r+  r,  ré   rõ   ©r-   rq   r1   r1   r2   Útest_imshow_float128×  s   ÿ"ýr7  c                  C   s0   t  ¡ \} }| tjddgddggtd¡ d S )NTFr9   )r$   r(   r)   r%   rT   rÖ  r6  r1   r1   r2   Útest_imshow_boolà  s   $r8  c                  C   sZ   t  ¡ \} }| t dtj¡¡ t t¡ | j	 
¡  W d   ƒ d S 1 s&w   Y  d S )Nr  )r$   r(   r)   r%   rñ  rî  r  r+  r,  ré   rõ   r6  r1   r1   r2   Útest_full_invalidå  s
   "ÿr9  zfmt,counted)r¯   s    colorimage)rG   s   <imagezcomposite_image,count)Tr5   )Fr6   c           
      C   s²   t  t  ddd¡t  ddd¡¡\}}t  |d ¡}t ¡ \}}| dd¡ |j|g d¢d |j|d d d	… g d
¢d |tjd< t	 
¡ }	|j|	| d |	 ¡  |¡|ksWJ ‚d S )Nr*  r   r5   r6   r   r   ©r   r5   r   r5   rà   rb   )r6   r   r   r5   zimage.composite_imager¥   )r%   rÁ  r&   re   r$   r(   r‡   r)   r   rl   rm   rn   rœ  Úcount)
r    ÚcountedÚcomposite_imager;  r,   rÈ  rÙ   r-   rq   rÂ   r1   r1   r2   Útest_compositeì  s   $
r>  c                  C   sV   t  ¡ \} }|jdggdd | ¡  | ¡  | ¡ | ¡   kr&dks)J ‚ J ‚d S )Nr   r:  rà   rL  )r$   r(   r)   ÚrelimÚ	autoscaleÚget_xlimÚget_ylimr6  r1   r1   r2   Ú
test_relimÿ  s
   (rC  c                  C   sx   t  ¡ \} }| ¡  |jddgddggddddd}|jddd | j ¡  t | j 	¡ ¡d	d d
…f dk 
¡ s:J ‚d S )Nr   r"  r.  r0  F)r´  rá   r1  r¾  rL  rM  .r   )r$   r(   rÕ  r)   rQ  ré   rõ   r%   rT   Úbuffer_rgbar  r  r1   r1   r2   Útest_unclipped  s   ÿ
,rE  c                  C   sÄ   t  d¡\} }|D ]}| ¡  q	|d jddgddggddd}| d ¡ | |d j¡ t ¡ }| j	|dd	 h | 
¡ £d
hksCJ ‚|d jdd t ¡ }| j	|dd	 | 
¡ | 
¡ ks`J ‚d S )Nr6   r5   r   r   r"  r:  )r´  rá   Úrgbar¥   rQ   )rb   r   )rO  )r$   r(   rÕ  r)   rý   Úset_clip_boxÚbboxrl   rm   rn   rœ  rQ  )r-   r…   rq   rÃ   Ú
buf_beforeÚ	buf_afterr1   r1   r2   Útest_respects_bbox  s   
 
rK  c                  C   s„   t  ¡ \} }| t d¡¡}tjjdgdgd}| |¡dks!J ‚tjjdgdgd}| |¡dks4J ‚tj}| |¡dks@J ‚d S )	NrÝ   r   T©r  z[]Fz[0]z[nan])	r$   r(   r)   r%   r=   rç  rï  ró   rî  )r-   rq   rÃ   r©   r1   r1   r2   Útest_image_cursor_formatting%  s   rM  c           
      C   sœ   t  dd¡}t  ||¡\}}t  d|d d  |d  ¡}|| ¡  }t d¡}|  ¡ }|j|||dd	 | ¡ }|t	 
¡ |ƒƒ}	||	d
< |j|	dd dS )zPer-pixel alpha channel test.r   r5   r½  rØ   r6   g[Âõ(\ß?r±  r   )r×   r1  r!   ).rb   r    N)r%   ru  rÁ  rÂ  Úmaxr$   rü  Úadd_subplotr)   r   rr  )
r€   r   rf   ÚxxÚyyÚzzr×   r1  rq   rF  r1   r1   r2   Útest_image_array_alpha4  s   
rS  c                   C   sL   t jtdd tjt d¡ddgd W d   ƒ d S 1 sw   Y  d S )Nzalpha must be a float, two-dr(  rY   r5   )r×   )r  r  r  r$   r)   r%   r=   r1   r1   r1   r2   Ú!test_image_array_alpha_validationG  s   "ÿrT  c                  C   sÌ   t tj d¡ƒ} | jdd tjddd}| g d¢¡}tjg d¢gt	d	}|j
|d
| ddd}| d¡ |j ¡  | |jj¡d d }| | |dggd  j ¡ ¡¡d  t¡}t ||k¡sdJ ‚d S )NÚautumn_rÚ	lightgrey)Úcolor)gffffffþ?rB  r   rZ   rx   )rb   rb   rb   r   r   r   r   é+   éO   é_   éB   r5   rb   rb   rb   r   r   r   é"   r9   r"  r   )r´  r1  r³  r²  rû  r5   ru   rQ   )r   r$   rå  rü  Ú	set_underrc   r3  r%   rT   r‚  r)   r  ré   rõ   r/  rb  r1  r!  ÚTr  rµ   r}   r  )r1  r-   rq   r©   rÃ   Ú
from_imageÚdirect_computationr1   r1   r2   Útest_exact_vminL  s    þ

$þra  c                  C   s8   t  ¡  t d¡} W d   ƒ d S 1 sw   Y  d S )Nz.https://matplotlib.org/1.5.0/_static/logo2.png)r   r©  r   rp   )rÊ   r1   r1   r2   Útest_https_imread_smoketesti  s   
"ÿrb  c                       s@   e Zd Zdd„ Zdd„ Z‡ fdd„Zdd„ Zed	d
„ ƒZ‡  Z	S )Ú
QuantityNDc                 C   s   t  |¡ | ¡}||_|S rp  )r%   rP  ÚviewÚunits)ÚclsÚinput_arrayre  Úobjr1   r1   r2   Ú__new__u  s   zQuantityND.__new__c                 C   s   t |dd ƒ| _d S ©Nre  )Úgetattrre  )Úselfrh  r1   r1   r2   Ú__array_finalize__z  s   zQuantityND.__array_finalize__c                    s<   t | dd ƒ}tt| ƒ |¡}t|tƒs|d urt||ƒ}|S rj  )rk  Úsuperrc  Ú__getitem__Ú
isinstance)rl  Úitemre  Úret©Ú	__class__r1   r2   ro  }  s
   
zQuantityND.__getitem__c                 O   sJ  t ||ƒ}d|v rt‚t|ƒdkr'|d }t |ddƒ}|t |¡fi |¤Ž}nlt|ƒdkr‘|d }|d }	t |ddƒ}
t |	ddƒ}|
d u rG|n|
}
|d u rO|
n|}|tjtjfv rb|
|kr_t‚|
}n|tjkro|
› d|› }n|tj	kr}|
› d|› d	}nt‚|| 
tj¡|	 
tj¡fi |¤Ž}nt‚|d u ržt |¡}|S t||ƒ}|S )
Nr  r5   r   re  Údimensionlessr6   Ú*z/(ú))rk  ÚNotImplementedErrorrƒ  r%   rP  ÚaddÚsubtractÚ
ValueErrorÚmultiplyÚdividerd  ÚndarrayrT   rc  )rl  ÚufuncÚmethodÚinputsrö  ÚfuncÚi0ÚunitÚout_arrÚi1Úu0Úu1r1   r1   r2   Ú__array_ufunc__„  s<   


$

ÿzQuantityND.__array_ufunc__c                 C   s   |   tj¡S rp  )rd  r%   r~  )rl  r1   r1   r2   rÊ   ¦  s   zQuantityND.v)
Ú__name__Ú
__module__Ú__qualname__ri  rm  ro  r‰  ÚpropertyrÊ   Ú__classcell__r1   r1   rs  r2   rc  t  s    "rc  c                  C   sÌ   t ddgdƒ} | d d … \}}t | jt ddg¡k¡sJ ‚| jdks%J ‚t || jt dg¡k¡s5J ‚|| jdks>J ‚|| jdksGJ ‚t t¡ |t ddƒ  W d   ƒ d S 1 s_w   Y  d S )Nr5   r6   Úmr   zm*mzm/(m)r  )	rc  r%   r  rÊ   rP  re  r  r  r{  )ÚqÚq0Úq1r1   r1   r2   Útest_quantitynd«  s    "ÿr“  c                  C   s4   t t d¡dƒ} t ¡ \}}| | ¡ |j ¡  d S )NrY   r  )rc  r%   r>   r$   r(   r)   ré   rõ   )r  r-   rq   r1   r1   r2   Útest_imshow_quantitynd·  s   
r”  c                 C   s.  t jddt jd}d|dd…d d …f< t jj|dd}d	|jdd…dd…f< t d
¡jdd}|  	¡ }|j
|tjddddd|d}| tjddd¡ |j
|tjddddd|d}| tjddd¡ |jddd | 	¡ }|j
|tjddddd|d |j
|tjddddd|d |jddd d S )Nr8   r5   r9   rb   r   r6   FrL  Tr±  Úw©rÛ  rØ   rú  r  r   )r!  rá   r!   r1  r¼  )r   ru   r   ru   )r   ru   rM  )r%   rñ  r5  rç  rT   r  r$   rü  ræ  r(   r)   r   r#  rq  rr  rQ  )r€   r   r©   Úmasked_datar1  rq   rÃ   r1   r1   r2   Útest_norm_changeÀ  s.   ÿÿÿÿr˜  rf   rb   r5   c                 C   s²   t jd|t jd}d|dd…d d …f< |  ¡ }|j|tjd| ¡ ddd	d
 t jd|t jd}d|dd…d d …f< | ¡ }t 	d	¡j
dd}|j|tjd| ¡ dd|d
 d S )Nr8   r9   g@Œµx¯Dr   r6   r5   rú  r   r±  )r!  r!   r1  iè  r•  r–  )r%   rñ  r5  r(   r)   r   r#  rN  r$   rü  ræ  rr  )r€   r   rf   r©   rq   r1  r1   r1   r2   Útest_huge_range_logÜ  s   ÿ
ÿr™  c           	   
   C   sB  |   dd¡}|  dd¡}ddgddggddgddggddgddggf}g d¢}tt||ƒƒD ]p\}\}}||  |¡ ||  |¡ ||  |¡ || j|ddddddd	 ||  d
d¡ ||  dd
¡ || j 	¡  || j
 d¡ || j d¡ || j tjdg d¢dd¡ || j tjdg d¢dd¡ q.d S )Nr5   r   r   )r>   r=   Úmixedr   Úequalr³   ÚGreys)r!   r´  ra   r1  r³  r²  ri  r»  gÍÌÌÌÌÌð?rÞ  r-  )r5   r6   r   ru   T)ÚnbinsÚstepsÚinteger)r(   Ú	enumerater  r*   Úspyr)   r‡   rˆ   ÚxaxisÚtick_topÚtitleÚset_yÚset_ticks_positionÚset_major_locatorÚmtickerÚMaxNLocatorÚyaxis)	r€   r   Úax_testÚax_refÚ	plot_dataÚplot_titlesrz  rh   r¤  r1   r1   r2   Útest_spy_boxð  s6   ýþ
ÿ
ÿñr¯  )‚Ú
contextlibr   r   rl   r—   Úpathlibr   r¦  r¥  Úurllib.requestrª  Únumpyr%   Únumpy.testingr   ÚPILr   Ú
matplotlibr   r   r	   r   r
   r   r$   r   r   Úmatplotlib.imager   r   r   r   r   Úmatplotlib.testing.decoratorsr   r   Úmatplotlib.transformsr   r   r   Úmatplotlib.tickerÚtickerr¨  r  r3   rD   rU   ÚmarkÚparametrizerj   rs   r†   r‰   r“   rž   rŸ   r®   r²   r¸   rÄ   rÔ   rÚ   rò   rø   r   r
  r  r  r  r  r  r(  r;  r>  rH  rT  r]  rg  rj  ro  rs  r{  rˆ  r  r’  r&   r'   r˜  r¢  r¯  r·  rÑ  rÒ  rØ  rì  rð  ró  r÷  Úmachiner  r  Úsplitr  r  r  r   rr  r#  r1  r7  r8  r9  r>  rC  rE  rK  rM  rS  rT  ra  ÚnetworkÚflakyrb  r~  rc  r“  r”  r˜  r™  r¯  r1   r1   r1   r2   Ú<module>   sf   $

ÿ
	þ




"



Gþÿ

	





ÿ
	

ÿ

ÿ

		ÿÿýÿ
	!


!

þ
!ÿ



ÿ

ýþ
	ÿ


	7
	

