o
    ‘iv  ã                   @   sâ  d dl Z d dlZd dlmZmZmZm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mZmZ d dlmZ d dlmZmZ dd„ Zd	d
„ Zedgdddddd„ ƒZdd„ Zdd„ Z dd„ Z!dd„ Z"dd„ Z#dd„ Z$dd„ Z%G d d!„ d!ej&ƒZ'G d"d#„ d#ƒZ(G d$d%„ d%ƒZ)d&d'„ Z*d(d)„ Z+d*d+„ Z,d,d-„ Z-d.d/„ Z.d0d1„ Z/d2d3„ Z0d4d5„ Z1d6d7„ Z2d8d9„ Z3d:d;„ Z4d<d=„ Z5d>d?„ Z6ej7 8d@g dA¢¡dBdC„ ƒZ9dDdE„ Z:dFdG„ Z;dHdI„ Z<edJgdKdLdM„ ƒZ=dNdO„ Z>dPdQ„ Z?dS )Ré    N)Úassert_allcloseÚassert_almost_equalÚassert_array_equalÚassert_array_almost_equal)Úscale)ÚAffine2DÚBboxÚTransformedBbox)ÚPath)Úimage_comparisonÚcheck_figures_equalc                  C   s^   G dd„ dt jƒ} | ƒ }t ¡ }tjt d¡||j d t ¡  d|_	|j
 ¡  t ¡  d S )Nc                       sD   e Zd ZdZd ZZdZ‡ fdd„Zdd„ ZeZ	dd	„ Z
e
Z‡  ZS )
z<test_non_affine_caching.<locals>.AssertingNonAffineTransformz
        This transform raises an assertion error when called when it
        shouldn't be and ``self.raise_on_transform`` is True.

        é   Fc                    s.   t ƒ j|i |¤Ž d| _t ¡  dd¡| _d S )NFé
   )ÚsuperÚ__init__Úraise_on_transformÚmtransformsr   r   Úunderlying_transform)ÚselfÚargsÚkwargs©Ú	__class__© úo/var/www/html/eduruby.in/lip-sync/lip-sync-env/lib/python3.10/site-packages/matplotlib/tests/test_transforms.pyr      s   zEtest_non_affine_caching.<locals>.AssertingNonAffineTransform.__init__c                 S   ó   | j rJ dƒ‚| j |¡S ©Nz3Invalidated affine part of transform unnecessarily.)r   r   Útransform_path©r   Úpathr   r   r   Útransform_path_non_affine    ó   ÿzVtest_non_affine_caching.<locals>.AssertingNonAffineTransform.transform_path_non_affinec                 S   r   r   )r   r   Ú	transformr   r   r   r   Útransform_non_affine&   r!   zQtest_non_affine_caching.<locals>.AssertingNonAffineTransform.transform_non_affine)Ú__name__Ú
__module__Ú__qualname__Ú__doc__Ú
input_dimsÚoutput_dimsÚ	is_affiner   r    r   r#   r"   Ú__classcell__r   r   r   r   ÚAssertingNonAffineTransform   s    r,   r   ©r"   T)r   Ú	TransformÚpltÚaxesÚplotÚnpÚarangeÚ	transDataÚdrawr   Ú	transAxesZ
invalidate)r,   Zmy_transÚaxr   r   r   Útest_non_affine_caching   s   
r8   c                  C   sn   G dd„ dƒ} t  ¡ }t jt d¡| dƒd\}| dd¡ | dd¡ t| ¡ j	 
¡ t ¡  d¡ 
¡ ƒ d S )Nc                   @   s   e Zd Zdd„ Zdd„ ZdS )z-test_external_transform_api.<locals>.ScaledByc                 S   s
   || _ d S ©N)Ú_scale_factor)r   Zscale_factorr   r   r   r   9   s   
