+
    /i(                     h    ^ RI t^ RIHt ^RIHtHtHt RR.t. ROt	R t
R t ! R R	4      tRR
 ltR# )    N)array_namespace)_output_len_apply	mode_enumupfirdnr   c                   \        V 4      \        V 4      ) V,          ,           p\        P                  ! W P                  4      pWR\        V 4      % VP	                  RV4      P
                  RRRR13,          P                  4       pV# )a  Store coefficients in a transposed, flipped arrangement.

For example, suppose upRate is 3, and the
input number of coefficients is 10, represented as h[0], ..., h[9].

Then the internal buffer will look like this::

   h[9], h[6], h[3], h[0],   // flipped phase 0 coefs
   0,    h[7], h[4], h[1],   // flipped phase 1 coefs (zero-padded)
   0,    h[8], h[5], h[2],   // flipped phase 2 coefs (zero-padded)

N:NNN)lennpzerosdtypereshapeTravel)huph_padlenh_fulls   &&  S/var/www/html/photoedit/myenv/lib/python3.14/site-packages/scipy/signal/_upfirdn.py_pad_hr   /   sl     1v#a&2&HXXh(F7CFO^^B#%%a2g.446FM    c                 <    V P                  4       p \        V 4      pV# )N)lowerr   )modeenums   & r   _check_moder   C   s    ::<DT?DKr   c                   4   a  ] tR t^It o RtR tRR ltRtV tR# )_UpFIRDnzHelper for resampling.c                n   \         P                  ! V4      pVP                  ^8w  g   VP                  ^ 8X  d   \	        R4      h\         P
                  ! VP                  V\         P                  4      V n        \         P                  ! WP                  4      p\        V4      V n
        \        V4      V n        V P                  ^8  g   V P                  ^8  d   \	        R4      h\        WP                  4      V n        \         P                  ! V P                  4      V n        \        V4      V n        R# )   z"h must be 1-D with non-zero lengthzBoth up and down must be >= 1N)r   asarrayndimsize
ValueErrorresult_typer   float32_output_typeint_up_downr   _h_trans_flipascontiguousarrayr
   _h_len_orig)selfr   x_dtyper   downs   &&&&&r   __init___UpFIRDn.__init__L   s    JJqM66Q;!&&A+ABBNN177GRZZHJJq++,r7Y
