
    Kh                       S r / SQrSSKrSSKrSSKJr  SSKJrJrJ	r	J
r
JrJrJrJrJrJrJrJrJrJrJrJrJrJrJrJrJr  SSKrSSKJrJ
r  SSK J!r!J"r"  SS	K#J$r$  SS
K%J&r&  S r'SMS jr(\)4S jr*S r+ " S S5      r, " S S\,5      r- " S S\,5      r. " S S\,5      r/ " S S\,5      r0\0" S5      r1\0" S5      r2\0" S5      r3\." S5      =r4r5\." S5      r6\." S5      r7\." S5      r8\." S 5      r9\-" S!5      r:\-" S"5      r;S# r<S$ r=\Rz                  R                   \=l         S% r>\>R                   bR  \R|                  R                   S\R|                  R                   R                  S&5       R                  5       S'-   \>l         SN\R                  S(.S) jjrBSOS* jrCSNS+ jrDSMS, jrESMS- jrFS. rGS/ rHSMS0 jrI\R                  4S1 jrJ\R                  4S2 jrKSPS3 jrLSQS4 jrMSRS5 jrNSRS6 jrOSQS7 jrPSQS8 jrQS9 rRSRS: jrSSSS< jrTSTS= jrUSS;\R                  S;\R                  4S> jrV " S? S@\&5      rW " SA SB\W5      rX\X" 5       rYSUSC jrZSD r[SMSE jr\SF r]SMSG jr^SH r_SI r`SJ raSMSK jrb\R                  " \R                  R                   \bR                   5      \bl         SVSL jrd\R                  " \R                  R                   \dR                   5      \dl         g)Wz
Masked arrays add-ons.

A collection of utilities for `numpy.ma`.