z6test_external_transform_api.<locals>.ScaledBy.__init__c                 S   s   t  ¡  | j¡|j S r9   )r   r   r   r:   r4   )r   r0   r   r   r   Ú_as_mpl_transform<   s   ÿz?test_external_transform_api.<locals>.ScaledBy._as_mpl_transformN)r$   r%   r&   r   r;   r   r   r   r   ÚScaledBy8   s    r<   r   r-   r   éd   )r/   r0   r1   r2   r3   Zset_xlimZset_ylimr   Zget_transformZ_aÚ
get_matrixr   r   r   )r<   r7   Úliner   r   r   Útest_external_transform_api7   s   ÿr@   Zpre_transform_dataTZmpl20gš™™™™™©?)Zremove_textÚstyleZtolc               
   C   s¼  t  ¡ } t ¡  d¡}| jt d¡ dd¡|| j	 d | j
t ddd¡t d	dd
¡t d¡ dd¡|| j	 d | jt dd¡t dd¡|| j	 d t ddd¡}t ddd¡}dt |¡ t |d d …tjf ¡ }t |¡t |d d …tjf ¡ }| j|||||| j	 t ||¡d |d d d… |d d d… }}|d d d…d d d…f |d d d…d d d…f }}| j||d |||| j	 d | j|d |d |d |d || j	 d d S )Nr   é0   é   é   r-   r   é   é   g      @é	   é   é   é   r   )r"   Z	linewidthé   )r/   r0   r   r   r   Úcontourfr2   r3   Zreshaper4   Ú
pcolormeshÚlinspaceZscatterÚsinÚcosZnewaxisZ
streamplotÚhypotZquiverZbarbs)r7   Ztimes10ÚxÚyÚuÚvr   r   r   Útest_pre_transform_plottingI   s,   "ýÿ&"
ÿ2.rV   c                  C   s‚   t  ¡ } t t ddd¡t ddd¡¡\}}| j||t || ¡t ¡  	d¡| j
 d t ddgd	d
gg¡}t|| j ¡ ƒ d S )Né   rH   çÍÌÌÌÌÌ(@ç      )@çš™™™™™¹?r-   ç      ø?ç×£p=
×ó?ç       @ç      ô?)r/   r0   r2   ÚmeshgridrN   rL   Úlogr   r   r   r4   Úarrayr   ÚdataLimÚ
get_points©r7   ZxsZysÚexpectedr   r   r   Ú!test_contour_pre_transform_limitsn   s   $ÿ
ÿrf   c                  C   ó’   t  ¡ } t t ddd¡t ddd¡¡\}}| j||t || ¡d d…d d…f t ¡  	d¡| j
 d t dd	gd
dgg¡}t|| j ¡ ƒ d S ©NrW   rH   rX   rY   éÿÿÿÿrZ   r-   r[   r\   r]   r^   )r/   r0   r2   r_   rN   Zpcolorr`   r   r   r   r4   ra   r   rb   rc   rd   r   r   r   Ú test_pcolor_pre_transform_limitsy   ó   $$ÿ
ÿrj   c                  C   rg   rh   )r/   r0   r2   r_   rN   rM   r`   r   r   r   r4   ra   r   rb   rc   rd   r   r   r   Ú$test_pcolormesh_pre_transform_limits…   rk   rl   c                  C   s’   t j d¡ t  ddd¡} t  ddd¡}t  | |¡\}}t  t jj|jŽ d ¡}t 	¡ }|j
dd	d
}| dd¡ |j|||dd |j ¡  d S )Né!N,r   é´   rK   r=   iè  r   éo   Úpolar©Z
projectionée   Zgouraud)Zshading)r2   ÚrandomÚseedrN   r_   ÚradiansZrandÚshaper/   ZfigureZadd_subplotZset_rlimrM   Úcanvasr5   )ÚvaluesZradiiÚzrS   rR   Úfigr7   r   r   r   Útest_pcolormesh_gouraud_nans‘   s   r{   c                  C   sÄ  t  ddgddgddgg¡} tj dddddd¡}| | ¡}t  ddgddgddgg¡}t||ƒ tj dddddd¡}| | ¡}t  ddgddgddgg¡}t||ƒ tj dddddd¡}| | ¡}t  ddgd	dgddgg¡}t||ƒ tj dddd
dd¡}| | ¡}t  ddgddgddgg¡}t||ƒ tj dddddd¡}| | ¡}t  ddgddgddgg¡}t||ƒ tj dddddd¡}| | ¡}t  ddgddgddgg¡}t||ƒ d S )Nr   r   rH   ri   rI   r   éþÿÿÿrK   é<   rE   éP   rJ   rC   )r2   ra   r   r   Zfrom_valuesr"   r   )ÚpointsÚtÚactualre   r   r   r   Útest_Affine2D_from_values¤   s8   
þ