88a<4::><==#Axx011$2D2DEq6r   c           
         \        V P                  VP                  V,          V P                  V P                  4      p\
        P                  ! VP                  \
        P                  R7      pWVV&   \
        P                  ! W`P                  RR7      pW!P                  ,          p\        V4      p\        \
        P                  ! WP                  4      V P                  VV P                  V P                  W#V4       V# )z@Apply the prepared filter to the specified axis of N-D signal x.)r   C)r   order)r   r-   shaper)   r*   r   r!   int64r   r'   r"   r   r   r+   )r.   xaxisr   cval
output_lenoutput_shapeouts   &&&&&   r   apply_filter_UpFIRDn.apply_filter[   s     !1!11774=!%4::7
 zz!'':'Thh|+<+<CHff}4 rzz!../!!3xxT	7 
r   )r*   r-   r+   r'   r)   N)r	   constantr   )	__name__
__module____qualname____firstlineno____doc__r1   r>   __static_attributes____classdictcell__)__classdict__s   @r   r   r   I   s      " r   r   c                    \        W4      p\        P                  ! V4      p\        WP                  W#4      pVP                  VP                  WWV4      4      # )aG  Upsample, FIR filter, and downsample.

Parameters
----------
h : array_like
    1-D FIR (finite-impulse response) filter coefficients.
x : array_like
    Input signal array.
up : int, optional
    Upsampling rate. Default is 1.
down : int, optional
    Downsampling rate. Default is 1.
axis : int, optional
    The axis of the input data array along which to apply the
    linear filter. The filter is applied to each subarray along
    this axis. Default is -1.
mode : str, optional
    The signal extension mode to use. The set
    ``{"constant", "symmetric", "reflect", "edge", "wrap"}`` correspond to
    modes provided by `numpy.pad`. ``"smooth"`` implements a smooth
    extension by extending based on the slope of the last 2 points at each
    end of the array. ``"antireflect"`` and ``"antisymmetric"`` are
    anti-symmetric versions of ``"reflect"`` and ``"symmetric"``. The mode
    `"line"` extends the signal based on a linear trend defined by the
    first and last points along the ``axis``.

    .. versionadded:: 1.4.0
cval : float, optional
    The constant value to use when ``mode == "constant"``.

    .. versionadded:: 1.4.0

Returns
-------
y : ndarray
    The output signal array. Dimensions will be the same as `x` except
    for along `axis`, which will change size according to the `h`,
    `up`,  and `down` parameters.

Notes
-----
The algorithm is an implementation of the block diagram shown on page 129
of the Vaidyanathan text [1]_ (Figure 4.3-8d).

The direct approach of upsampling by factor of P with zero insertion,
FIR filtering of length ``N``, and downsampling by factor of Q is
O(N*Q) per output sample. The polyphase implementation used here is
O(N/P).

.. versionadded:: 0.18

References
----------
.. [1] P. P. Vaidyanathan, Multirate Systems and Filter Banks,
       Prentice Hall, 1993.

Examples
--------
Simple operations:

>>> import numpy as np
>>> from scipy.signal import upfirdn
>>> upfirdn([1, 1, 1], [1, 1, 1])   # FIR filter
array([ 1.,  2.,  3.,  2.,  1.])
>>> upfirdn([1], [1, 2, 3], 3)  # upsampling with zeros insertion
array([ 1.,  0.,  0.,  2.,  0.,  0.,  3.])
>>> upfirdn([1, 1, 1], [1, 2, 3], 3)  # upsampling with sample-and-hold
array([ 1.,  1.,  1.,  2.,  2.,  2.,  3.,  3.,  3.])
>>> upfirdn([.5, 1, .5], [1, 1, 1], 2)  # linear interpolation
array([ 0.5,  1. ,  1. ,  1. ,  1. ,  1. ,  0.5])
>>> upfirdn([1], np.arange(10), 1, 3)  # decimation by 3
array([ 0.,  3.,  6.,  9.])
>>> upfirdn([.5, 1, .5], np.arange(10), 2, 3)  # linear interp, rate 2/3
array([ 0. ,  1. ,  2.5,  4. ,  5.5,  7. ,  8.5])

Apply a single filter to multiple signals:

>>> x = np.reshape(np.arange(8), (4, 2))
>>> x
array([[0, 1],
       [2, 3],
       [4, 5],
       [6, 7]])

Apply along the last dimension of ``x``:

>>> h = [1, 1]
>>> upfirdn(h, x, 2)
array([[ 0.,  0.,  1.,  1.],
       [ 2.,  2.,  3.,  3.],
       [ 4.,  4.,  5.,  5.],
       [ 6.,  6.,  7.,  7.]])

Apply along the 0th dimension of ``x``:

>>> upfirdn(h, x, 2, axis=0)
array([[ 0.,  1.],
       [ 0.,  1.],
       [ 2.,  3.],
       [ 2.,  3.],
       [ 4.,  5.],
       [ 4.,  5.],
       [ 6.,  7.],
       [ 6.,  7.]])
)r   r   r!   r   r   r>   )	r   r8   r   r0   r9   r   r:   xpufds	   &&&&&&&  r   r   r   l   sH    T 
	B


1A
1ggr
(C::c&&q;<<r   )	r@   wrapedgesmooth	symmetricreflectantisymmetricantireflectline)r    r    r	   r@   r   )numpyr   scipy._lib._array_apir   _upfirdn_applyr   r   r   __all___upfirdn_modesr   r   r   r    r   r   <module>rZ      s@   D  1 : :m
$(   Fo=r   