spectrochempy.find_peaks
- find_peaks(dataset, height=None, window_length=3, threshold=None, distance=None, prominence=None, width=None, wlen=None, rel_height=0.5, plateau_size=None, use_coord=True)[source][source]
Find and analyze peaks in spectroscopic data with advanced filtering options.
This function extends scipy.signal.find_peaks by adding spectroscopy-specific features like coordinate system awareness and unit handling. It performs peak detection through local maxima analysis and supports various filtering criteria to identify significant peaks.
- Parameters:
dataset (NDDataset) – Input dataset containing spectral data. Must be 1D or 2D with len(X.y) == 1.
height (float or array-like, optional) – Minimum and/or maximum peak height criteria. Can be specified as: - Single value for minimum height - Tuple (min, max) for height range - Array matching x for position-dependent criteria
window_length (int, default: 3) – Window size for peak interpolation. Must be odd. Larger values provide smoother interpolation but may miss narrow peaks.
threshold (float or array-like, optional) – Minimum height difference between peak and neighboring points. Useful for filtering out noise-related peaks.
distance (float, optional) – Minimum separation between peaks. Peaks closer than this are filtered based on their prominence.
prominence (float or array-like, optional) – Required prominence (height above surrounding baseline) of peaks.
width (float or array-like, optional) – Required width of peaks. Interpreted as coordinate units if use_coord=True, otherwise as number of points.
wlen (int or float, optional) – Window length for prominence calculation. Affects computation speed for large datasets.
rel_height (float, default: 0.5) – Relative height for width calculation (0-1 range).
plateau_size (float or array-like, optional) – Required size of peak plateau (flat top).
use_coord (bool, default: True) – Whether to use coordinate system units instead of array indices.
- Returns:
peaks (NDDataset) – Dataset containing identified peaks with interpolated positions and heights.
properties (dict) – Peak properties including heights, widths, prominences, and more. All values use appropriate units when use_coord=True.
Notes
Peak positions are refined using quadratic interpolation when window_length > 1
The function handles units automatically when use_coord=True
For noisy data, consider preprocessing with smoothing functions
Examples
Basic peak finding with height threshold: >>> dataset = scp.read(“irdata/nh4y-activation.spg”) >>> X = dataset[0, 1800.0:1300.0] >>> peaks, props = X.find_peaks(height=1.5)
Find well-separated peaks with minimum width: >>> peaks, props = X.find_peaks(distance=50.0, width=10.0)
Complex filtering with multiple criteria: >>> peaks, props = X.find_peaks( … height=1.5, … distance=50.0, … prominence=0.5, … width=20.0 … )