Source code for neurokit2.rsp.rsp_phase

# -*- coding: utf-8 -*-
import numpy as np
import pandas as pd

from ..signal import signal_phase
from .rsp_fixpeaks import _rsp_fixpeaks_retrieve


[docs] def rsp_phase(peaks, troughs=None, desired_length=None): """**Compute respiratory phase (inspiration and expiration)** Finds the respiratory phase, labelled as 1 for inspiration and 0 for expiration. Parameters ---------- peaks : list or array or DataFrame or Series or dict The samples at which the inhalation peaks occur. If a dict or a DataFrame is passed, it is assumed that these containers were obtained with :func:`.rsp_findpeaks`. troughs : list or array or DataFrame or Series or dict The samples at which the inhalation troughs occur. If a dict or a DataFrame is passed, it is assumed that these containers were obtained with :func:`.rsp_findpeaks`. desired_length : int By default, the returned respiration rate has the same number of elements as ``peaks``. If set to an integer, the returned rate will be interpolated between ``peaks`` over ``desired_length`` samples. Has no effect if a DataFrame is passed in as the ``peaks`` argument. Returns ------- pd.DataFrame A DataFrame of same length as :func:`.rsp_signal` containing the following columns: * ``"RSP_Phase"``: breathing phase, marked by "1" for inspiration and "0" for expiration. * ``"RSP_Phase_Completion"``: breathing phase completion, expressed in percentage (from 0 to 1), representing the stage of the current respiratory phase. See Also -------- rsp_clean, rsp_peaks, rsp_amplitude, rsp_process, rsp_plot Examples -------- .. ipython:: python import neurokit2 as nk rsp = nk.rsp_simulate(duration=30, respiratory_rate=15) cleaned = nk.rsp_clean(rsp, sampling_rate=1000) peak_signal, info = nk.rsp_peaks(cleaned) phase = nk.rsp_phase(peak_signal, desired_length=len(cleaned)) @savefig p_rsp_phase1.png scale=100% fig = nk.signal_plot([rsp, phase], standardize=True) @suppress plt.close() """ # Format input. peaks, troughs = _rsp_fixpeaks_retrieve(peaks, troughs) # Phase inspiration = np.full(desired_length, np.nan) inspiration[peaks] = 0.0 inspiration[troughs] = 1.0 last_element = np.where(~np.isnan(inspiration))[0][ -1 ] # Avoid filling beyond the last peak/trough inspiration[0:last_element] = pd.Series(inspiration).ffill().values[0:last_element] # Phase Completion completion = signal_phase(inspiration, method="percent") return pd.DataFrame({"RSP_Phase": inspiration, "RSP_Phase_Completion": completion})