r‚   c                  C   sX   ddg} t  ¡ }t| | | ¡  | ¡¡ƒ | dd¡ ¡  t| | | ¡  | ¡¡ƒ d S )Nç      ð?)r   r   r   r"   ÚinvertedÚ	translater>   )Úpointr€   r   r   r   Ú test_affine_inverted_invalidatedÉ   s
   r‡   c                  C   sh   t  g d¢¡} t t ¡ t dd¡¡}| | ¡}|j| 	¡ ddd}t
|Ž \}}t|| jd d… ƒ d S )N))çš™™™™™É?éÿÿÿ)çš™™™™™Ù?r‰   )rŠ   rH   )rˆ   rH   r   Úclip)r   r   r=   r=   F)r‹   Úsimplifyri   )r
   Z_create_closedr   ZBlendedGenericTransformr   r   ÚLogTransformr    Úiter_segmentsÚ
get_affineÚzipr   Úcodes)r   ÚtransZtpathÚresultZtpointsZtcodesr   r   r   Útest_clipping_of_logÔ   s   ÿ

þr”   c                       s<   e Zd ZdZdZdZdZ‡ fdd„Zdd„ Zdd	„ Z	‡  Z
S )
ÚNonAffineForTestzÚ
    A class which looks like a non affine transform, but does whatever
    the given transform does (even if it is affine). This is very useful
    for testing NonAffine behaviour with a simple Affine transform.

    Fr   c                    s   || _ tƒ j|i |¤Ž d S r9   )Ú
real_transr   r   )r   r–   r   r   r   r   r   r   í   s   zNonAffineForTest.__init__c                 C   ó   | j  |¡S r9   )r–   r"   )r   rx   r   r   r   r#   ñ   ó   z%NonAffineForTest.transform_non_affinec                 C   r—   r9   )r–   r   r   r   r   r   r    ô   r˜   z*NonAffineForTest.transform_path_non_affine)r$   r%   r&   r'   r*   r)   r(   r   r#   r    r+   r   r   r   r   r•   â   s    r•   c                   @   s<   e Zd Zdd„ Zdd„ Zdd„ Zdd„ Zd	d
„ Zdd„ ZdS )ÚTestBasicTransformc                 C   sà   t jdd tjd ¡| _t jdd dd¡| _t jdd dd¡| _	t
t  ¡  dd¡d	d| _t
t  ¡  dd¡d
d| _t
t  ¡  dd¡dd| _| j| j| j  | j	 | _| j| j | j | j	 | _| j| j | j	 | _d S )NÚta1)Zshorthand_namer   Úta2r   r   Úta3rI   Útn1Útn2Útn3)r   r   Úrotater2   Úpirš   r…   r›   r   rœ   r•   r   rž   rŸ   Ústack1Ústack2Ústack2_subset©r   r   r   r   Úsetup_methodù   s   ÿÿÿzTestBasicTransform.setup_methodc                 C   s4   | j jdksJ ‚| jjdksJ ‚| jjdksJ ‚d S )NrE   rK   )r¢   Údepthr£   r¤   r¥   r   r   r   Útest_transform_depth  s   z'TestBasicTransform.test_transform_depthc                 C   s¢   | j | j| j| j   | j }|| j| j| j  | j | j| j | j | j| j | jg}dd„ | ¡ D ƒ}t|ƒt|ƒks?J ‚t||ƒD ]
\}}||ksNJ ‚qDd S )Nc                 S   s   g | ]\}}|‘qS r   r   )Ú.0Ú_Zrhr   r   r   Ú
<listcomp>!  s    zCTestBasicTransform.test_left_to_right_iteration.<locals>.<listcomp>)rš   r   r›   rž   rœ   Z_iter_break_from_left_to_rightÚlenr   )r   Zstack3Ztarget_transformsÚrZtarget_stackÚstackr   r   r   Útest_left_to_right_iteration  s   
üÿz/TestBasicTransform.test_left_to_right_iterationc                 C   sN  | j | j | jksJ ‚| j| j | jksJ ‚| j| j | j ¡ ks#J ‚| j| j jdks.J ‚t t¡ | j | j  W d   ƒ n1 sDw   Y  | j| j	| j
  }| j	| j
 }|| | jksaJ ‚|| j	 || j	 ¡  ksoJ ‚| j | j
 | j| j| j	  ks€J ‚| j| j
 | j| j | j	 ks‘J ‚| j	| j
 | j
 | j
 | j	| j
 ks¥J ‚d S )NrI   )r¢   r¤   rš   r£   r„   r§   ÚpytestÚraisesÚ
