Benchmarking Functions#
benchmark_ecg()#
- benchmark_ecg_preprocessing(function, ecg, rpeaks=None, sampling_rate=1000)[source]#
Benchmark ECG preprocessing pipelines
- Parameters:
function (function) – Must be a Python function which first argument is the ECG signal and which has a
sampling_rate
argument.ecg (pd.DataFrame or str) – The path to a folder where you have an ECGs.csv file or directly its loaded DataFrame. Such file can be obtained by running THIS SCRIPT (TO COMPLETE).
rpeaks (pd.DataFrame or str) – The path to a folder where you have an Rpeaks.csv fils or directly its loaded DataFrame. Such file can be obtained by running THIS SCRIPT (TO COMPLETE).
sampling_rate (int) – The sampling frequency of
ecg_signal
(in Hz, i.e., samples/second). Only used ifecgs
andrpeaks
are single vectors.
- Returns:
pd.DataFrame – A DataFrame containing the results of the benchmarking
Examples
In [1]: import neurokit2 as nk # Define a preprocessing routine In [2]: def function(ecg, sampling_rate): ...: signal, info = nk.ecg_peaks(ecg, method="engzeemod2012", sampling_rate=sampling_rate) ...: return info["ECG_R_Peaks"] ...: # Synthetic example In [3]: ecg = nk.ecg_simulate(duration=20, sampling_rate=200) In [4]: true_rpeaks = nk.ecg_peaks(ecg, sampling_rate=200)[1]["ECG_R_Peaks"] In [5]: nk.benchmark_ecg_preprocessing(function, ecg, true_rpeaks, sampling_rate=200) Out[5]: Sampling_Rate Duration Score Recording_Length Error 0 200 0.031235 0.019025 0.333333 None # Example using database (commented-out) # nk.benchmark_ecg_preprocessing(function, r"path/to/GUDB_database")