a
    Sic3                     @   sN   d Z ddlZddlmZ ddlmZ ddlZG dd dZG dd deZ	dS )	z'
Mesh refinement for triangular grids.
    N)_api)Triangulationc                   @   s   e Zd ZdZdd ZdS )
TriRefinera{  
    Abstract base class for classes implementing mesh refinement.

    A TriRefiner encapsulates a Triangulation object and provides tools for
    mesh refinement and interpolation.

    Derived classes must implement:

    - ``refine_triangulation(return_tri_index=False, **kwargs)`` , where
      the optional keyword arguments *kwargs* are defined in each
      TriRefiner concrete implementation, and which returns:

      - a refined triangulation,
      - optionally (depending on *return_tri_index*), for each
        point of the refined triangulation: the index of
        the initial triangulation triangle to which it belongs.

    - ``refine_field(z, triinterpolator=None, **kwargs)``, where:

      - *z* array of field values (to refine) defined at the base
        triangulation nodes,
      - *triinterpolator* is an optional `~matplotlib.tri.TriInterpolator`,
      - the other optional keyword arguments *kwargs* are defined in
        each TriRefiner concrete implementation;

      and which returns (as a tuple) a refined triangular mesh and the
      interpolated values of the field at the refined triangulation nodes.
    c                 C   s   t jt|d || _d S )N)triangulation)r   check_isinstancer   _triangulationselfr    r
   T/var/www/html/django/DPS/env/lib/python3.9/site-packages/matplotlib/tri/trirefine.py__init__*   s    zTriRefiner.__init__N)__name__
__module____qualname____doc__r   r
   r
   r
   r   r      s   r   c                       sB   e Zd ZdZ fddZdddZdd	d
ZedddZ  Z	S )UniformTriRefinerz
    Uniform mesh refinement by recursive subdivisions.

    Parameters
    ----------
    triangulation : `~matplotlib.tri.Triangulation`
        The encapsulated triangulation (to be refined)
    c                    s   t  | d S )N)superr   r   	__class__r
   r   r   =   s    zUniformTriRefiner.__init__F   c                 C   s   | j }|jjd }tj|tjd}t|D ]}| ||\}}q*|jjd }|j}|rtj	|dtjd}	| j j
}
|
du rt|ddd|	|< n\|
| }t|| ddd|	||ddf < t||  ddd|	|| ddf < ||	fS |S dS )a  
        Compute an uniformly refined triangulation *refi_triangulation* of
        the encapsulated :attr:`triangulation`.

        This function refines the encapsulated triangulation by splitting each
        father triangle into 4 child sub-triangles built on the edges midside
        nodes, recursing *subdiv* times.  In the end, each triangle is hence
        divided into ``4**subdiv`` child triangles.

        Parameters
        ----------
        return_tri_index : bool, default: False
            Whether an index table indicating the father triangle index of each
            point is returned.
        subdiv : int, default: 3
            Recursion level for the subdivision.
            Each triangle is divided into ``4**subdiv`` child triangles;
            hence, the default results in 64 refined subtriangles for each
            triangle of the initial triangulation.

        Returns
        -------
        refi_triangulation : `~matplotlib.tri.Triangulation`
            The refined triangulation.
        found_index : int array
            Index of the initial triangulation containing triangle, for each
            point of *refi_triangulation*.
            Returned only if *return_tri_index* is set to True.
        r   dtypeNr   )r   	trianglesshapenparangeint32range_refine_triangulation_oncexfullmaskrepeatreshape)r	   return_tri_indexsubdivZrefi_triangulationntri	ancestors_	refi_nptsZrefi_trianglesfound_indextri_maskZancestor_maskr
   r
   r   refine_triangulation@   sB    