:author: Pierre Gerard-Marchant
:contact: pierregm_at_uga_dot_edu
:version: $Id: extras.py 3473 2007-10-29 15:18:13Z jarrod.millman $

).apply_along_axisapply_over_axes
atleast_1d
atleast_2d
atleast_3daverageclump_maskedclump_unmaskedcolumn_stackcompress_colscompress_ndcompress_rowcolscompress_rowscount_maskedcorrcoefcovdiagflatdotdstackediff1dflatnotmasked_contiguousflatnotmasked_edgeshsplithstackisinin1dintersect1d	mask_colsmask_rowcols	mask_rows
masked_allmasked_all_likemedianmr_ndenumeratenotmasked_contiguousnotmasked_edgespolyfit	row_stack	setdiff1dsetxor1dstackuniqueunion1dvandervstack    N   )core)MaskedArrayMAErroraddarrayasarrayconcatenatefilledcountgetmaskgetmaskarraymake_mask_descrmaskedmasked_arraymask_ornomaskonessortzerosgetdataget_masked_subclassr   )ndarrayr6   )normalize_axis_indexnormalize_axis_tuple)_ureduce)AxisConcatenatorc                 8    [        U [        [        [        45      $ )z.
Is seq a sequence (ndarray, list or tuple)?

)
isinstancerG   tuplelist)seqs    A/var/www/html/env/lib/python3.13/site-packages/numpy/ma/extras.py
issequencerR   (   s    
 cGUD122    c                 :    [        U 5      nUR                  U5      $ )a   
Count the number of masked elements along the given axis.

Parameters
----------
arr : array_like
    An array with (possibly) masked elements.
axis : int, optional
    Axis along which to count. If None (default), a flattened
    version of the array is used.

Returns
-------
count : int, ndarray
    The total number of masked elements (axis=None) or the number
    of masked elements along each slice of the given axis.

See Also
--------
MaskedArray.count : Count non-masked elements.

Examples
--------
>>> import numpy as np
>>> a = np.arange(9).reshape((3,3))
>>> a = np.ma.array(a)
>>> a[1, 0] = np.ma.masked
>>> a[1, 2] = np.ma.masked
>>> a[2, 1] = np.ma.masked
>>> a
masked_array(
  data=[[0, 1, 2],
        [--, 4, --],
        [6, --, 8]],
  mask=[[False, False, False],
        [ True, False,  True],
        [False,  True, False]],
  fill_value=999999)
>>> np.ma.count_masked(a)
3

When the `axis` keyword is used an array is returned.

>>> np.ma.count_masked(a, axis=0)
array([1, 1, 1])
>>> np.ma.count_masked(a, axis=1)
array([0, 2, 1])

)r<   sum)arraxisms      rQ   r   r   0   s    d 	SA55;rS   c           	      ~    [        [        R                  " X5      [        R                  " U [	        U5      5      S9nU$ )a'  
Empty masked array with all elements masked.

Return an empty masked array of the given shape and dtype, where all the
data are masked.

Parameters
----------
shape : int or tuple of ints
    Shape of the required MaskedArray, e.g., ``(2, 3)`` or ``2``.
dtype : dtype, optional
    Data type of the output.

Returns
-------
a : MaskedArray
    A masked array with all data masked.

See Also
--------
masked_all_like : Empty masked array modelled on an existing array.

Notes
-----
Unlike other masked array creation functions (e.g. `numpy.ma.zeros`,
`numpy.ma.ones`, `numpy.ma.full`), `masked_all` does not initialize the
values of the array, and may therefore be marginally faster. However,
the values stored in the newly allocated array are arbitrary. For
reproducible behavior, be sure to set each element of the array before
reading.

Examples
--------
>>> import numpy as np
>>> np.ma.masked_all((3, 3))
masked_array(
  data=[[--, --, --],
        [--, --, --],
        [--, --, --]],
  mask=[[ True,  True,  True],
        [ True,  True,  True],
        [ True,  True,  True]],
  fill_value=1e+20,
  dtype=float64)

The `dtype` parameter defines the underlying data type.

>>> a = np.ma.masked_all((3, 3))
>>> a.dtype
dtype('float64')
>>> a = np.ma.masked_all((3, 3), dtype=np.int32)
>>> a.dtype
dtype('int32')

mask)r?   npemptyrB   r=   )shapedtypeas      rQ   r    r    f   s3    p 	RXXe+''%)?@	BAHrS   c                     [         R                  " U 5      R                  [        5      n[         R                  " UR
                  [        UR                  5      S9Ul        U$ )a  
Empty masked array with the properties of an existing array.

Return an empty masked array of the same shape and dtype as
the array `arr`, where all the data are masked.

Parameters
----------
arr : ndarray
    An array describing the shape and dtype of the required MaskedArray.

Returns
-------
a : MaskedArray
    A masked array with all data masked.

Raises
------
AttributeError
    If `arr` doesn't have a shape attribute (i.e. not an ndarray)

See Also
--------
masked_all : Empty masked array with all elements masked.

Notes
-----
Unlike other masked array creation functions (e.g. `numpy.ma.zeros_like`,
`numpy.ma.ones_like`, `numpy.ma.full_like`), `masked_all_like` does not
initialize the values of the array, and may therefore be marginally
faster. However, the values stored in the newly allocated array are
arbitrary. For reproducible behavior, be sure to set each element of the
array before reading.

Examples
--------
>>> import numpy as np
>>> arr = np.zeros((2, 3), dtype=np.float32)
>>> arr
array([[0., 0., 0.],
       [0., 0., 0.]], dtype=float32)
>>> np.ma.masked_all_like(arr)
masked_array(
  data=[[--, --, --],
        [--, --, --]],
  mask=[[ True,  True,  True],
        [ True,  True,  True]],
  fill_value=np.float64(1e+20),
  dtype=float32)

The dtype of the masked array matches the dtype of `arr`.

>>> arr.dtype
dtype('float32')
>>> np.ma.masked_all_like(arr).dtype
dtype('float32')

r_   )	r\   
empty_likeviewr3   rB   r^   r=   r_   _mask)rV   r`   s     rQ   r!   r!      sB    v 	c,Aggagg_QWW%=>AGHrS   c                   *    \ rS rSrSrS rS rS rSrg)_fromnxfunction   a&  
Defines a wrapper to adapt NumPy functions to masked arrays.


An instance of `_fromnxfunction` can be called with the same parameters
as the wrapped NumPy function. The docstring of `newfunc` is adapted from
the wrapped function as well, see `getdoc`.

This class should not be used directly. Instead, one of its extensions that
provides support for a specific type of input should be used.

Parameters
----------
funcname : str
    The name of the function to be adapted. The function should be
    in the NumPy namespace (i.e. ``np.funcname``).

c                 F    Xl         Xl        U R                  5       U l        g N)__name____qualname__getdoc__doc__)selffuncnames     rQ   __init___fromnxfunction.__init__   s     ${{}rS   c                     [        [        U R                  S5      n[        USS5      nU(       aJ  [        R                  " U5      n[        R
                  " US5      nU(       a  U R                  U-   S-   nX2-   $ g)a  
Retrieve the docstring and signature from the function.

The ``__doc__`` attribute of the function is used as the docstring for
the new masked array version of the function. A note on application
of the function to the mask is appended.

Parameters
----------
None

Nrn   z@The function is applied to both the _data and the _mask, if any.z

)getattrr\   rk   maget_object_signaturedoc_note)ro   npfuncdocsigs       rQ   rm   _fromnxfunction.getdoc   sm     T]]D1fi.))&1C++c $< =Cmmc)F29rS   c                     g rj    )ro   argsparamss      rQ   __call___fromnxfunction.__call__  s    rS   )rn   rk   rl   N)	rk   
__module__rl   __firstlineno__rn   rq   rm   r   __static_attributes__r}   rS   rQ   rg   rg      s    &%
0rS   rg   c                       \ rS rSrSrS rSrg)_fromnxfunction_singlei  z
A version of `_fromnxfunction` that is called with a single array
argument followed by auxiliary args that are passed verbatim for
both the data and mask calls.
c                 L   [        [        U R                  5      n[        U[        5      (       a8  U" UR                  5       /UQ70 UD6nU" [        U5      /UQ70 UD6n[        XVS9$ U" [        R                  " U5      /UQ70 UD6nU" [        U5      /UQ70 UD6n[        XVS9$ NrZ   )	rt   r\   rk   rM   rG   	__array__r<   r?   r7   )ro   xr~   r   func_d_ms          rQ   r   _fromnxfunction_single.__call__!  s    r4==)a!!akkm5d5f5Bl1o777B,,bjjm5d5f5Bl1o777B,,rS   r}   Nrk   r   rl   r   rn   r   r   r}   rS   rQ   r   r     s    
	-rS   r   c                       \ rS rSrSrS rSrg)_fromnxfunction_seqi-  z
A version of `_fromnxfunction` that is called with a single sequence
of arrays followed by auxiliary args that are passed verbatim for
both the data and mask calls.
c           
      .   [        [        U R                  5      nU" [        U Vs/ s H  n[        R                  " U5      PM     sn5      /UQ70 UD6nU" [        U Vs/ s H  n[        U5      PM     sn5      /UQ70 UD6n[        XgS9$ s  snf s  snf r   )rt   r\   rk   rN   r7   r<   r?   )ro   r   r~   r   r   r`   r   r   s           rQ   r   _fromnxfunction_seq.__call__3  s    r4==)%21A23EdEfE%!4!Qa!45GGGB(( 34s    B Br}   Nr   r}   rS   rQ   r   r   -  s    
)rS   r   c                       \ rS rSrSrS rSrg)_fromnxfunction_argsi:  a}  
A version of `_fromnxfunction` that is called with multiple array
arguments. The first non-array-like input marks the beginning of the
arguments that are passed verbatim for both the data and mask calls.
Array arguments are processed independently and the results are
returned in a list. If only one array is found, the return value is
just the processed array instead of a list.
c                    [        [        U R                  5      n/ n[        U5      n[	        U5      S:  aW  [        US   5      (       aD  UR                  UR                  S5      5        [	        U5      S:  a  [        US   5      (       a  MD  / nU HP  nU" [        R                  " U5      /UQ70 UD6nU" [        U5      /UQ70 UD6nUR                  [        XxS95        MR     [	        U5      S:X  a  US   $ U$ )Nr0   rZ   r1   )rt   r\   rk   rO   lenrR   appendpopr7   r<   r?   )	ro   r~   r   r   arraysresr   r   r   s	            rQ   r   _fromnxfunction_args.__call__C  s    r4==)Dz$i!m
47 3 3MM$((1+& $i!m
47 3 3Abjjm5d5f5Bl1o777BJJ|B01  v;!q6M
rS   r}   Nr   r}   rS   rQ   r   r   :  s    rS   r   c                       \ rS rSrSrS rSrg)_fromnxfunction_allargsiS  a  
A version of `_fromnxfunction` that is called with multiple array
arguments. Similar to `_fromnxfunction_args` except that all args
are converted to arrays even if they are not so already. This makes
it possible to process scalars as 1-D arrays. Only keyword arguments
are passed through verbatim for the data and mask calls. Arrays
arguments are processed independently and the results are returned
in a list. If only one arg is present, the return value is just the
processed array instead of a list.
c                    [        [        U R                  5      n/ nU HJ  nU" [        R                  " U5      40 UD6nU" [	        U5      40 UD6nUR                  [        XgS95        ML     [        U5      S:X  a  US   $ U$ )NrZ   r1   r0   )rt   r\   rk   r7   r<   r   r?   r   )ro   r~   r   r   r   r   r   r   s           rQ   r    _fromnxfunction_allargs.__call__^  sw    r4==)Abjjm.v.Bl1o00BJJ|B01  t9>q6M
rS   r}   Nr   r}   rS   rQ   r   r   S  s    		rS   r   r   r   r   r/   r   r
   r   r+   r   r   c                     SnU[        U 5      :w  aG  [        X   S5      (       a  X   XUS-   & [        X   S5      (       a  M  US-  nU[        U 5      :w  a  MG  U $ )zFlatten a sequence in place.r0   __iter__r1   )r   hasattr)rP   ks     rQ   flatten_inplacer   |  s^    	AC=cfj)) VC1q5N cfj))	Q C= JrS   c                 x	   [        USSS9nUR                  n[        X5      nS/US-
  -  n[        R                  " US5      n[        [        U5      5      nUR                  U5        [        SS5      Xq'   [        R                  " UR                  5      R                  U5      n	UR                  X5        U " U[        UR                  5       5         /UQ70 UD6n
[        R                  " U
5      nU(       d   [!        U
5        / nU(       Ga4  UR%                  [        R                  " U
5      R&                  5        [	        U	[(        5      nX[        U5      '   [        R*                  " U	5      nSnX:  a  US==   S-  ss'   SnUU   U	U   :  a:  USU-
  :  a1  UUS-
  ==   S-  ss'   SUU'   US-  nUU   U	U   :  a  USU-
  :  a  M1  UR                  X5        U " U[        UR                  5       5         /UQ70 UD6n
X[        U5      '   UR%                  [        U
5      R&                  5        US-  nX:  a  M  GO[        U
SSS9n
UR-                  5       n[        SS5      /U
R                  -  UU'   UR                  X5        [        R*                  " U	5      nU	n[        UR                  5      n	U
R                  X'   UR%                  [        U
5      R&                  5        [/        U	5      n	[	        U	[(        5      nX[        [/        UR                  5       5      5      '   SnX:  a  US==   S-  ss'   SnUU   UU   :  a:  USU-
  :  a1  UUS-
  ==   S-  ss'   SUU'   US-  nUU   UU   :  a  USU-
  :  a  M1  UR                  X5        UR                  X5        U " U[        UR                  5       5         /UQ70 UD6n
X[        [/        UR                  5       5      5      '   UR%                  [        U
5      R&                  5        US-  nX:  a  M  [        R&                  " [        R                  " U5      R1                  5       5      n[3        US	5      (       d  [        R                  " UUS
9nU$ [        UUS
9n[4        R6                  " U5      Ul        U$ ! ["         a    Sn GNf = f)z(
(This docstring should be overwritten)
FT)copysubokr0   r1   ONre   rb   )r6   ndimrH   r\   rD   rO   rangeremoveslicer7   r^   takeputrN   tolistisscalarr   	TypeErrorr   r_   objectprodr   r   maxr   ru   default_fill_value
fill_value)func1drW   rV   r~   kwargsndindiindlistoutshaper   asscalardtypesoutarrNtotr   nj	holdshape
max_dtypesresults                        rQ   r   r     s    %t
,C	B)D#a.C
SA59oGNN4D$AGzz#))$))'2HEE'
U188:&'
9$
9&
9C{{3H	H Fbjjo++,x( uSzwwx hGqLGAq6Xa[(qAF|AE
a
AQ q6Xa[(qAF| EE'U188:./A$A&AC!$5:MM'#,,,-FA h Ce40FFH$%&1$	gwwx 			?gcl(()"8,x(58u_QXXZ012hGqLGAq6Yq\)QVAE
a
AQ q6Yq\)QV EE'EE'U188:./A$A&AC9<5456MM'#,,,-FA h "**V,0023J3  F*5 M z211&9Mw  	H	s   :R) )R98R9c                 X   [        U5      nUR                  n[        U5      R                  S:X  a  U4nU Hp  nUS:  a  XE-   nX54nU " U6 nUR                  UR                  :X  a  UnM3  [        R                  " Xu5      nUR                  UR                  :X  a  UnMg  [        S5      e   U$ )z&
(This docstring will be overwritten)
r0   z7function is not returning an array of the correct shape)r7   r   r6   ru   expand_dims
ValueError)r   r`   axesvalNrW   r~   r   s           rQ   r   r     s     !*C	AT{1w!88D{Dk88sxxC..+Cxx388#  "8 9 9  JrS   Notesa  

    Examples
    --------
    >>> import numpy as np
    >>> a = np.ma.arange(24).reshape(2,3,4)
    >>> a[:,0,1] = np.ma.masked
    >>> a[:,1,:] = np.ma.masked
    >>> a
    masked_array(
      data=[[[0, --, 2, 3],
             [--, --, --, --],
             [8, 9, 10, 11]],
            [[12, --, 14, 15],
             [--, --, --, --],
             [20, 21, 22, 23]]],
      mask=[[[False,  True, False, False],
             [ True,  True,  True,  True],
             [False, False, False, False]],
            [[False,  True, False, False],
             [ True,  True,  True,  True],
             [False, False, False, False]]],
      fill_value=999999)
    >>> np.ma.apply_over_axes(np.ma.sum, a, [0,2])
    masked_array(
      data=[[[46],
             [--],
             [124]]],
      mask=[[[False],
             [ True],
             [False]]],
      fill_value=999999)

    Tuple axis arguments to ufuncs are equivalent:

    >>> np.ma.sum(a, axis=(0,2)).reshape((1,-1,1))
    masked_array(
      data=[[[46],
             [--],
             [124]]],
      mask=[[[False],
             [ True],
             [False]]],
      fill_value=999999)
    )keepdimsc                `  ^ ^ [        T 5      m [        T 5      nTb  [        TT R                  SS9mU[        R
                  L a  0 nOSU0nUc?  T R                  " T40 UD6nUR                  R                  T R                  T5      5      nGO[        U5      n	[        T R                  R                  [        R                  [        R                  45      (       a-  [        R                  " T R                  U	R                  S5      n
O+[        R                  " T R                  U	R                  5      n
T R                  U	R                  :w  a  Tc  [        S5      eU	R                  [!        U 4S jT 5       5      :w  a  [#        S5      eU	R%                  [        R&                  " T5      5      n	U	R)                  [!        U4S j[+        T R                  5       5       5      5      n	U[,        La/  U	T R.                  ) -  n	U	=R.                  T R.                  -  sl        U	R0                  " STU
S	.UD6n[        R2                  " T U	U
S
9R0                  " T40 UD6U-  nU(       aK  UR                  UR                  :w  a.  [        R4                  " XR                  5      R7                  5       nXx4$ U$ )a  
Return the weighted average of array over the given axis.

Parameters
----------
a : array_like
    Data to be averaged.
    Masked entries are not taken into account in the computation.
axis : None or int or tuple of ints, optional
    Axis or axes along which to average `a`.  The default,
    `axis=None`, will average over all of the elements of the input array.
    If axis is a tuple of ints, averaging is performed on all of the axes
    specified in the tuple instead of a single axis or all the axes as
    before.
weights : array_like, optional
    An array of weights associated with the values in `a`. Each value in
    `a` contributes to the average according to its associated weight.
    The array of weights must be the same shape as `a` if no axis is
    specified, otherwise the weights must have dimensions and shape
    consistent with `a` along the specified axis.
    If `weights=None`, then all data in `a` are assumed to have a
    weight equal to one.
    The calculation is::

        avg = sum(a * weights) / sum(weights)

    where the sum is over all included elements.
    The only constraint on the values of `weights` is that `sum(weights)`
    must not be 0.
returned : bool, optional
    Flag indicating whether a tuple ``(result, sum of weights)``
    should be returned as output (True), or just the result (False).
    Default is False.
keepdims : bool, optional
    If this is set to True, the axes which are reduced are left
    in the result as dimensions with size one. With this option,
    the result will broadcast correctly against the original `a`.
    *Note:* `keepdims` will not work with instances of `numpy.matrix`
    or other classes whose methods do not support `keepdims`.

    .. versionadded:: 1.23.0

Returns
-------
average, [sum_of_weights] : (tuple of) scalar or MaskedArray
    The average along the specified axis. When returned is `True`,
    return a tuple with the average as the first element and the sum
    of the weights as the second element. The return type is `np.float64`
    if `a` is of integer type and floats smaller than `float64`, or the
    input data-type, otherwise. If returned, `sum_of_weights` is always
    `float64`.

Raises
------
ZeroDivisionError
    When all weights along axis are zero. See `numpy.ma.average` for a
    version robust to this type of error.
TypeError
    When `weights` does not have the same shape as `a`, and `axis=None`.
ValueError
    When `weights` does not have dimensions and shape consistent with `a`
    along specified `axis`.

Examples
--------
>>> import numpy as np
>>> a = np.ma.array([1., 2., 3., 4.], mask=[False, False, True, True])
>>> np.ma.average(a, weights=[3, 1, 0, 0])
1.25

>>> x = np.ma.arange(6.).reshape(3, 2)
>>> x
masked_array(
  data=[[0., 1.],
        [2., 3.],
        [4., 5.]],
  mask=False,
  fill_value=1e+20)
>>> data = np.arange(8).reshape((2, 2, 2))
>>> data
array([[[0, 1],
        [2, 3]],
       [[4, 5],
        [6, 7]]])
>>> np.ma.average(data, axis=(0, 1), weights=[[1./4, 3./4], [1., 1./2]])
masked_array(data=[3.4, 4.4],
         mask=[False, False],
   fill_value=1e+20)
>>> np.ma.average(data, axis=0, weights=[[1./4, 3./4], [1., 1./2]])
Traceback (most recent call last):
    ...
ValueError: Shape of weights must be consistent
with shape of a along specified axis.

>>> avg, sumweights = np.ma.average(x, axis=0, weights=[1, 2, 3],
...                                 returned=True)
>>> avg
masked_array(data=[2.6666666666666665, 3.6666666666666665],
             mask=[False, False],
       fill_value=1e+20)

With ``keepdims=True``, the following result has shape (3, 1).

>>> np.ma.average(x, axis=1, keepdims=True)
masked_array(
  data=[[0.5],
        [2.5],
        [4.5]],
  mask=False,
  fill_value=1e+20)
rW   )argnamer   f8z;Axis must be specified when shapes of a and weights differ.c              3   B   >#    U  H  nTR                   U   v   M     g 7frj   )r^   ).0axr`   s     rQ   	<genexpr>average.<locals>.<genexpr>  s     !="!''"+s   zIShape of weights must be consistent with shape of a along specified axis.c              3   <   >#    U  H  u  pUT;   a  UOS v   M     g7f)r1   Nr}   )r   r   srW   s      rQ   r   r     s&      $E1C +-*Q!%;1Cs   )rW   r_   rb   r}   )r7   r;   rI   r   r\   _NoValuemeanr_   typer:   
issubclassintegerboolresult_typer^   r   rN   r   	transposeargsortreshape	enumeraterA   r[   rU   multiplybroadcast_tor   )r`   rW   weightsreturnedr   rX   keepdims_kwavgsclwgtresult_dtypes   ``         rQ   r   r   $  s/   b 	
A
A#D!&&&A2;;!8,ffT)[)iinnQWWT]+gaggllRZZ$9::>>!''399dCL>>!''399=L 77cii|  yyE!=!=== 78 8
 --

4 01C++e $E1:1771C$E E FC F?w-CHHHggC4|C{Ckk!S ,..1c226G:EGILM 99		!//#yy1668Cx
rS   c           	          [        U S5      (       dZ  [        R                  " [        U SS9UX#US9n[	        U[        R
                  5      (       a  SUR                  ::  a
  [        USS9$ U$ [        U [        XAUUS9$ )	a[  
Compute the median along the specified axis.

Returns the median of the array elements.

Parameters
----------
a : array_like
    Input array or object that can be converted to an array.
axis : int, optional
    Axis along which the medians are computed. The default (None) is
    to compute the median along a flattened version of the array.
out : ndarray, optional
    Alternative output array in which to place the result. It must
    have the same shape and buffer length as the expected output
    but the type will be cast if necessary.
overwrite_input : bool, optional
    If True, then allow use of memory of input array (a) for
    calculations. The input array will be modified by the call to
    median. This will save memory when you do not need to preserve
    the contents of the input array. Treat the input as undefined,
    but it will probably be fully or partially sorted. Default is
    False. Note that, if `overwrite_input` is True, and the input
    is not already an `ndarray`, an error will be raised.
keepdims : bool, optional
    If this is set to True, the axes which are reduced are left
    in the result as dimensions with size one. With this option,
    the result will broadcast correctly against the input array.

Returns
-------
median : ndarray
    A new array holding the result is returned unless out is
    specified, in which case a reference to out is returned.
    Return data-type is `float64` for integers and floats smaller than
    `float64`, or the input data-type, otherwise.

See Also
--------
mean

Notes
-----
Given a vector ``V`` with ``N`` non masked values, the median of ``V``
is the middle value of a sorted copy of ``V`` (``Vs``) - i.e.
``Vs[(N-1)/2]``, when ``N`` is odd, or ``{Vs[N/2 - 1] + Vs[N/2]}/2``
when ``N`` is even.

Examples
--------
>>> import numpy as np
>>> x = np.ma.array(np.arange(8), mask=[0]*4 + [1]*4)
>>> np.ma.median(x)
1.5

>>> x = np.ma.array(np.arange(10).reshape(2, 5), mask=[0]*6 + [1]*4)
>>> np.ma.median(x)
2.5
>>> np.ma.median(x, axis=-1, overwrite_input=True)
masked_array(data=[2.0, 5.0],
             mask=[False, False],
       fill_value=1e+20)

r[   Tr   )rW   outoverwrite_inputr   r1   Fr   )r   r   rW   r   r   )
r   r\   r"   rE   rM   rG   r   r?   rJ   _median)r`   rW   r   r   r   rX   s         rQ   r"   r"     sx    B 1fIIgat,4') a$$aff..HAGhs$35 5rS   c                 4  ^^ [         R                  " U R                  [         R                  5      (       a  [         R                  nOS nU(       a6  Tc   U R                  5       mTR                  US9  OU R                  TUS9  U mO[        U TUS9mTc  SmO[        TTR                  5      mTR                  T   S:X  aU  [        S 5      /TR                  -  n[        SS5      UT'   [        U5      n[         R                  R                  TU   TUS9$ TR                  S:X  Ga:  [        [        T5      S5      u  pgTXg-   S-
  US-    n[         R                  " TR                  [         R                  5      (       ai  TR                   S:  aY  UR#                  US9n	U(       d  [         R$                  " U	SS	US
9n	[         R&                  R(                  R+                  TU	T5      n	OUR                  US9n	[         R                  R-                  U	5      (       aD  [         R.                  " TR0                  5      (       d  [         R                  R3                  T5      $ U	$ [        TTSS9n
U
S-  nU
S-  S:H  n[         R4                  " X{US-
  5      n[         R6                  " X/TS9n[         R8                  " TUTS9nUU4S jnU" U5        [         R                  " TR                  [         R                  5      (       aw  [         R                  R#                  UTUS9n	[         R$                  " U	R:                  SSU	R:                  S
9  [         R&                  R(                  R+                  TU	T5      n	U	$ [         R                  R                  UTUS9n	U	$ )N)r   )rW   r   r0   )rW   r   r1      )r   g       @safe)castingr   TrW   r   rW   c                 "  > [         R                  R                  U 5      (       aj  [         R                  " TR                  TSS9) U R                  -  n[         R                  R                  T5      U R                  U'   SU R                  U'   g g )NTr   F)r\   ru   	is_maskedallr[   minimum_fill_valuedata)r   repasortedrW   s     rQ   replace_masked_median.<locals>.replace_maskedW  sh    
 55??1FF7<<dTBBaffLC%%227;AFF3KAFF3K rS   unsafe)r\   
issubdtyper_   inexactinfravelrC   rH   r   r^   r   rN   ru   r   divmodr:   sizerU   true_dividelib_utils_impl_median_nancheckr   r   r[   r   wherer8   take_along_axisr   )r`   rW   r   r   r   indexeridxoddmidr   countshllhlow_highr  r  s    `              @rQ   r   r     s    
}}QWWbjj))VV

<ggiGLLJL/FFF4Gqt
;|#D',,7}}Ta ;-',,.a.uuzz''*3z??||q%.!,ci!mC!G,==

33q8HC ANN1b&cB""33GQEAS!A
 55??1bffW\\&:&:55++G4475F!A 1*/C
1A	D	)B !!'2D9H  8	}}W]]BJJ//EEIIhTsI3
qvvr8@FF//DA H EEJJxdJ4HrS   c           
      &   [        U 5      n [        U 5      nUc  [        [        U R                  5      5      nO[        XR                  5      nU[        L d  UR                  5       (       d  U R                  $ UR                  5       (       a  [        / 5      $ U R                  nU Hg  n[        [        [        U5      5      [        [        US-   U R                  5      5      -   5      nU[        S5      4U-  UR                  US9) 4-      nMi     U$ )a  Suppress slices from multiple dimensions which contain masked values.

Parameters
----------
x : array_like, MaskedArray
    The array to operate on. If not a MaskedArray instance (or if no array
    elements are masked), `x` is interpreted as a MaskedArray with `mask`
    set to `nomask`.
axis : tuple of ints or int, optional
    Which dimensions to suppress slices from can be configured with this
    parameter.
    - If axis is a tuple of ints, those are the axes to suppress slices from.
    - If axis is an int, then that is the only axis to suppress slices from.
    - If axis is None, all axis are selected.

Returns
-------
compress_array : ndarray
    The compressed array.

Examples
--------
>>> import numpy as np
>>> arr = [[1, 2], [3, 4]]
>>> mask = [[0, 1], [0, 0]]
>>> x = np.ma.array(arr, mask=mask)
>>> np.ma.compress_nd(x, axis=0)
array([[3, 4]])
>>> np.ma.compress_nd(x, axis=1)
array([[1],
       [3]])
>>> np.ma.compress_nd(x)
array([[3]])

Nr1   r   )r7   r;   rN   r   r   rI   rA   any_datar   nxarrayrO   r   )r   rW   rX   r   r   r   s         rQ   r   r   o  s    H 	
A
A|U166]##D&&1 	F{!%%''wwuuwwr{77DT%)_tE"q&!&&,A'BBCU4[N2%!%%T%*:):(<<=  KrS   c                 \    [        U 5      R                  S:w  a  [        S5      e[        XS9$ )a  
Suppress the rows and/or columns of a 2-D array that contain
masked values.

The suppression behavior is selected with the `axis` parameter.

- If axis is None, both rows and columns are suppressed.
- If axis is 0, only rows are suppressed.
- If axis is 1 or -1, only columns are suppressed.

Parameters
----------
x : array_like, MaskedArray
    The array to operate on.  If not a MaskedArray instance (or if no array
    elements are masked), `x` is interpreted as a MaskedArray with
    `mask` set to `nomask`. Must be a 2D array.
axis : int, optional
    Axis along which to perform the operation. Default is None.

Returns
-------
compressed_array : ndarray
    The compressed array.

Examples
--------
>>> import numpy as np
>>> x = np.ma.array(np.arange(9).reshape(3, 3), mask=[[1, 0, 0],
...                                                   [1, 0, 0],
...                                                   [0, 0, 0]])
>>> x
masked_array(
  data=[[--, 1, 2],
        [--, 4, 5],
        [6, 7, 8]],
  mask=[[ True, False, False],
        [ True, False, False],
        [False, False, False]],
  fill_value=999999)

>>> np.ma.compress_rowcols(x)
array([[7, 8]])
>>> np.ma.compress_rowcols(x, 0)
array([[6, 7, 8]])
>>> np.ma.compress_rowcols(x, 1)
array([[1, 2],
       [4, 5],
       [7, 8]])

r   z*compress_rowcols works for 2D arrays only.r   )r7   r   NotImplementedErrorr   )r   rW   s     rQ   r   r     s,    f qz!!"NOOq$$rS   c                 f    [        U 5      n U R                  S:w  a  [        S5      e[        U S5      $ )a  
Suppress whole rows of a 2-D array that contain masked values.

This is equivalent to ``np.ma.compress_rowcols(a, 0)``, see
`compress_rowcols` for details.

Parameters
----------
x : array_like, MaskedArray
    The array to operate on. If not a MaskedArray instance (or if no array
    elements are masked), `x` is interpreted as a MaskedArray with
    `mask` set to `nomask`. Must be a 2D array.

Returns
-------
compressed_array : ndarray
    The compressed array.

See Also
--------
compress_rowcols

Examples
--------
>>> import numpy as np
>>> a = np.ma.array(np.arange(9).reshape(3, 3), mask=[[1, 0, 0],
...                                                   [1, 0, 0],
...                                                   [0, 0, 0]])
>>> np.ma.compress_rows(a)
array([[6, 7, 8]])

r   z'compress_rows works for 2D arrays only.r0   r7   r   r  r   r`   s    rQ   r   r     s2    B 	
Avv{!"KLLAq!!rS   c                 f    [        U 5      n U R                  S:w  a  [        S5      e[        U S5      $ )a4  
Suppress whole columns of a 2-D array that contain masked values.

This is equivalent to ``np.ma.compress_rowcols(a, 1)``, see
`compress_rowcols` for details.

Parameters
----------
x : array_like, MaskedArray
    The array to operate on.  If not a MaskedArray instance (or if no array
    elements are masked), `x` is interpreted as a MaskedArray with
    `mask` set to `nomask`. Must be a 2D array.

Returns
-------
compressed_array : ndarray
    The compressed array.

See Also
--------
compress_rowcols

Examples
--------
>>> import numpy as np
>>> a = np.ma.array(np.arange(9).reshape(3, 3), mask=[[1, 0, 0],
...                                                   [1, 0, 0],
...                                                   [0, 0, 0]])
>>> np.ma.compress_cols(a)
array([[1, 2],
       [4, 5],
       [7, 8]])

r   z'compress_cols works for 2D arrays only.r1   r!  r"  s    rQ   r   r     s2    F 	
Avv{!"KLLAq!!rS   c                    [        U SS9n U R                  S:w  a  [        S5      e[        U 5      nU[        L d  UR                  5       (       d  U $ UR                  5       nU R                  R                  5       U l        U(       d   [        U [        R                  " US   5      '   US;   a$  [        U SS2[        R                  " US   5      4'   U $ )	a  
Mask rows and/or columns of a 2D array that contain masked values.

Mask whole rows and/or columns of a 2D array that contain
masked values.  The masking behavior is selected using the
`axis` parameter.

  - If `axis` is None, rows *and* columns are masked.
  - If `axis` is 0, only rows are masked.
  - If `axis` is 1 or -1, only columns are masked.

Parameters
----------
a : array_like, MaskedArray
    The array to mask.  If not a MaskedArray instance (or if no array
    elements are masked), the result is a MaskedArray with `mask` set
    to `nomask` (False). Must be a 2D array.
axis : int, optional
    Axis along which to perform the operation. If None, applies to a
    flattened version of the array.

Returns
-------
a : MaskedArray
    A modified version of the input array, masked depending on the value
    of the `axis` parameter.

Raises
------
NotImplementedError
    If input array `a` is not 2D.

See Also
--------
mask_rows : Mask rows of a 2D array that contain masked values.
mask_cols : Mask cols of a 2D array that contain masked values.
masked_where : Mask where a condition is met.

Notes
-----
The input array's mask is modified by this function.

Examples
--------
>>> import numpy as np
>>> a = np.zeros((3, 3), dtype=int)
>>> a[1, 1] = 1
>>> a
array([[0, 0, 0],
       [0, 1, 0],
       [0, 0, 0]])
>>> a = np.ma.masked_equal(a, 1)
>>> a
masked_array(
  data=[[0, 0, 0],
        [0, --, 0],
        [0, 0, 0]],
  mask=[[False, False, False],
        [False,  True, False],
        [False, False, False]],
  fill_value=1)
>>> np.ma.mask_rowcols(a)
masked_array(
  data=[[0, --, 0],
        [--, --, --],
        [0, --, 0]],
  mask=[[False,  True, False],
        [ True,  True,  True],
        [False,  True, False]],
  fill_value=1)

Fr   r   z&mask_rowcols works for 2D arrays only.r0   )Nr1   r   Nr1   )r6   r   r  r;   rA   r  nonzerore   r   r>   r\   r,   )r`   rW   rX   	maskedvals       rQ   r   r   1  s    R 	auAvv{!"JKK
AF{!%%''		IggllnAG%+"))IaL
!"}(.!RYYy|$
$%HrS   c                 t    U[         R                  La  [        R                  " S[        SS9  [        U S5      $ )aA  
Mask rows of a 2D array that contain masked values.

This function is a shortcut to ``mask_rowcols`` with `axis` equal to 0.

See Also
--------
mask_rowcols : Mask rows and/or columns of a 2D array.
masked_where : Mask where a condition is met.

Examples
--------
>>> import numpy as np
>>> a = np.zeros((3, 3), dtype=int)
>>> a[1, 1] = 1
>>> a
array([[0, 0, 0],
       [0, 1, 0],
       [0, 0, 0]])
>>> a = np.ma.masked_equal(a, 1)
>>> a
masked_array(
  data=[[0, 0, 0],
        [0, --, 0],
        [0, 0, 0]],
  mask=[[False, False, False],
        [False,  True, False],
        [False, False, False]],
  fill_value=1)

>>> np.ma.mask_rows(a)
masked_array(
  data=[[0, 0, 0],
        [--, --, --],
        [0, 0, 0]],
  mask=[[False, False, False],
        [ True,  True,  True],
        [False, False, False]],
  fill_value=1)

TThe axis argument has always been ignored, in future passing it will raise TypeErrorr   
stacklevelr0   r\   r   warningswarnDeprecationWarningr   r`   rW   s     rQ   r   r     s9    T 2;; 	#$61	F 1rS   c                 t    U[         R                  La  [        R                  " S[        SS9  [        U S5      $ )aC  
Mask columns of a 2D array that contain masked values.

This function is a shortcut to ``mask_rowcols`` with `axis` equal to 1.

See Also
--------
mask_rowcols : Mask rows and/or columns of a 2D array.
masked_where : Mask where a condition is met.

Examples
--------
>>> import numpy as np
>>> a = np.zeros((3, 3), dtype=int)
>>> a[1, 1] = 1
>>> a
array([[0, 0, 0],
       [0, 1, 0],
       [0, 0, 0]])
>>> a = np.ma.masked_equal(a, 1)
>>> a
masked_array(
  data=[[0, 0, 0],
        [0, --, 0],
        [0, 0, 0]],
  mask=[[False, False, False],
        [False,  True, False],
        [False, False, False]],
  fill_value=1)
>>> np.ma.mask_cols(a)
masked_array(
  data=[[0, --, 0],
        [0, --, 0],
        [0, --, 0]],
  mask=[[False,  True, False],
        [False,  True, False],
        [False,  True, False]],
  fill_value=1)

r(  r   r)  r1   r+  r/  s     rQ   r   r     s9    R 2;; 	#$61	F 1rS   c                     [         R                  " U 5      R                  n U SS U SS -
  nU/nUb  UR                  SU5        Ub  UR	                  U5        [        U5      S:w  a  [        U5      nU$ )a  
Compute the differences between consecutive elements of an array.

This function is the equivalent of `numpy.ediff1d` that takes masked
values into account, see `numpy.ediff1d` for details.

See Also
--------
numpy.ediff1d : Equivalent function for ndarrays.

Examples
--------
>>> import numpy as np
>>> arr = np.ma.array([1, 2, 4, 7, 0])
>>> np.ma.ediff1d(arr)
masked_array(data=[ 1,  2,  3, -7],
             mask=False,
       fill_value=999999)

r1   Nr   r0   )ru   
asanyarrayflatinsertr   r   r   )rV   to_endto_beginedr   s        rQ   r   r     sw    * --

!
!C	QR3s8	BTFa"f
6{a F^IrS   c                     [         R                  " U UUS9n[        U[        5      (       a3  [	        U5      nUS   R                  [        5      US'   [        U5      nU$ UR                  [        5      nU$ )a  
Finds the unique elements of an array.

Masked values are considered the same element (masked). The output array
is always a masked array. See `numpy.unique` for more details.

See Also
--------
numpy.unique : Equivalent function for ndarrays.

Examples
--------
>>> import numpy as np
>>> a = [1, 2, 1000, 2, 3]
>>> mask = [0, 0, 1, 0, 0]
>>> masked_a = np.ma.masked_array(a, mask)
>>> masked_a
masked_array(data=[1, 2, --, 2, 3],
            mask=[False, False,  True, False, False],
    fill_value=999999)
>>> np.ma.unique(masked_a)
masked_array(data=[1, 2, 3, --],
            mask=[False, False, False,  True],
    fill_value=999999)
>>> np.ma.unique(masked_a, return_index=True)
(masked_array(data=[1, 2, 3, --],
            mask=[False, False, False,  True],
    fill_value=999999), array([0, 1, 4, 2]))
>>> np.ma.unique(masked_a, return_inverse=True)
(masked_array(data=[1, 2, 3, --],
            mask=[False, False, False,  True],
    fill_value=999999), array([0, 1, 3, 1, 2]))
>>> np.ma.unique(masked_a, return_index=True, return_inverse=True)
(masked_array(data=[1, 2, 3, --],
            mask=[False, False, False,  True],
    fill_value=999999), array([0, 1, 4, 2]), array([0, 1, 3, 1, 2]))
)return_indexreturn_inverser0   )r\   r,   rM   rN   rO   rd   r3   )ar1r9  r:  outputs       rQ   r,   r,     sn    L YYs$0&46F &%  f1INN;/q	v M [)MrS   c                     U(       a  [         R                  " X45      nO*[         R                  " [        U 5      [        U5      45      nUR                  5         USS USS USS :H     $ )a  
Returns the unique elements common to both arrays.

Masked values are considered equal one to the other.
The output is always a masked array.

See `numpy.intersect1d` for more details.

See Also
--------
numpy.intersect1d : Equivalent function for ndarrays.

Examples
--------
>>> import numpy as np
>>> x = np.ma.array([1, 3, 3, 3], mask=[0, 0, 0, 1])
>>> y = np.ma.array([3, 1, 1, 1], mask=[0, 0, 0, 1])
>>> np.ma.intersect1d(x, y)
masked_array(data=[1, 3, --],
             mask=[False, False,  True],
       fill_value=999999)

Nr   r1   )ru   r8   r,   rC   )r;  ar2assume_uniqueauxs       rQ   r   r   K  s_    0 nncZ( nnfSk6#;78HHJs8CGs3Bx'((rS   c                 2   U(       d  [        U 5      n [        U5      n[        R                  " X4SS9nUR                  S:X  a  U$ UR	                  5         UR                  5       n[        R                  " S/USS USS :g  S/45      nUSS USS :H  nX6   $ )a  
Set exclusive-or of 1-D arrays with unique elements.

The output is always a masked array. See `numpy.setxor1d` for more details.

See Also
--------
numpy.setxor1d : Equivalent function for ndarrays.

Examples
--------
>>> import numpy as np
>>> ar1 = np.ma.array([1, 2, 3, 2, 4])
>>> ar2 = np.ma.array([2, 3, 5, 7, 5])
>>> np.ma.setxor1d(ar1, ar2)
masked_array(data=[1, 4, 5, 7],
             mask=False,
       fill_value=999999)

Nr   r0   Tr1   r   )r,   ru   r8   r
  rC   r9   )r;  r>  r?  r@  auxfflagflag2s          rQ   r*   r*   l  s    * SkSk
..#$
/C
xx1}
HHJ::<D>>D6DHSb	$9TFCDD!"Xcr"E:rS   c                 X   U(       d  [        U SS9u  p[        U5      n[        R                  " X45      nUR                  SS9nXV   nU(       a  USS USS :g  nOUSS USS :H  n[        R                  " X/45      n	UR                  SS9S[	        U 5       n
U(       a  X   $ X   W   $ )aA  
Test whether each element of an array is also present in a second
array.

The output is always a masked array. See `numpy.in1d` for more details.

We recommend using :func:`isin` instead of `in1d` for new code.

See Also
--------
isin       : Version of this function that preserves the shape of ar1.
numpy.in1d : Equivalent function for ndarrays.

Examples
--------
>>> import numpy as np
>>> ar1 = np.ma.array([0, 1, 2, 5, 0])
>>> ar2 = [0, 2]
>>> np.ma.in1d(ar1, ar2)
masked_array(data=[ True, False,  True, False,  True],
             mask=False,
       fill_value=True)

T)r:  	mergesort)kindr1   Nr   )r,   ru   r8   r   r   )r;  r>  r?  invertrev_idxarordersarbool_arrC  indxs              rQ   r   r     s    2 c$7Sk	
	#B JJKJ(E
)Cqr7c#2h&qr7c#2h&>>7H-.D==k=*9CH5Dzz'""rS   c                 v    [         R                  " U 5      n [        XUUS9R                  U R                  5      $ )a/  
Calculates `element in test_elements`, broadcasting over
`element` only.

The output is always a masked array of the same shape as `element`.
See `numpy.isin` for more details.

See Also
--------
in1d       : Flattened version of this function.
numpy.isin : Equivalent function for ndarrays.

Examples
--------
>>> import numpy as np
>>> element = np.ma.array([1, 2, 3, 4, 5, 6])
>>> test_elements = [0, 2]
>>> np.ma.isin(element, test_elements)
masked_array(data=[False,  True, False, False, False, False],
             mask=False,
       fill_value=True)

r?  rH  )ru   r7   r   r   r^   )elementtest_elementsr?  rH  s       rQ   r   r     s4    0 jj!Gm&ww}}56rS   c                 @    [        [        R                  " X4SS95      $ )a  
Union of two arrays.

The output is always a masked array. See `numpy.union1d` for more details.

See Also
--------
numpy.union1d : Equivalent function for ndarrays.

Examples
--------
>>> import numpy as np
>>> ar1 = np.ma.array([1, 2, 3, 4])
>>> ar2 = np.ma.array([3, 4, 5, 6])
>>> np.ma.union1d(ar1, ar2)
masked_array(data=[1, 2, 3, 4, 5, 6],
         mask=False,
   fill_value=999999)

Nr   )r,   ru   r8   )r;  r>  s     rQ   r-   r-     s    * "..#$788rS   c                     U(       a%  [         R                  " U 5      R                  5       n O[        U 5      n [        U5      nU [	        XSSS9   $ )a  
Set difference of 1D arrays with unique elements.

The output is always a masked array. See `numpy.setdiff1d` for more
details.

See Also
--------
numpy.setdiff1d : Equivalent function for ndarrays.

Examples
--------
>>> import numpy as np
>>> x = np.ma.array([1, 2, 3, 4], mask=[0, 1, 0, 1])
>>> np.ma.setdiff1d(x, [1, 2])
masked_array(data=[3, --],
             mask=[False,  True],
       fill_value=999999)

TrP  )ru   r7   r  r,   r   )r;  r>  r?  s      rQ   r)   r)     sC    * jjo##%SkSktCD>??rS   Tc                 8   [         R                  " U SS[        S9n [         R                  " U 5      nU(       d   UR	                  5       (       a  [        S5      eU R                  S   S:X  a  Sn[        [        U5      5      nSU-
  nU(       a  [        S5      S4nOS[        S5      4nUcn  U R                  S   S:  d  U R                  S   S:  a  [        R                  nO[        R                  n[        R                  " U5      R                  U5      nGOj[        US	S[        S
9n[         R                  " U5      n	U(       d   U	R	                  5       (       a  [        S5      eUR	                  5       (       d  U	R	                  5       (       aY  UR                  U R                  :X  a?  [        R                  " XI5      n
U
[         La   U
=n=U l        =Ul        n	S	U l        S	Ul        [         R&                  " X4U5      n U R                  S   S:  d  U R                  S   S:  a  [        R                  nO[        R                  n[        R                  " [        R&                  " XI4U5      5      R                  U5      nX R)                  US9U   -  n XU4$ )zS
Private function for the computation of covariance and correlation
coefficients.

r   T)ndminr   r_   zCannot process masked data.r0   r1   Ni   F)r   rV  r_   r   )ru   r6   floatr<   r  r   r^   intr   r   r\   float64float32logical_notastype
logical_orrA   re   _sharedmaskr8   r   )r   yrowvarallow_maskedxmaskrW   tup	xnm_dtypexnotmaskymaskcommon_masks              rQ   
_covhelperrh    s    	!$e4AOOAEEIIKK677wwqzQfFv:DT{D!U4[!y 771:1771:#7

I

I>>%(//	:!%q6"		:;;99;;%))++ww!''! mmE9f,8CCECAGCag$)AM$)AMNNA64( 771:1771:#7

I

I>>"..%"FGNN
 V	S	!!A  rS   c                    Ub  U[        U5      :w  a  [        S5      eUc  U(       a  SnOSn[        XX$5      u  pnU(       d  [        R                  " UR
                  U5      U-
  n[        R                  " US[        S9n[        R                  " SSS9   [        R                  " [        U R
                  S5      [        U R                  5       S5      5      U-  n	SSS5        [        R                  " W	US9R                  5       n
U
$ [        R                  " XfR
                  5      U-
  n[        R                  " US[        S9n[        R                  " SSS9   [        R                  " [        U S5      [        U R
                  R                  5       S5      5      U-  n	SSS5        [        R                  " W	US9R                  5       n
U
$ ! , (       d  f       N= f! , (       d  f       ND= f)	aQ	  
Estimate the covariance matrix.

Except for the handling of missing data this function does the same as
`numpy.cov`. For more details and examples, see `numpy.cov`.

By default, masked values are recognized as such. If `x` and `y` have the
same shape, a common mask is allocated: if ``x[i,j]`` is masked, then
``y[i,j]`` will also be masked.
Setting `allow_masked` to False will raise an exception if values are
missing in either of the input arrays.

Parameters
----------
x : array_like
    A 1-D or 2-D array containing multiple variables and observations.
    Each row of `x` represents a variable, and each column a single
    observation of all those variables. Also see `rowvar` below.
y : array_like, optional
    An additional set of variables and observations. `y` has the same
    shape as `x`.
rowvar : bool, optional
    If `rowvar` is True (default), then each row represents a
    variable, with observations in the columns. Otherwise, the relationship
    is transposed: each column represents a variable, while the rows
    contain observations.
bias : bool, optional
    Default normalization (False) is by ``(N-1)``, where ``N`` is the
    number of observations given (unbiased estimate). If `bias` is True,
    then normalization is by ``N``. This keyword can be overridden by
    the keyword ``ddof`` in numpy versions >= 1.5.
allow_masked : bool, optional
    If True, masked values are propagated pair-wise: if a value is masked
    in `x`, the corresponding value is masked in `y`.
    If False, raises a `ValueError` exception when some values are missing.
ddof : {None, int}, optional
    If not ``None`` normalization is by ``(N - ddof)``, where ``N`` is
    the number of observations; this overrides the value implied by
    ``bias``. The default value is ``None``.

Raises
------
ValueError
    Raised if some values are missing and `allow_masked` is False.

See Also
--------
numpy.cov

Examples
--------
>>> import numpy as np
>>> x = np.ma.array([[0, 1], [1, 1]], mask=[0, 1, 0, 1])
>>> y = np.ma.array([[1, 0], [0, 1]], mask=[0, 0, 1, 1])
>>> np.ma.cov(x, y)
masked_array(
data=[[--, --, --, --],
      [--, --, --, --],
      [--, --, --, --],
      [--, --, --, --]],
mask=[[ True,  True,  True,  True],
      [ True,  True,  True,  True],
      [ True,  True,  True,  True],
      [ True,  True,  True,  True]],
fill_value=1e+20,
dtype=float64)

Nzddof must be an integerr0   r1   rb   ignore)divideinvalidrZ   )rX  r   rh  r\   r   T
less_equalr   errstater9   conjru   r6   squeeze)r   r_  r`  biasra  ddofre  factr[   r   r   s              rQ   r   r   S  sl   L DCI-233|DD&qVBQ&vvhjj(+d2}}T1D1[[(;66&a.&1*=>ED <$T*224 M vvh

+d2}}T1D1[[(;66&A,qssxxz1(=>ED <$T*224M <; <;s   AGAG!
G!
G/c                    SnU[         R                  Ld  U[         R                  La  [        R                  " U[        SS9  [        XX$S9n [        R                  " [        R                  " U5      5      nU[        R                  R                  X5      -  nU$ ! [         a    [        R                  " 5       s $ f = f)a  
Return Pearson product-moment correlation coefficients.

Except for the handling of missing data this function does the same as
`numpy.corrcoef`. For more details and examples, see `numpy.corrcoef`.

Parameters
----------
x : array_like
    A 1-D or 2-D array containing multiple variables and observations.
    Each row of `x` represents a variable, and each column a single
    observation of all those variables. Also see `rowvar` below.
y : array_like, optional
    An additional set of variables and observations. `y` has the same
    shape as `x`.
rowvar : bool, optional
    If `rowvar` is True (default), then each row represents a
    variable, with observations in the columns. Otherwise, the relationship
    is transposed: each column represents a variable, while the rows
    contain observations.
bias : _NoValue, optional
    Has no effect, do not use.

    .. deprecated:: 1.10.0
allow_masked : bool, optional
    If True, masked values are propagated pair-wise: if a value is masked
    in `x`, the corresponding value is masked in `y`.
    If False, raises an exception.  Because `bias` is deprecated, this
    argument needs to be treated as keyword only to avoid a warning.
ddof : _NoValue, optional
    Has no effect, do not use.

    .. deprecated:: 1.10.0

See Also
--------
numpy.corrcoef : Equivalent function in top-level NumPy module.
cov : Estimate the covariance matrix.

Notes
-----
This function accepts but discards arguments `bias` and `ddof`.  This is
for backwards compatibility with previous versions of this function.  These
arguments had no effect on the return values of the function and can be
safely ignored in this and previous versions of numpy.

Examples
--------
>>> import numpy as np
>>> x = np.ma.array([[0, 1], [1, 1]], mask=[0, 1, 0, 1])
>>> np.ma.corrcoef(x)
masked_array(
  data=[[--, --],
        [--, --]],
  mask=[[ True,  True],
        [ True,  True]],
  fill_value=1e+20,
  dtype=float64)

z/bias and ddof have no effect and are deprecatedr   r)  )ra  )r\   r   r,  r-  r.  r   ru   sqrtdiagonalr   MaskedConstantr   outer)	r   r_  r`  rr  ra  rs  msgcorrstds	            rQ   r   r     s    | <C2;;$bkk"9c-!<qV7D#ggbkk$'( 	BKKc''DK  #  ""#s   *B B>=B>c                   V   ^  \ rS rSrSrSr\" \5      r\U 4S j5       r	U 4S jr
SrU =r$ )MAxisConcatenatori  z
Translate slice objects to concatenation along an axis.

For documentation on usage, see `mr_class`.

See Also
--------
mr_class

r}   c                 Z   > [         TU ]  UR                  SS9n[        X!R                  S9$ )NFr   rZ   )supermakematr   r6   r[   )clsrV   r   	__class__s      rQ   r  MAxisConcatenator.makemat  s*     wsxxe4T))rS   c                 b   > [        U[        5      (       a  [        S5      e[        TU ]  U5      $ )NzUnavailable for masked array.)rM   strr4   r  __getitem__)ro   keyr  s     rQ   r  MAxisConcatenator.__getitem__  s,    c39::w"3''rS   )rk   r   rl   r   rn   	__slots__staticmethodr8   classmethodr  r  r   __classcell__)r  s   @rQ   r~  r~    s5    	 I{+K* *( (rS   r~  c                   "    \ rS rSrSrSrS rSrg)mr_classi"  aJ  
Translate slice objects to concatenation along the first axis.

This is the masked array version of `r_`.

See Also
--------
r_

Examples
--------
>>> import numpy as np
>>> np.ma.mr_[np.ma.array([1,2,3]), 0, 0, np.ma.array([4,5,6])]
masked_array(data=[1, 2, 3, ..., 4, 5, 6],
             mask=False,
       fill_value=999999)

r}   c                 0    [         R                  U S5        g )Nr0   )r~  rq   )ro   s    rQ   rq   mr_class.__init__7  s    ""4+rS   N)rk   r   rl   r   rn   r  rq   r   r}   rS   rQ   r  r  "  s    $ I,rS   r  c              #      #    [        [        R                  " U 5      [        U 5      R                  5       H(  u  p#U(       d  Uv   M  U(       a  M  US   [
        4v   M*     g7f)a  
Multidimensional index iterator.

Return an iterator yielding pairs of array coordinates and values,
skipping elements that are masked. With `compressed=False`,
`ma.masked` is yielded as the value of masked elements. This
behavior differs from that of `numpy.ndenumerate`, which yields the
value of the underlying data array.

Notes
-----
.. versionadded:: 1.23.0

Parameters
----------
a : array_like
    An array with (possibly) masked elements.
compressed : bool, optional
    If True (default), masked elements are skipped.

See Also
--------
numpy.ndenumerate : Equivalent function ignoring any mask.

Examples
--------
>>> import numpy as np
>>> a = np.ma.arange(9).reshape((3, 3))
>>> a[1, 0] = np.ma.masked
>>> a[1, 2] = np.ma.masked
>>> a[2, 1] = np.ma.masked
>>> a
masked_array(
  data=[[0, 1, 2],
        [--, 4, --],
        [6, --, 8]],
  mask=[[False, False, False],
        [ True, False,  True],
        [False,  True, False]],
  fill_value=999999)
>>> for index, x in np.ma.ndenumerate(a):
...     print(index, x)
(0, 0) 0
(0, 1) 1
(0, 2) 2
(1, 1) 4
(2, 0) 6
(2, 2) 8

>>> for index, x in np.ma.ndenumerate(a, compressed=False):
...     print(index, x)
(0, 0) 0
(0, 1) 1
(0, 2) 2
(1, 0) --
(1, 1) 4
(1, 2) --
(2, 0) 6
(2, 1) --
(2, 2) 8
r0   N)zipr\   r$   r<   r3  r>   )r`   
compresseditr[   s       rQ   r$   r$   A  sJ     | q)<?+?+?@HQ%-	 As   AA#A#c                    [        U 5      nU[        L d  [        R                  " U5      (       d%  [        R                  " SU R
                  S-
  /5      $ [        R                  " U) 5      n[        U5      S:  a  USS/   $ g)aH  
Find the indices of the first and last unmasked values.

Expects a 1-D `MaskedArray`, returns None if all values are masked.

Parameters
----------
a : array_like
    Input 1-D `MaskedArray`

Returns
-------
edges : ndarray or None
    The indices of first and last non-masked value in the array.
    Returns None if all values are masked.

See Also
--------
flatnotmasked_contiguous, notmasked_contiguous, notmasked_edges
clump_masked, clump_unmasked

Notes
-----
Only accepts 1-D arrays.

Examples
--------
>>> import numpy as np
>>> a = np.ma.arange(10)
>>> np.ma.flatnotmasked_edges(a)
array([0, 9])

>>> mask = (a < 3) | (a > 8) | (a == 5)
>>> a[mask] = np.ma.masked
>>> np.array(a[~a.mask])
array([3, 4, 6, 7, 8])

>>> np.ma.flatnotmasked_edges(a)
array([3, 8])

>>> a[:] = np.ma.masked
>>> print(np.ma.flatnotmasked_edges(a))
None

r0   r1   r   N)r;   rA   r\   r  r6   r
  flatnonzeror   )r`   rX   unmaskeds      rQ   r   r     sj    \ 	
AF{"&&))xxAFFQJ((~~qb!H
8}qB  rS   c           	      J   [        U 5      n Ub  U R                  S:X  a  [        U 5      $ [        U 5      n[	        [
        R                  " U R                  5      [
        R                   " U/U R                  -  5      S9n[        [        U R                  5       Vs/ s H$  oCU   R                  U5      R                  5       PM&     sn5      [        [        U R                  5       Vs/ s H$  oCU   R                  U5      R                  5       PM&     sn5      /$ s  snf s  snf )a  
Find the indices of the first and last unmasked values along an axis.

If all values are masked, return None.  Otherwise, return a list
of two tuples, corresponding to the indices of the first and last
unmasked values respectively.

Parameters
----------
a : array_like
    The input array.
axis : int, optional
    Axis along which to perform the operation.
    If None (default), applies to a flattened version of the array.

Returns
-------
edges : ndarray or list
    An array of start and end indexes if there are any masked data in
    the array. If there are no masked data in the array, `edges` is a
    list of the first and last index.

See Also
--------
flatnotmasked_contiguous, flatnotmasked_edges, notmasked_contiguous
clump_masked, clump_unmasked

Examples
--------
>>> import numpy as np
>>> a = np.arange(9).reshape((3, 3))
>>> m = np.zeros_like(a)
>>> m[1:, 1:] = 1

>>> am = np.ma.array(a, mask=m)
>>> np.array(am[~am.mask])
array([0, 1, 2, 3, 6])

>>> np.ma.notmasked_edges(am)
array([0, 6])

r1   rZ   )r7   r   r   r<   r6   r\   indicesr^   rN   r   minr  r   )r`   rW   rX   r  r   s        rQ   r&   r&     s    V 	
A|qvv{"1%%QA


177#"**aS166\*B
CC%-H-Qq6::d#..0-HI%-H-Qq6::d#..0-HIM MHHs   +D(+D 
c                 6   [        U 5      nU[        L a  [        SU R                  5      /$ Sn/ n[        R
                  " UR                  5       5       HA  u  pE[        [        U5      5      nU(       d  UR                  [        X"U-   5      5        X&-  nMC     U$ )a  
Find contiguous unmasked data in a masked array.

Parameters
----------
a : array_like
    The input array.

Returns
-------
slice_list : list
    A sorted sequence of `slice` objects (start index, end index).

See Also
--------
flatnotmasked_edges, notmasked_contiguous, notmasked_edges
clump_masked, clump_unmasked

Notes
-----
Only accepts 2-D arrays at most.

Examples
--------
>>> import numpy as np
>>> a = np.ma.arange(10)
>>> np.ma.flatnotmasked_contiguous(a)
[slice(0, 10, None)]

>>> mask = (a < 3) | (a > 8) | (a == 5)
>>> a[mask] = np.ma.masked
>>> np.array(a[~a.mask])
array([3, 4, 6, 7, 8])

>>> np.ma.flatnotmasked_contiguous(a)
[slice(3, 5, None), slice(6, 9, None)]
>>> a[:] = np.ma.masked
>>> np.ma.flatnotmasked_contiguous(a)
[]

r0   )
r;   rA   r   r
  	itertoolsgroupbyr  r   rO   r   )r`   rX   r   r   r   gr   s          rQ   r   r     s    T 	
AF{a !!	AF##AGGI.QLMM%q5/*		 /
 MrS   c           	      H   [        U 5      n U R                  nUS:  a  [        S5      eUb  US:X  a  [        U 5      $ / nUS-   S-  nSS/n[	        SS5      XQ'   [        U R                  U   5       H-  nXeU'   UR                  [        U [        U5         5      5        M/     U$ )a  
Find contiguous unmasked data in a masked array along the given axis.

Parameters
----------
a : array_like
    The input array.
axis : int, optional
    Axis along which to perform the operation.
    If None (default), applies to a flattened version of the array, and this
    is the same as `flatnotmasked_contiguous`.

Returns
-------
endpoints : list
    A list of slices (start and end indexes) of unmasked indexes
    in the array.

    If the input is 2d and axis is specified, the result is a list of lists.

See Also
--------
flatnotmasked_edges, flatnotmasked_contiguous, notmasked_edges
clump_masked, clump_unmasked

Notes
-----
Only accepts 2-D arrays at most.

Examples
--------
>>> import numpy as np
>>> a = np.arange(12).reshape((3, 4))
>>> mask = np.zeros_like(a)
>>> mask[1:, :-1] = 1; mask[0, 1] = 1; mask[-1, 0] = 0
>>> ma = np.ma.array(a, mask=mask)
>>> ma
masked_array(
  data=[[0, --, 2, 3],
        [--, --, --, 7],
        [8, --, --, 11]],
  mask=[[False,  True, False, False],
        [ True,  True,  True, False],
        [False,  True,  True, False]],
  fill_value=999999)
>>> np.array(ma[~ma.mask])
array([ 0,  2,  3,  7, 8, 11])

>>> np.ma.notmasked_contiguous(ma)
[slice(0, 1, None), slice(2, 4, None), slice(7, 9, None), slice(11, 12, None)]

>>> np.ma.notmasked_contiguous(ma, axis=0)
[[slice(0, 1, None), slice(2, 3, None)], [], [slice(0, 1, None)], [slice(0, 3, None)]]

>>> np.ma.notmasked_contiguous(ma, axis=1)
[[slice(0, 1, None), slice(2, 4, None)], [slice(3, 4, None)], [slice(0, 1, None), slice(3, 4, None)]]

r   z&Currently limited to at most 2D array.Nr1   r0   )	r7   r   r  r   r   r   r^   r   rN   )r`   rW   r   r   otherr  r   s          rQ   r%   r%   )  s    v 	
A	
B	Av!"JKK|rQw'**FAXNEa&CdD!CI1775>"E
.qs}=> # MrS   c           
      b   U R                   S:  a  U R                  5       n U SS U SS -  R                  5       nUS   S-   nU S   (       ae  [        U5      S:X  a  [	        SU R
                  5      /$ [	        SUS   5      /nUR                  S [        USSS2   USSS2   5       5       5        OF[        U5      S:X  a  / $ [        USSS2   USSS2   5       VVs/ s H  u  p4[	        X45      PM     nnnU S   (       a(  UR                  [	        US   U R
                  5      5        U$ s  snnf )zj
Finds the clumps (groups of data with the same values) for a 1D bool array.

Returns a series of slices.
r1   Nr   r0   c              3   <   #    U  H  u  p[        X5      v   M     g 7frj   )r   )r   leftrights      rQ   r   _ezclump.<locals>.<genexpr>  s"      B%@kd $$%@s   r   )	r   r  r%  r   r   r
  extendr  r   )r[   r  rr  r  s        rQ   _ezclumpr  w  s-    yy1}zz|8d3Bi
(
(
*C
a&1*CAws8q=!TYY'((1c!f	 B%(Qr!Vc!$Q$i%@B 	C s8q=I36s5Bq5z3qt!t93MN3MKDU43MNBx	s2w		*+H	 Os   D+c                 |    [        U S[        5      nU[        L a  [        SU R                  5      /$ [	        U) 5      $ )a  
Return list of slices corresponding to the unmasked clumps of a 1-D array.
(A "clump" is defined as a contiguous region of the array).

Parameters
----------
a : ndarray
    A one-dimensional masked array.

Returns
-------
slices : list of slice
    The list of slices, one for each continuous region of unmasked
    elements in `a`.

See Also
--------
flatnotmasked_edges, flatnotmasked_contiguous, notmasked_edges
notmasked_contiguous, clump_masked

Examples
--------
>>> import numpy as np
>>> a = np.ma.masked_array(np.arange(10))
>>> a[[0, 1, 2, 6, 8, 9]] = np.ma.masked
>>> np.ma.clump_unmasked(a)
[slice(3, 6, None), slice(7, 8, None)]

re   r0   )rt   rA   r   r
  r  r`   r[   s     rQ   r	   r	     s9    < 1gv&Dv~a !!TE?rS   c                 Z    [         R                  " U 5      nU[        L a  / $ [        U5      $ )a  
Returns a list of slices corresponding to the masked clumps of a 1-D array.
(A "clump" is defined as a contiguous region of the array).

Parameters
----------
a : ndarray
    A one-dimensional masked array.

Returns
-------
slices : list of slice
    The list of slices, one for each continuous region of masked elements
    in `a`.

See Also
--------
flatnotmasked_edges, flatnotmasked_contiguous, notmasked_edges
notmasked_contiguous, clump_unmasked

Examples
--------
>>> import numpy as np
>>> a = np.ma.masked_array(np.arange(10))
>>> a[[0, 1, 2, 6, 8, 9]] = np.ma.masked
>>> np.ma.clump_masked(a)
[slice(0, 3, None), slice(6, 7, None), slice(8, 10, None)]

)ru   r;   rA   r  r  s     rQ   r   r     s'    < ::a=Dv~	D>rS   c                 b    [         R                  " X5      n[        U 5      nU[        La  SX#'   U$ )z<
Masked values in the input array result in rows of zeros.

r0   )r\   r.   r;   rA   )r   r   _vanderrX   s       rQ   r.   r.     s-    
 iioG
A
NrS   c           	         [        U 5      n [        U5      n[        U 5      nUR                  S:X  a  [        U[        U5      5      nOKUR                  S:X  a0  [        [	        U5      5      nU[
        La  [        XxSS2S4   5      nO[        S5      eUbf  [        U5      nUR                  S:w  a  [        S5      eUR                  S   UR                  S   :w  a  [        S5      e[        U[        U5      5      nU[
        La(  U) n	Ub  XY   n[        R                  " X	   X   X#XEU5      $ [        R                  " XX#XEU5      $ )z=
Any masked values in x is propagated in y, and vice-versa.

r1   r   Nr0   z Expected a 1D or 2D array for y!z expected a 1-d array for weightsz(expected w and y to have the same length)
r7   r;   r   r@   r   rA   r   r^   r\   r'   )
r   r_  degrcondfullwr   rX   mynot_ms
             rQ   r'   r'     s   
 	
A
A
Avv{Awqz"	
1Yq\"Vad8$A:;;}AJ66Q;>??771:#FGGAwqz"=Azz!(AHc$3GGzz!DS99rS   rj   )NNF)NNFF)NN)FF)F)NTT)NTFTN)T)NFNF)ern   __all__r  r,   r2   ru   r3   r4   r5   r6   r7   r8   r9   r:   r;   r<   r=   r>   r?   r@   rA   rB   rC   rD   rE   rF   r   numpyr\   rG   r  numpy.lib.array_utilsrH   rI   numpy.lib._function_base_implrJ   numpy.lib._index_tricks_implrK   rR   r   rW  r    r!   rg   r   r   r   r   r   r   r   r/   r(   r   r
   r   r+   r   r   r   r   r   findrstripr   r   r"   r   r   r   r   r   r   r   r   r   r,   r   r*   r   r   r-   r)   rh  r   r   r~  r  r#   r$   r   r&   r   r%   r  r	   r   r.   rw   r'   r}   rS   rQ   <module>r     s  	
          + L 2 933l " :z=F2 2j-_ -$
)/ 
)? 2o . %\2
$\2
$\2
(2 2	X	&">2	X	&G$		)!*-O` ..66  2 & 00881			#	#	(	(	133968,.Obe[[ePK5\Rj7t5%p$"N&"RVr kk 0f kk /l#L/d)B"J-#`6:90@D8!v\~ t"++D++J`(( (@,  ,0 jB J5p1Mh4nK\:!H!R	 RYY..? :D ++bjj00'//BrS   