ValueErrorr›   rœ   r   )r   Zaff1Zaff2r   r   r   Útest_transform_shortcuts'  s    ÿ""
ÿz+TestBasicTransform.test_transform_shortcutsc                 C   s:  | j | j }| j | j }||ksJ ‚|| jksJ ‚| |¡s J ‚| | j¡s(J ‚| | j ¡r0J ‚| | j | j  ¡r;J ‚||ksAJ ‚| j | j¡sJJ ‚| j | j¡sSJ ‚| j | j¡s\J ‚| j | j¡seJ ‚| j | j¡rnJ ‚| j | j¡rwJ ‚| j | j | j ¡sƒJ ‚| j | j | j ¡sJ ‚| j | j| j  ¡r›J ‚d S r9   )r›   rš   Zcontains_branchr¢   rœ   r£   r¤   r   )r   Úr1Úr2r   r   r   Útest_contains_branch=  s$   z'TestBasicTransform.test_contains_branchc                 C   s  t jddgddgt jdgddggt jd}| j |¡}| j |¡}t jddgd	d
gt jt jgddggt jd}t jddgddgt jt jgddggt jd}t||ƒ t||ƒ t| j |¡|ƒ t| j 	¡  |¡|ƒ | j
| j  ¡ }| j 	¡  ¡ }t||ƒ | j 	¡  ¡ }t||ƒ d S )Nr   r   rH   rI   ri   )Zdtyperƒ   r]   g      3Àç      (@g      &@g      @g      "Àg      8@)r2   ra   ÚnanZfloat64r¢   r#   r"   r   Útransform_affiner   r›   rœ   r>   r   r£   )r   r   Zna_ptsZall_ptsZna_expectedZall_expectedZexpected_resultr“   r   r   r   Útest_affine_simplificationW  s8    ÿÿÿÿþ

ÿÿ
z-TestBasicTransform.test_affine_simplificationN)	r$   r%   r&   r¦   r¨   r¯   r³   r¶   rº   r   r   r   r   r™   ø   s    r™   c                   @   s\   e Zd Zdd„ Zdd„ Zdd„ Zdd„ Zd	d
„ Zdd„ Zdd„ Z	dd„ Z
dd„ Zdd„ ZdS )ÚTestTransformPlotInterfacec                 C   sT   t  ¡ }|jg d¢g d¢|jd t|j ¡ t tj	tj	gtj	 tj	 gg¡ƒ d S )N©rZ   ç333333ó?çš™™™™™é?©çÍÌÌÌÌÌì?ç      à?r¾   r-   )
r/   r0   r1   r6   r   rb   rc   r2   ra   Úinf©r   r7   r   r   r   Útest_line_extent_axes_coords~  s   
ÿÿz7TestTransformPlotInterface.test_line_extent_axes_coordsc                 C   sH   t  ¡ }|jg d¢g d¢|jd t|j ¡ t ddgddgg¡ƒ d S )Nr¼   r¿   r-   rZ   rÁ   r½   rÀ   )	r/   r0   r1   r4   r   rb   rc   r2   ra   rÃ   r   r   r   Útest_line_extent_data_coords†  s
   
ÿz7TestTransformPlotInterface.test_line_extent_data_coordsc                 C   s\   t  ¡ }t |j|j¡}|jg d¢g d¢|d t|j 	¡ t
 t
