o
    Õj÷X  ã                   @   s,  d dl Z d dlmZmZ d dlmZmZmZmZm	Z	m
Z
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Zd dlZdZdd	„ Zd
d„ Zdd„ Zdd„ Zej d¡dd„ ƒZdd„ Z ej !dg d¢¡dd„ ƒZ"dd„ Z#dd„ Z$dd„ Z%dd „ Z&ej !d!d"d#g¡ej !d$d%d&g¡ej !d'd(ej'd)fd(ej(d*fd+ej'd,fd+ej(d-fg¡d.d/„ ƒƒƒZ)d0d1„ Z*d2d3„ Z+ej !d4d5d6dej,d7ed8g¡d9d:„ ƒZ-ej !d;g d<¢¡d=d>„ ƒZ.d?d@„ Z/dAdB„ Z0dCdD„ Z1ej !dEd(d+g¡ej !dFej'ej(g¡ej !dGdHdIg¡ej !dJg dK¢¡ej !dLdMdNg¡dOdP„ ƒƒƒƒƒZ2dS )Qé    N)ÚpathÚ
transforms)ÚFigureCanvasBaseÚKeyEventÚLocationEventÚMouseButtonÚ
MouseEventÚNavigationToolbar2ÚRendererBase)ÚRubberbandBase©ÚFigure)Úneeds_pgf_xelatexzƒTreat the new Tool classes introduced in v[0-9]*.[0-9]* as experimental for now; the API and rcParam may change in future versions.c               	      sR  t  ¡ ‰ dd„ tddƒD ƒ} ‡ fdd„tddƒD ƒ}t d¡ d	¡}d
dg}d
dg}dd„ }|ˆ | ||||ƒ |ˆ | dd… ||||ƒ |ˆ g ||||ƒ |ˆ | |dd… |||ƒ |ˆ | g |||ƒ td|jd ƒD ]}|ˆ | ||d|…d d …f ||ƒ qk|ˆ | ||g |ƒ |ˆ | |||g ƒ |ˆ | ||g g ƒ |ˆ | |||dd… |ƒ d S )Nc                 S   s   g | ]}t j |¡‘qS © )r   ÚPathZunit_regular_polygon©Ú.0Úir   r   úd/var/www/html/Deteccion_Ine/venv/lib/python3.10/site-packages/matplotlib/tests/test_backend_bases.pyÚ
<listcomp>   s    z&test_uses_per_path.<locals>.<listcomp>é   é   c                    s   g | ]}ˆ   |¡ ¡  ¡ ‘qS r   )ÚrotateZ
get_matrixÚcopyr   ©Úidr   r   r      s    é   é   é   )é
   é   ÚredÚgreenc                 S   s¢   t ƒ }t| | ||¡ƒ}| ¡ }dd„ | |tt|ƒƒ|t | ¡||g g dgg d¡D ƒ}	| 	|||||¡}
|rMt
j|	t|ƒd}t|ƒ |
d |
g¡sOJ ‚d S d S )Nc                 S   s   g | ]	\}}}}}|‘qS r   r   )r   ZxoZyoZpath_idZgc0ZrgbFacer   r   r   r   $   s    z5test_uses_per_path.<locals>.check.<locals>.<listcomp>FÚscreen)Z	minlengthr   )r
   ÚlistZ_iter_collection_raw_pathsZnew_gcZ_iter_collectionÚrangeÚlenr   ZAffineDeltaTransformZ_iter_collection_uses_per_pathÚnpZbincountÚsetÚissubset)Zmaster_transformÚpathsZall_transformsÚoffsetsÚ
