Data stream classes (gaze, eye states, IMU)#
- class pyneon.stream.NeonStream(file: Path)#
Bases:
NeonTabular
Base for Neon continuous data (gaze, eye states, IMU). It’s indexed by
timestamp [ns]
.- Parameters:
file (pathlib.Path) – Path to the CSV file containing the stream data.
- file#
Path to the CSV file containing the stream data.
- Type:
- data#
DataFrame containing the stream data.
- Type:
- sampling_freq_nominal#
Nominal sampling frequency of the stream as specified by Pupil Labs (https://pupil-labs.com/products/neon/specs).
- Type:
int or None
- time_to_ts(time: Number | ndarray) ndarray #
Convert relative time(s) in seconds to closest timestamp(s) in nanoseconds.
- crop(tmin: Number | None = None, tmax: Number | None = None, by: Literal['timestamp', 'time', 'row'] = 'timestamp', inplace: bool = False) NeonStream | None #
Crop data to a specific time range based on timestamps, relative times since start, or row numbers.
- Parameters:
tmin (numbers.Number, optional) – Start timestamp/time/row to crop the data to. If
None
, the minimum timestamp/time/row in the data is used. Defaults toNone
.tmax (numbers.Number, optional) – End timestamp/time/row to crop the data to. If
None
, the maximum timestamp/time/row in the data is used. Defaults toNone
.by ("timestamp" or "time" or "row", optional) – Whether tmin and tmax are UTC timestamps in nanoseconds OR relative times in seconds OR row numbers of the stream data. Defaults to “timestamp”.
inplace (bool, optional) – Whether to replace the data in the object with the cropped data. Defaults to False.
- Returns:
Cropped stream if
inplace=False
, otherwiseNone
.- Return type:
NeonStream or None
- restrict(other: NeonStream, inplace: bool = False) NeonStream | None #
Temporally restrict the stream to the timestamps of another stream. Equivalent to
crop(other.first_ts, other.last_ts)
.- Parameters:
other (NeonStream) – The other stream whose timestamps are used to restrict the data.
inplace (bool, optional) – Whether to replace the data in the object with the restricted data.
- Returns:
Restricted stream if
inplace=False
, otherwiseNone
.- Return type:
NeonStream or None
- interpolate(new_ts: ndarray | None = None, float_kind: str = 'cubic', other_kind: str = 'nearest', inplace: bool = False) NeonStream | None #
Interpolate the stream to a new set of timestamps.
- Parameters:
new_ts (numpy.ndarray, optional) – An array of new timestamps (in nanoseconds) at which to evaluate the interpolant. If
None
(default), new timestamps are generated according to the nominal sampling frequency of the stream as specified by Pupil Labs: https://pupil-labs.com/products/neon/specs.float_kind (str, optional) – Kind of interpolation applied on columns of float type, by default
"cubic"
. For details seescipy.interpolate.interp1d
.other_kind (str, optional) – Kind of interpolation applied on columns of other types, by default
"nearest"
. For details seescipy.interpolate.interp1d
.inplace (bool, optional) – Whether to replace the data in the object with the interpolated data. Defaults to False.
- Returns:
Interpolated stream if
inplace=False
, otherwiseNone
.- Return type:
NeonStream or None
- window_average(new_ts: ndarray, window_size: int | None = None, inplace: bool = False) NeonStream | None #
Take the average over a time window to obtain smoothed data at new timestamps.
- Parameters:
new_ts (numpy.ndarray) – An array of new timestamps (in nanoseconds) at which to compute the windowed averages. The median interval between these new timestamps must be larger than the median interval between the original data timestamps, i.e.,
np.median(np.diff(new_ts)) > np.median(np.diff(data.index))
. In other words, only downsampling is supported.window_size (int, optional) – The size of the time window (in nanoseconds) over which to compute the average around each new timestamp. If
None
(default), the window size is set to the median interval between the new timestamps, i.e.,np.median(np.diff(new_ts))
. The window size must be larger than the median interval between the original data timestamps, i.e.,window_size > np.median(np.diff(data.index))
.inplace (bool, optional) – Whether to replace the data in the object with the window averaged data. Defaults to False.
- Returns:
Stream with window average applied on data if
inplace=False
, otherwiseNone
.- Return type:
NeonStream or None
- class pyneon.stream.NeonGaze(file: Path)#
Bases:
NeonStream
Gaze data that inherits attributes and methods from
NeonStream
.
- class pyneon.stream.NeonEyeStates(file: Path)#
Bases:
NeonStream
3D eye states data that inherits attributes and methods from
NeonStream
.
- class pyneon.stream.NeonIMU(file: Path)#
Bases:
NeonStream
IMU data that inherits attributes and methods from
NeonStream
.
- class pyneon.stream.CustomStream(data: DataFrame)#
Bases:
NeonStream
Custom stream data that inherits attributes and methods from
NeonStream
.file
andsampling_freq_nominal
attributes areNone
because of the custom nature of the data.