z&UniformTriRefiner.refine_triangulationNc                 C   sb   |du rt j| j|}ntjt jj|d |}| j|dd\}}|j|j	|j
|dd }||fS )a  
        Refine a field defined on the encapsulated triangulation.

        Parameters
        ----------
        z : (npoints,) array-like
            Values of the field to refine, defined at the nodes of the
            encapsulated triangulation. (``n_points`` is the number of points
            in the initial triangulation)
        triinterpolator : `~matplotlib.tri.TriInterpolator`, optional
            Interpolator used for field interpolation. If not specified,
            a `~matplotlib.tri.CubicTriInterpolator` will be used.
        subdiv : int, default: 3
            Recursion level for the subdivision.
            Each triangle is divided into ``4**subdiv`` child triangles.

        Returns
        -------
        refi_tri : `~matplotlib.tri.Triangulation`
             The returned refined triangulation.
        refi_z : 1D array of length: *refi_tri* node count.
             The returned interpolated field (at *refi_tri* nodes).
        N)triinterpolatorT)r&   r%   )	tri_indexr   )
matplotlibtriCubicTriInterpolatorr   r   r   TriInterpolatorr-   _interpolate_multikeysr    y)r	   zr.   r&   interpZrefi_trir+   Zrefi_zr
   r
   r   refine_field   s"    


zUniformTriRefiner.refine_fieldc           $   
   C   s  | j }| j}| j}| j}t|d }t|d }|durrt|}t||fkrrtdt|t|t	|dk}d| | d }	||	 }
t
|
}t
|
}||d|< ||d|< ttj|tjdd}ttjdtjd|}|||f }||k}|| }|| }||||f  ||||d d f   d	 }||||f  ||||d d f   d	 }|||d< |||d< |}tj|dgtjd}|}tdD ]L}||k}t	|}|| }tj|tjd| |dd|f |< ||7 }qt|}|| }|| }t||ddf t|tjdtjd }tj|dd
} || }!||| f |||!f< tj|d dgtjd}"t|dddf |dddf |dddf gj|"dddddf< t|dddf |dddf |dddf gj|"dddddf< t|dddf |dddf |dddf gj|"dddddf< t|dddf |dddf |dddf gj|"dddddf< t|||"}#| jdur|#t| jd |du r|#S |#t|dfS dS )a  
        Refine a `.Triangulation` by splitting each triangle into 4
        child-masked_triangles built on the edges midside nodes.

        Masked triangles, if present, are also split, but their children
        returned masked.

        If *ancestors* is not provided, returns only a new triangulation:
        child_triangulation.

        If the array-like key table *ancestor* is given, it shall be of shape
        (ntri,) where ntri is the number of *triangulation* masked_triangles.
        In this case, the function returns
        (child_triangulation, child_ancestors)
        child_ancestors is defined so that the 4 child masked_triangles share
        the same index as their father: child_ancestors.shape = (4 * ntri,).
        r   NzYIncompatible shapes provide for triangulation.masked_triangles and ancestors: {0} and {1}r   r      r      g      ?)axis   )r    r5   	neighborsr   r   r   asarray
ValueErrorformatsumzerostiler   r   r#   emptyr   logical_notabsouteronesargminvstackTr   r"   set_mask)$r   r(   r    r5   r=   r   nptsr'   bordersZ	added_ptsr*   Zrefi_xZrefi_yZ
edge_elemsZedge_apexesZedge_neighborsZmask_mastersZmastersZapex_mastersZx_addZy_addZnew_pt_cornerZnew_pt_midsideZcum_sumZimidZmask_st_locZn_masters_locZelem_masters_locZmask_slavesZslavesZslaves_mastersZ
diff_tableZslave_masters_apexZslaves_apexZchild_trianglesZchild_triangulationr
   r
   r   r      s    





z,UniformTriRefiner._refine_triangulation_once)Fr   )Nr   )N)
r   r   r   r   r   r-   r8   staticmethodr   __classcell__r
   r
   r   r   r   /   s   
E
&r   )
r   numpyr   r0   r   Zmatplotlib.tri.triangulationr   Zmatplotlib.tri.triinterpolater   r   r
   r
   r
   r   <module>   s   #