From 688b85f4400e95cdd80f1e6986bd3530add5b9bf Mon Sep 17 00:00:00 2001 From: Marc Weitz Date: Fri, 6 Sep 2024 09:17:02 +0200 Subject: [PATCH] adds enmo convinience function --- paat/features.py | 23 ++++++++++++++++++++++- 1 file changed, 22 insertions(+), 1 deletion(-) diff --git a/paat/features.py b/paat/features.py index f1a5268..1668cc5 100644 --- a/paat/features.py +++ b/paat/features.py @@ -37,7 +37,7 @@ def calculate_vector_magnitude(data, minus_one=False, round_negative_to_zero=Fal round_negative_to_zero : Boolean (optional) If set to True, round negative values to zero dtype : np.dtype (optional) - set the data type of the return array. Standard float 16, but can be set to better precision + set the data type of the return array. Standard float 32, but can be set to better precision Returns @@ -78,6 +78,27 @@ def calculate_vector_magnitude(data, minus_one=False, round_negative_to_zero=Fal return vector_magnitude.reshape(data.shape[0], 1) +def calculate_enmo(data, dtype=np.float32): + """ + Calculate the Euclidean norm minus one from raw acceleration data. + This function is a wrapper of `calculate_vector_magnitude`. + Parameters + ---------- + data : array_like + numpy array with acceleration data + dtype : np.dtype (optional) + set the data type of the return array. Standard float 32, but can be set to better precision + Returns + ------- + vector_magnitude : np.array (acceleration values, 1)(np.float) + numpy array with vector magnitude of the acceleration + """ + if isinstance(data, pd.DataFrame): + data = data[["Y", "X", "Z"]].values + + return calculate_vector_magnitude(data, minus_one=True, round_negative_to_zero=True) + + def calculate_frequency_features(data, win_len=60, win_step=60, sample_rate=100, nfft=512, nfilt=40): """ Calculate frequency features from raw acceleration signal.