facecolorsÚ
edgecolorsÚrbZ	raw_pathsÚgcZidsZusesÚseenr   r   r   Úcheck   s*   ÿüÿ
ÿþz!test_uses_per_path.<locals>.checkr   )r   ZAffine2Dr%   r'   ÚarangeÚreshapeÚshape)r*   Ztforms_matricesr+   r,   r-   r1   Únr   r   r   Útest_uses_per_path   s(   ÿr6   c                   C   s   t tƒ jtƒs	J ‚d S ©N)Ú
isinstancer   Úfigurer   r   r   r   r   Útest_canvas_ctor>   s   r:   c                  C   s>   t  ¡ } | j ¡ dksJ ‚| jj d¡ | j ¡ dksJ ‚d S )NzFigure_1.pngz0:1/2<3z0_1_2_3.png)Úpltr9   ÚcanvasZget_default_filenameÚmanagerÚset_window_title©Úfigr   r   r   Útest_get_default_filenameB   s   rA   c                  C   s.   t  ¡ } t| ƒ}t  | ¡ t  | j¡rJ ‚d S r7   )r;   r9   r   ÚcloseZfignum_existsÚnumber)r@   r<   r   r   r   Útest_canvas_changeI   s   
rD   Zpdfc                 C   sÎ   t  ¡  |  dd¡ t t¡}t  ¡  t|ƒdksJ ‚dt|d j	ƒv s'J ‚W d   ƒ n1 s1w   Y  t t¡"}t  
¡  ¡  t|ƒdksJJ ‚dt|d j	ƒv sUJ ‚W d   ƒ d S 1 s`w   Y  d S )NZDISPLAYz:999r   z<FigureCanvasPdf is non-interactive, and thus cannot be shownr   )r;   ÚsubplotsZsetenvÚpytestÚwarnsÚUserWarningÚshowr&   ÚstrÚmessageÚgcf)ZmonkeypatchZrecr   r   r   Útest_non_gui_warningR   s    
ÿý
ÿ"ýrM   c                  C   sD   t  ¡ \} }| j |¡ | jj|ksJ ‚|  ¡  | jjd u s J ‚d S r7   )r;   rE   r<   Z
grab_mouseZmouse_grabberÚclear©r@   Úaxr   r   r   Útest_grab_cleare   s
   rQ   zx, y))é*   é   )NrR   )NN)éÈ   gq=
×£ Y@)g     ¸i@g       @c                 C   s  t  ¡ \}}t|ƒ}td|| |ƒ}| d u r|jd u sJ ‚n|jt| ƒks&J ‚t|jtƒs.J ‚|d u r:|jd u s9J ‚n|jt|ƒksCJ ‚t|jtƒsKJ ‚| d ur||d ur~| | |¡d| 	| ¡› d| 
|¡› dksjJ ‚dd„  |_|_| | |¡dks€J ‚d S d S d S )NZ
test_eventz
(x, y) = (z, ú)c                 S   s   dS )NÚfoor   )Úxr   r   r   Ú<lambda>ƒ   s    z.test_location_event_position.<locals>.<lambda>z(x, y) = (foo, foo))r;   rE   r   r   rW   Úintr8   ÚyÚformat_coordZformat_xdataZformat_ydataZ	fmt_xdataZ	fmt_ydata)rW   rZ   r@   rP   r<   Úeventr   r   r   Útest_location_event_positiono   s&   
ÿür]   c                  C   sz   t  ¡ \} }|jddd | dd¡dksJ ‚| ¡ jdd | dd¡dks)J ‚| ¡ jd	d
 | dd¡dks;J ‚d S )N©r   r   )r   r   )ÚxlimÚylimg      @z(x, y) = (5.00, 5.00))r   é(   )r`   z$(x, y) = (5.00, 5.00) | (5.00, 10.0))r   r   )r_   z3(x, y) = (5.00, 5.00) | (5.00, 10.0) | (2.50, 5.00))r;   rE   r(   r[   ÚtwinxZtwinyrO   r   r   r   Ú!test_location_event_position_twin‡   s   
ÿrc   c                     s¤   t  ¡ } | jddddddd | j ¡  g ‰ ‡ fdd„}| j d|¡ td	| jd
ƒ ¡  td| jg| j	 
d¡¢tj‘R Ž  ¡  td| jd
ƒ ¡  tˆ ƒdksPJ ‚d S )Nç      à?ZhelloÚcenterT)ZhaÚvaZpickerc                    s   | j jdksJ ‚ˆ  | ¡ d S )NÚa)Z
mouseeventÚkeyÚappend)r\   ©Zpicksr   r   Úhandle_pick˜   s   ztest_pick.<locals>.handle_pickZ
pick_eventÚkey_press_eventrg   Úbutton_press_event©rd   rd   Zkey_release_eventr   )r;   r9   Útextr<   ÚdrawZmpl_connectr   Ú_processr   ZtransFigureÚ	transformr   ÚLEFTr&   )r@   rk   r   rj   r   Ú	test_pick’   s   


