ARGRELMAX
Download Flojoy Studio to try this app
The ARGRELMAX node is based on a numpy or scipy function. The description of that function is as follows:
Calculate the relative maxima of 'data'. Params: data : ndarray Array in which to find the relative maxima. axis : int Axis over which to select from 'data'. Default is 0. order : int How many points on each side to use for the comparison
to consider "comparator(n, n+x)" to be True. mode : str How the edges of the vector are treated.
Available options are 'wrap' (wrap around) or 'clip' (treat overflow
as the same as the last (or first) element).
Default 'clip'. See numpy.take. Returns: out : DataContainer type 'ordered pair', 'scalar', or 'matrix'
Python Code
from flojoy import OrderedPair, flojoy, Matrix, Scalar
import scipy.signal
@flojoy
def ARGRELMAX(
default: OrderedPair | Matrix,
axis: int = 0,
order: int = 1,
mode: str = "clip",
) -> OrderedPair | Matrix | Scalar:
"""The ARGRELMAX node is based on a numpy or scipy function.
The description of that function is as follows:
Calculate the relative maxima of 'data'.
Parameters
----------
data : ndarray
Array in which to find the relative maxima.
axis : int, optional
Axis over which to select from 'data'. Default is 0.
order : int, optional
How many points on each side to use for the comparison
to consider "comparator(n, n+x)" to be True.
mode : str, optional
How the edges of the vector are treated.
Available options are 'wrap' (wrap around) or 'clip' (treat overflow
as the same as the last (or first) element).
Default 'clip'. See numpy.take.
Returns
-------
DataContainer
type 'ordered pair', 'scalar', or 'matrix'
"""
result = OrderedPair(
x=default.x,
y=scipy.signal.argrelmax(
data=default.y,
axis=axis,
order=order,
mode=mode,
),
)
return result