jdgt
j dgg¡ƒ d S )Nr¼   ©é#   éûÿÿÿé   r-   g      Àg     €A@)r/   r0   r   Úblended_transform_factoryr6   r4   r1   r   rb   rc   r2   ra   rÂ   ©r   r7   r’   r   r   r   Ú!test_line_extent_compound_coords1  s   ÿ

ÿÿz<TestTransformPlotInterface.test_line_extent_compound_coords1c                 C   sZ   t  ¡ }t ¡  d¡|j }|jg d¢g d¢|d t|j 	¡ t
 ddgddgg¡ƒ d S )	Nr   r¼   rÆ   r-   rƒ   ç      IÀr·   ç     àu@)r/   r0   r   r   r   r4   r1   r   rb   rc   r2   ra   rË   r   r   r   Ú)test_line_extent_predata_transform_coords˜  s   
ÿzDTestTransformPlotInterface.test_line_extent_predata_transform_coordsc                 C   sj   t  ¡ }t |jt ¡  d¡|j ¡}|jg d¢g d¢|d t	|j
 ¡ t tjdgtj dgg¡ƒ d S )Nr   r¼   rÆ   r-   rÍ   rÎ   )r/   r0   r   rÊ   r6   r   r   r4   r1   r   rb   rc   r2   ra   rÂ   rË   r   r   r   Ú!test_line_extent_compound_coords2   s   ÿ