ÿþrt   c                  C   sÎ  t  ¡ \} }|jdd | ¡ d u sJ ‚t| jƒ}| ¡  | ¡ dks%J ‚| ¡ }| ¡ }d}d}|j	 
|¡ t¡}|j	 
|¡ t¡}td| jg|¢tj‘R Ž }	| jj |	j|	¡ td| jg|¢tj‘R Ž }
| jj |
j|
¡ | ¡ |	j|
jfks{J ‚| ¡ |	j|
jfks‡J ‚td| jg|¢tj‘R Ž }	| jj |	j|	¡ td| jg|¢tj‘R Ž }
| jj |
j|
¡ | ¡ tj|dd	d
ksÁJ ‚| ¡ tj|dd	d
ksÏJ ‚| ¡  | ¡ d u sÛJ ‚| ¡ sã| ¡ råJ ‚d S )NZlogit)ZxscaleÚZOOM)gíµ ÷Æ°>çš™™™™™¹?)gwJëÿï?çš™™™™™é?rm   Úbutton_release_eventr   g»½×Ùß|Û=)ÚrelÚabs)r;   rE   r(   Úget_navigate_moder	   r<   ÚzoomÚget_xlimÚget_ylimÚ	transDatarr   ÚastyperY   r   r   rs   Ú	callbacksÚprocessÚnameZxdataZydataÚRIGHTrF   ÚapproxZget_autoscalex_onZget_autoscaley_on)r@   rP   ÚtbZxlim0Zylim0Úd0Úd1Ús0Ús1Ústart_eventÚ
stop_eventr   r   r   Útest_interactive_zoom¥   sf   
ÿÿÿÿÿÿÿÿÿÿÿÿr   c                  C   sj   t  ¡ \} }| ddgddg¡ | j |¡ t| jƒ}| ¡  | ¡ d u s'J ‚| ¡  | ¡ d u s3J ‚d S )Nr   r   )	r;   rE   Úplotr<   Z
widgetlockr	   r|   r{   Úpan)r@   rP   r†   r   r   r   Útest_widgetlock_zoompanÕ   s   
r   Ú	plot_funcZimshowÚcontourfÚorientationÚverticalÚ
horizontalztool,button,expectedr|   ©é   é   )iìÿÿÿé   r   )éþÿÿÿé   )g…ëQ¸…÷?g…ëQ¸@c                 C   s†  t  ¡ \}}t d¡ d¡}d\}}	t|| ƒ|||	d}
|j|
||d}| dkr1|j ¡ r/J ‚d S |j ¡ s8J ‚d\}}|df}|df}|d	krV|d d d
… }|d d d
… }|jj	 
|¡ t¡}|jj	 
|¡ t¡}td|jg|¢|‘R Ž }td|jg|¢|‘R Ž }t|jƒ}|dkrŸ| ¡  | |¡ | |¡ | |¡ n| ¡  | |¡ | |¡ | |¡ |j|jftj|ddksÁJ ‚d S )Né   )r—   r   r^   )ÚvminÚvmax)rP   r“   r’   r–   rd   r”   éÿÿÿÿrm   rx   r|   ç333333Ã?©rz   )r;   rE   r'   r2   r3   ÚgetattrZcolorbarrP   Úget_navigater   rr   r€   rY   r   r<   r	   r|   Ú
press_zoomÚ	drag_zoomÚrelease_zoomr   Ú	press_panÚdrag_panÚrelease_panr   rž   rF   r…   )r‘   r“   ÚtoolÚbuttonÚexpectedr@   rP   ÚdataZvmin0Zvmax0ZcollÚcbr   rž   r‡   rˆ   r‰   rŠ   r‹   rŒ   r†   r   r   r   Útest_interactive_colorbarà   sT   ÿÿÿÿÿÿ





