Source code for sensors.yei
''' Import data saved with yei-sensors, through subclassing "IMU_Base" '''
# Author: Thomas Haslwanter
from skinematics.imus import IMU_Base
import numpy as np
import pandas as pd
import re
import abc
# To ensure that the relative path works
import os
import sys
parent_dir = os.path.abspath(os.path.join(os.path.dirname(__file__), '..'))
if parent_dir not in sys.path:
sys.path.insert(0, parent_dir)
[docs]
class YEI(IMU_Base):
"""Concrete class based on abstract base class IMU_Base """
[docs]
def get_data(self, in_file, in_data=None):
'''Get the sampling rate, as well as the recorded data,
and assign them to the corresponding attributes of "self".
Parameters
----------
in_file : string
Filename of the data-file
in_data : not used here
Assigns
-------
- rate : rate
- acc : acceleration
- omega : angular_velocity
- mag : mag_field_direction
'''
data = pd.read_csv(in_file)
# Generate a simple list of column names
newColumns = []
pattern = re.compile(r'.*%(\w+)\((\w+)\)')
for name in data.columns:
newColumns.append(pattern.match(name).groups()[1])
data.columns = newColumns
# Calculate rate (ChipTime is in microsec)
start = data.ChipTimeUS[0] * 1e-6 # microseconds to seconds
stop = data.ChipTimeUS.values[-1] * 1e-6 # pandas can't count backwards
rate = len(data) / (stop-start)
# Extract the columns that you want, and pass them on
in_data = {'rate':rate,
'acc': data.filter(regex='Accel').values,
'omega': data.filter(regex='Gyro').values,
'mag': data.filter(regex='Compass').values}
self._set_data(in_data)
if __name__ == '__main__':
my_sensor = YEI(in_file=r'..\..\tests\data\data_yei.txt')
import matplotlib.pyplot as plt
plt.plot(my_sensor.acc)
plt.show()
print('Done')