ÿz<TestTransformPlotInterface.test_line_extent_compound_coords2c                 C   s`   t  ¡ }t ¡  dd¡}t jt d¡||j d t 	ddgddgg¡d }t
|j ¡ |ƒ d S )Nr   r-   ç        ç      "@©r/   r0   r   r   r…   r1   r2   r3   r4   ra   r   rb   rc   ©r   r7   ÚoffsetÚexpected_data_limr   r   r   Útest_line_extents_affineª  s
   z3TestTransformPlotInterface.test_line_extents_affinec                 C   sx   t  ¡ }t ¡  dd¡}tt ¡  dd¡ƒ}t jt d¡|| |j	 d t 
ddgddgg¡d }t|j ¡ |ƒ d S )Nr   r-   rÑ   rÒ   rH   )r/   r0   r   r   r…   r•   r1   r2   r3   r4   ra   r   rb   rc   )r   r7   rÕ   Ú	na_offsetrÖ   r   r   r   Útest_line_extents_non_affine±  s   z7TestTransformPlotInterface.test_line_extents_non_affinec                 C   sœ   t  ¡ }t ¡  dd¡}tt ¡  dd¡ƒ}tddgddgddgddggƒ}tj||| |j	 d}| 
|¡ t ddgddgg¡d }t|j ¡ |ƒ d S )Nr   r   r-   rÑ   ç      $@rH   )r/   r0   r   r   r…   r•   r
   ÚmpatchesÚ	PathPatchr4   Ú	add_patchr2   ra   r   rb   rc   )r   r7   rÕ   rØ   ÚpthÚpatchrÖ   r   r   r   Útest_pathc_extents_non_affine¹  s    ÿ
z8TestTransformPlotInterface.test_pathc_extents_non_affinec                 C   s„   t  ¡ }t ¡  dd¡}tddgddgddgddggƒ}tj|||j d}| 	|¡ t
 ddgddgg¡d }t|j ¡ |ƒ d S )Nr   r   r-   rÑ   rÚ   )r/   r0   r   r   r…   r
   rÛ   rÜ   r4   rÝ   r2   ra   r   rb   rc   )r   r7   rÕ   rÞ   rß   rÖ   r   r   r   Útest_pathc_extents_affineÄ  s    
z4TestTransformPlotInterface.test_pathc_extents_affinec                 C   sh   t jdd}t ¡  dd¡}t jt d¡||j d t 	ddgddgg¡ddg }t
|j ¡ |ƒ d S )Nrp   rq   r   r   r-   rÑ   rÒ   rÓ   rÔ   r   r   r   Ú*test_line_extents_for_non_affine_transDataÍ  s
   zETestTransformPlotInterface.test_line_extents_for_non_affine_transDataN)r$   r%   r&   rÄ   rÅ   rÌ   rÏ   rÐ   r×   rÙ   rà   rá   râ   r   r   r   r   r»   }  s    
	r»   c                 C   s   t | j|jƒ d S r9   )r   Zbounds)Zbbox1Zbbox2r   r   r   Úassert_bbox_eqÚ  s   rã   c                  C   s0   t jjdddddd} |  ¡ }t|j| jƒ d S )NrÑ   rƒ   )Úminpos)r   r   Úfrom_extentsÚfrozenr   rä   )Zbboxræ   r   r   r   Útest_bbox_frozen_copies_minposÞ  s   rç   c                  C   sÀ   t jj} t jj}| ddddƒ}| ddddƒ}| ddddƒ}| ddddƒ}| ddddƒ}t|||ƒ|ƒ t|||ƒ| ddddƒƒ t|||ƒ|ƒ |||ƒd u sQJ ‚t|||ƒ| ddddƒƒ d S )Nr   rI   rÁ   r[   ç      è?g      @r   )r   r   rå   Úintersectionrã   )Zbbox_from_extÚinterr´   rµ   Zr3Zr4Zr5r   r   r   Útest_bbox_intersectionä  s   rë   c                  C   s°   t  ddgddgg¡} t| tt| ƒdt jiƒƒ tt| ƒdtiƒ}| ¡ D ]\}}t| |ƒ|ks2J ‚q%d}tt	| |ƒdtiƒ}| ¡ D ]\}}tt	t| |ƒ|ƒƒ|ksUJ ‚qCd S )NrÁ   r   rè   r   z.1f)
r   r   rã   ÚevalÚreprÚstrÚdictÚitemsÚgetattrÚformat)ÚbÚasdictÚkrU   Úfmtr   r   r   Útest_bbox_as_stringsú  s   ÿr÷   c                   C   s   t tjddjƒdksJ ‚d S )Nrp   rq   aØ  CompositeGenericTransform(
    CompositeGenericTransform(
        CompositeGenericTransform(
            TransformWrapper(
                BlendedAffine2D(
                    IdentityTransform(),
                    IdentityTransform())),
            CompositeAffine2D(
                Affine2D().scale(1.0),
                Affine2D().scale(1.0))),
        PolarTransform(
            PolarAxes(0.125,0.1;0.775x0.8),
            use_rmin=True,
            _apply_theta_transforms=False)),
    CompositeGenericTransform(
        CompositeGenericTransform(
            PolarAffine(
                TransformWrapper(
                    BlendedAffine2D(
                        IdentityTransform(),
                        IdentityTransform())),
                LockableBbox(
                    Bbox(x0=0.0, y0=0.0, x1=6.283185307179586, y1=1.0),
                    [[-- --]
                     [-- --]])),
            BboxTransformFrom(
                _WedgeBbox(
                    (0.5, 0.5),
                    TransformedBbox(
                        Bbox(x0=0.0, y0=0.0, x1=6.283185307179586, y1=1.0),
                        CompositeAffine2D(
                            Affine2D().scale(1.0),
                            Affine2D().scale(1.0))),
                    LockableBbox(
                        Bbox(x0=0.0, y0=0.0, x1=6.283185307179586, y1=1.0),
                        [[-- --]
                         [-- --]])))),
        BboxTransformTo(
            TransformedBbox(
                Bbox(x0=0.125, y0=0.09999999999999998, x1=0.9, y1=0.9),
                BboxTransformTo(
                    TransformedBbox(
                        Bbox(x0=0.0, y0=0.0, x1=8.0, y1=6.0),
                        Affine2D().scale(80.0))))))))rî   r/   Zsubplotr4   r   r   r   r   Útest_str_transform  s   rø   c                  C   s$   t  ¡ } |  d¡}|jdksJ ‚d S )N©rI   rI   )r   )r   r   r¹   rv   )r€   r­   r   r   r   Útest_transform_single_point8  s   
rú   c                  C   s&   t  ¡ \} }| d¡ |j d¡ d S )Nr`   rù   )r/   ÚsubplotsÚ
set_yscaler4   r"   )rz   r7   r   r   r   Útest_log_transform>  s   
rý   c                  C   s@   t  ddgddgg¡} t  ddgdtjgg¡}|  |¡rJ ‚d S )Nr   rI   )r   r   r2   r¸   Úoverlaps)Úaró   r   r   r   Útest_nan_overlapF  s   r   c                  C   sÚ   t  ¡ } t g d¢¡}t ddgddgddgg¡}|  ||¡}t||ƒ t t¡ |  ||dd…dd…f ¡ W d   ƒ n1 sBw   Y  t t¡ |  ||dd…d d …f ¡ W d   ƒ d S 1 sfw   Y  d S )N)rH   é-   r}   r   rI   r   )	r   r   r2   ra   Ztransform_anglesr   r°   r±   r²   )r€   Zanglesr   Z
new_anglesr   r   r   Útest_transform_anglesL  s   
ÿ"ÿr  c                  C   sF   t  ddg¡} dt jfddg}|D ]}t  tj|Ž ¡}t|| ƒ qd S )Ngü©ñÒMbP¿gü©ñÒMbP?r   ©r   r   )r   güó     )r2   ra   r¸   r   Znonsingularr   )Zzero_expansionÚcasesr   Úoutr   r   r   Útest_nonsingular^  s   þr  c                  C   sX  t  ¡ } t t¡ |  d¡ W d   ƒ n1 sw   Y  t t¡ |  dggg¡ W d   ƒ n1 s6w   Y  t t¡ |  g ¡ W d   ƒ n1 sPw   Y  t t¡ |  dg¡ W d   ƒ n1 skw   Y  t t¡ |  dgg¡ W d   ƒ n1 s‡w   Y  t t¡ |  g d¢g¡ W d   ƒ d S 1 s¥w   Y  d S )NrI   )rI   r   rK   )r   r   r°   r±   r²   r"   ÚRuntimeError©r€   r   r   r   Útest_invalid_argumentsg  s&   ÿÿÿÿÿ"ÿr	  c                  C   sÂ   g d¢} t | dd}t ¡ }t ||¡}t| ¡ j| ƒ dt d¡ }| 	tj
d ¡ t| ¡ jd||fdd| f| |fgd	d
 dgd |_t| ¡ jd||fdd| f| |fgd	d
 d S )N)r  )rI   r   rù   )r   rI   T)ÚclosedrI   r   rE   r  r   gVçž¯Ò<)Zatol)r
   r   r   ZTransformedPathr   Úget_fully_transformed_pathÚverticesr2   Úsqrtr    r¡   r   )r   r   r’   Z