"r¯   c                  C   sœ   t jttd dtjd< W d   ƒ n1 sw   Y  t ¡ } |  ¡ }|  ¡ d u s,J ‚|j	j
j d¡ |  ¡ dks<J ‚|j	j
j d¡ |  ¡ dksLJ ‚d S )N©ÚmatchÚtoolmanagerÚtoolbarr|   ru   r   ZPAN)rF   rG   rH   Ú_EXPECTED_WARNING_TOOLMANAGERr;   ÚrcParamsZgcaZ
get_figurer{   r<   r=   r²   Útrigger_tool)rP   r@   r   r   r   Útest_toolbar_zoompan  s   ÿr·   c                  C   s¬  t  ¡ \} }| tdƒtdƒ¡ t| jƒ}| ¡  td| jdddƒ ¡  td| jdddƒ ¡  | 	¡ | 
¡   kr>dksAJ ‚ J ‚td| jdddƒ ¡  td| jdddƒ ¡  | 	¡ | 
¡   krfdksiJ ‚ J ‚|j dd	g¡\}}td
| jg|¢tj‘R Ž  ¡  td| jg|¢tj‘R Ž  ¡  td| jdƒ ¡  | 	¡ | 
¡   kr©dks¬J ‚ J ‚td| jdddƒ ¡  td| jdddƒ ¡  | 	¡ | 
¡   krÑdksÔJ ‚ J ‚d S )Né   rl   Úkéd   Úl)r   r   r^   )r    r    )r   r   rm   rx   Úh)r;   rE   rŽ   r%   r	   r<   r|   r   rq   r}   r~   r   rr   r   r   rs   )r@   rP   r†   ÚstartÚstopr   r   r   Ú$test_toolbar_home_restores_autoscale)  s$   
$$$(r¿   ÚbackendÚsvgZpsZpgf)Zmarksc                 C   s  ddl m} ddlm} t d| › ¡}|j}|dd}||ƒ | dd¡}|dd}||ƒ | dd¡}dd	„ | ¡ D ƒ}	|j 	¡  |j 	¡  d
d	„ | ¡ D ƒ}
dd	„ | ¡ D ƒ}t
|	|
ƒD ]\}}tj||ddrmJ ‚q_t
||
ƒD ]\}}tjj||dd qsd S )Nr   r   )ÚFigureCanvaszmatplotlib.backends.backend_T)Zconstrained_layoutr    c                 S   ó   g | ]}|  ¡ ‘qS r   ©Zget_position©r   rP   r   r   r   r   Z  ó    ztest_draw.<locals>.<listcomp>c                 S   rÃ   r   rÄ   rÅ   r   r   r   r   _  rÆ   c                 S   rÃ   r   rÄ   rÅ   r   r   r   r   `  rÆ   g{®Gázt?)Zatol)Úmatplotlib.figurer   Zmatplotlib.backends.backend_aggrÂ   Ú	importlibÚimport_modulerE   Zravelr<   rp   Úzipr'   ZallcloseZtestingZassert_allclose)rÀ   r   rÂ   Ztest_backendZ
TestCanvasZfig_testZ	axes_testZfig_aggZaxes_aggZinit_posZlayed_out_pos_testZlayed_out_pos_aggÚinitZplacedÚrefÚtestr   r   r   Ú	test_drawG  s(   



ÿrÎ   z&key,mouseend,expectedxlim,expectedylim))N©çš™™™™™É?rÐ   ©gìQ¸…ë@g{®Gáú(@©gš™™™™™@gffffff'@)N)rÐ   rd   rÑ   ©r   é	   )N)rd   rÐ   rÓ   rÒ   )Nrn   rÓ   rÓ   )N©rw   ç      Ð?©gÃõ(\ÂÀg…ëQ¸@©g      @g     €&@)N©rÐ   rÖ   rÑ   rØ   )N)rw   ç333333ë?r×   ©g…ëQ¸	Àgq=
×£p@)N©rÐ   rÚ   rÑ   rÛ   )Úshift)rÐ   çš™™™™™Ù?rÑ   rÓ   )rÝ   ©rÞ   rÐ   rÓ   rÒ   )rÝ   rÙ   rÑ   rÑ   )rÝ   rÕ   r×   )gÃõ(\Â@gq=
×£ð(@)rÝ   )rw   gÍÌÌÌÌÌì?©g¤p=
×£Àg¤p=
×£@rà   )rÝ   rÜ   rÑ   )gìQ¸…ëÀg
×£p=
@)rW   )rÐ   rv   rÑ   rÓ   )rZ   )rv   rÐ   rÓ   rÒ   )ÚcontrolrÏ   rÑ   rÑ   )rá   rß   ©gÃõ(\Â@gq=
×£p'@râ   c                 C   s  t  ¡ \}}| t d¡¡ | ¡ sJ ‚| d¡ d}|j |¡ 	t
¡}|j |¡ 	t
¡}td|jg|¢R tj| dœŽ}	td|jg|¢R tj| dœŽ}
t|jƒ}| ¡  | |	¡ | |
¡ | |
¡ t| ¡ ƒtj|ddksrJ ‚t| ¡ ƒtj|ddksJ ‚d S )	Nr   Úequalrn   rm   )r«   rh   rx   g{®Gáz”?r¡   )r;   rE   rŽ   r'   r2   r£   Z
set_aspectr   rr   r€   rY   r   r<   r   rs   r	   r   r§   r¨   r©   Útupler}   rF   r…   r~   )rh   ZmouseendZexpectedxlimZexpectedylimr@   rP   Z
mousestartZsstartÚsendr‹   rŒ   r†   r   r   r   Útest_interactive_pani  s<   
ÿÿþÿÿþ



"ræ   c                  C   s¨   t jttd dtjd< W d   ƒ n1 sw   Y  t ¡ } t| jj	j
jƒ}d| jj	j
jv s2J ‚| jj	j
 d¡ t| jj	j
jƒ|d ksHJ ‚d| jj	j
jvsRJ ‚d S )Nr°   r²   r³   Úforwardr   )rF   rG   rH   r´   r;   rµ   rL   r&   r<   r=   r²   ZtoolsZremove_tool)r@   Zinitial_lenr   r   r   Útest_toolmanager_removeŸ  s   ÿrè   c                  C   s$  t jttd dtjd< W d   ƒ n1 sw   Y  t ¡ } | jjj	 
d¡}t|tƒs/J ‚| jjj	 
|¡|u s;J ‚t jtdd | jjj	 
d¡d u sOJ ‚W d   ƒ n1 sYw   Y  | jjj	j
dddd u slJ ‚t jtdd | jjj	 d¡d u s€J ‚W d   ƒ d S 1 s‹w   Y  d S )	Nr°   r²   r³   Ú
rubberbandz'ToolManager does not control tool 'foo'rV   F)Úwarn)rF   rG   rH   r´   r;   rµ   rL   r<   r=   r²   Zget_toolr8   r   r¶   )r@   ré   r   r   r   Útest_toolmanager_get_toolª  s$   ÿÿþÿ"þrë   c                  C   sø   t jttd dtjd< W d   ƒ n1 sw   Y  t ¡ } d| jjj	 
d¡v s,J ‚t jtdd | jjj	 dd¡ W d   ƒ n1 sGw   Y  | jjj	 
d¡dgksYJ ‚t jtdd | jjj	 d	d¡ W d   ƒ d S 1 suw   Y  d S )
Nr°   r²   r³   Úvrç   z"Key c changed from back to forwardÚcz'foo' not in ToolsrV   )rF   rG   rH   r´   r;   rµ   rL   r<   r=   r²   Zget_tool_keymapZupdate_keymapZraisesÚKeyErrorr?   r   r   r   Útest_toolmanager_update_keymap»  s   ÿÿþ"ÿrï   rª   r«   Ú	patch_visTFÚforward_nav)TFÚautoÚt_sÚtwinÚsharec                 C   sð  t  ¡ \}}|jddd}| |¡ |j |¡ |dkr;| d¡}| |¡ | |¡ | d¡}	|	 |¡ |	 |¡ n|dkrG| ¡ }| ¡ }	| 	d¡ |j 
d	¡ | 	d
¡ |j 
d¡ | 	d¡ |j 
d¡ |	 	d¡ |	j 
d¡ d\}
}||fD ]}|j|
Ž  |j|Ž  q{d\}}}}|j ||f¡ t¡}|j ||f¡ t¡}|j ¡  |¡\}}|j ¡  |¡\}}td|jg|¢|‘R Ž }td|jg|¢|‘R Ž }t|jƒ}| dkr’|dkràdnd}| g |¢|¢|¡\}}| ¡ du r| g |¢|¢|¡\}}n#| ¡ du r|
}|}n|j ¡ s!| g |¢|¢|¡\}}n|
}|}| ¡  | |¡ | |¡ | |¡ | ¡ tj|ddksFJ ‚| ¡ tj|ddksTJ ‚| ¡ tj|ddksbJ ‚| ¡ tj|ddkspJ ‚| ¡ tj| ¡ ddks€J ‚| ¡ tj|	 ¡ ddksJ ‚d S |j g |¢|‘R Ž  |j!|d g|¢R Ž j" t#¡\}}| $¡  | ¡ du rÖ|j g |¢|‘R Ž  |j!|d g|¢R Ž j" t#¡\}}| $¡  n5| ¡ du râ|
}|}n)|j ¡ s|j g |¢|‘R Ž  |j!|d g|¢R Ž j" t#¡\}}| $¡  n|
}|}| %¡  | &|¡ | '|¡ | (|¡ | ¡ tj|ddks,J ‚| ¡ tj|ddks:J ‚| ¡ tj|ddksHJ ‚| ¡ tj|ddksVJ ‚| ¡ tj| ¡ ddksfJ ‚| ¡ tj|	 ¡ ddksvJ ‚d S )NéÝ   éc   )Zzorderrõ   éÞ   éß   rô   Úax_t)r   r   r   rd   Ú	ax_t_twinÚrÚax_b)r   r   r   rd   Ú	ax_b_twinÚb)r^   r^   )r   r    r   r    rm   rx   r|   r   ÚinÚoutTFr    r¡   ))r;   rE   Zadd_subplotZset_forward_navigation_eventsÚpatchZset_visibleZsharexZshareyrb   Z	set_labelZset_facecolorZset_xlimZset_ylimr   rr   r€   rY   Úinvertedr   r<   r	   Z_prepare_view_from_bboxZget_forward_navigation_eventsZget_visibler|   r¤   r¥   r¦   r}   rF   r…   r~   Z	start_panZ_get_pan_pointsÚTÚfloatZend_panr   r§   r¨   r©   )rª   r«   rð   rñ   ró   r@   rý   rú   rû   rþ   Z	init_xlimZ	init_ylimrP   Zxstart_tZxstop_tZystart_tZystop_tr‰   rŠ   Zxstart_bZystart_bZxstop_bZystop_br‹   rŒ   r†   Ú	directionZxlim_tZylim_tZxlim_bZylim_br   r   r   Ú test_interactive_pan_zoom_eventsÈ  s¤   















 $  
 



 $r  )3rÈ   Z
matplotlibr   r   Zmatplotlib.backend_basesr   r   r   r   r   r	   r
   Zmatplotlib.backend_toolsr   rÇ   r   Zmatplotlib.testing._markersr   Zmatplotlib.pyplotZpyplotr;   Únumpyr'   rF   r´   r6   r:   rA   rD   ÚmarkrÀ   rM   rQ   Zparametrizer]   rc   rt   r   r   rs   r„   r¯   r·   r¿   ÚparamrÎ   ræ   rè   rë   rï   r  r   r   r   r   Ú<module>   st    $ÿ(
	

ÿ
0



ýÿ6ÿÿ
þ
!