trans_pathrµ   r   r   r   Útest_transformed_path|  s    
þ

þr  c                  C   sl   t  ¡ } tjdddd| d}t  |¡}| ¡ j}|  d¡ t| ¡ j|d ƒ | 	d¡ t| ¡ j|ƒ d S )Nr  rI   r  é‡   r-   r   rÁ   )
r   r   rÛ   ZWedgeZTransformedPatchPathr  r  r   r   Z
set_radius)r’   rß   Ztpatchr   r   r   r   Útest_transformed_patch_path’  s   



r  Úlocked_element©Zx0Zy0Úx1Úy1c                 C   sv  g d¢}|  | ¡ tj ¡ }tj|fi | di¤Ž}t|| ƒdks"J ‚t|d|  ƒdks-J ‚|D ]}t||ƒt||ƒks=J ‚q/| | ¡ d ¡ t|| ƒdksPJ ‚t|d|  ƒdks[J ‚|D ]}t||ƒt||ƒkskJ ‚q]t|d|  d ƒ t|d|  ƒd u sJ ‚t	 
| ¡ | ¡ k¡sŒJ ‚t|d|  dƒ t|| ƒdksJ ‚t|d|  ƒdks¨J ‚|D ]}t||ƒt||ƒks¸J ‚qªd S )Nr  r   Zlocked_r   rK   )Úremover   r   ÚunitZLockableBboxrñ   Z
set_pointsrc   Úsetattrr2   Úall)r  Zother_elementsÚorigÚlockedÚelemr   r   r   Útest_lockable_bbox£  s,   

ÿr  c                  C   s²   t  ¡ } t  ¡ }| | }| ¡  t |¡}|js|jrJ ‚|  dd¡ |jr)|js+J ‚| ¡ |  ¡ k ¡ s7J ‚| ¡  t |¡}| dd¡ |jrKJ ‚| ¡ |  ¡ k ¡ sWJ ‚d S ©NrI   r   rK   rE   )r   r   r>   ÚcopyÚ_invalidr…   r  ©rÿ   ró   ÚsÚs1Úb1r   r   r   Ú	test_copyÅ  s   


r$  c                  C   s¶   t  ¡ } t  ¡ }| | }| ¡  t |¡}|js|jrJ ‚|  dd¡ |jr)|jr+J ‚| ¡ t  ¡  ¡ k ¡ s9J ‚| ¡  t |¡}| dd¡ |jrMJ ‚| ¡ |  ¡ k ¡ sYJ ‚d S r  )r   r   r>   r  Údeepcopyr  r…   r  r   r   r   r   Útest_deepcopyØ  s   


r&  c                  C   sR   t  t  ¡ ¡} tjtdd |  t d¡¡ W d   ƒ d S 1 s"w   Y  d S )Nz`The input and output dims of the new child \(1, 1\) do not match those of current child \(2, 2\)©Úmatchr   )	r   ZTransformWrapperr   r°   r±   r²   Úsetr   r   r  r   r   r   Útest_transformwrapperë  s   ÿ"ýr*  Zpng)Ú
extensionsc              	   C   s    t j d¡ t jjdd}t  ddd¡}t| |gddgƒD ]0\}}| ¡ }|j||dd | |t  	|d	  d	 ¡t  
d	t j ¡ ¡ |j ¡  | d
¡ qd S )Nrm   r   )ÚsizerÈ   rJ   TF)r`   Zdensityr   Zlinear)r2   rs   rt   ÚnormalrN   r   rû   Úhistr1   Úexpr  r¡   rw   r5   rü   )Zfig_testZfig_refZsamplesrR   rz   Z	log_stater7   r   r   r   Útest_scale_swappingó  s   ,
ûr0  c                   C   s~   t jtdd tjd dd W d   ƒ n1 sw   Y  t jtdd tjd dd W d   ƒ d S 1 s8w   Y  d S )NzZ'fontsize' is not a valid value for units; supported values are 'dots', 'points', 'inches'r'  Zfontsize)Zunitsz3For units of inches or points a fig kwarg is neededZinches)r°   r±   r²   r   Zoffset_copyr   r   r   r   Útest_offset_copy_errors  s   ÿýÿ"þr1  c                  C   s’   t t ¡ tƒ  d¡ƒ} |  dd¡sJ ‚|  dd¡sJ ‚|  dd¡r#J ‚t t ¡ tƒ  dd¡ƒ} |  dd	¡s7J ‚|  dd	¡r?J ‚|  d
d
¡rGJ ‚d S )Né   r¾   rÁ   gš™™™™™Ù¿g333333ë?rÀ   g      Ð?r^   r[   rZ   )r	   r   r  r   Z
rotate_degÚcontainsr…   Zfully_contains)Zbbr   r   r   Útest_transformedbbox_contains  s   r4  )@r  Únumpyr2   Znumpy.testingr   r   r   r   r°   Z
matplotlibr   Zmatplotlib.pyplotZpyplotr/   Zmatplotlib.patchesZpatchesrÛ   Zmatplotlib.transformsZ
transformsr   r   r   r	   Zmatplotlib.pathr
   Zmatplotlib.testing.decoratorsr   r   r8   r@   rV   rf   rj   rl   r{   r‚   r‡   r”   r.   r•   r™   r»   rã   rç   rë   r÷   rø   rú   rý   r   r  r  r	  r  r  ÚmarkZparametrizer  r$  r&  r*  r0  r1  r4  r   r   r   r   Ú<module>   sd    &
ÿ
#% ]2	
!

