
Downsample pupil time series with anti-aliasing filtering
Source:R/pipeline-downsample.R
downsample.Rd
This function downsamples pupillometry data by applying an anti-aliasing filter before decimation. Unlike binning, downsampling preserves the original temporal dynamics without averaging within bins.
Arguments
- eyeris
An object of class
eyeris
derived fromload_asc()
.- target_fs
The target sampling frequency in Hz after downsampling.
- plot_freqz
Boolean flag for displaying filter frequency response (default FALSE).
- rp
Passband ripple in dB (default 1).
- rs
Stopband attenuation in dB (default 35).
- call_info
A list of call information and parameters. If not provided, it will be generated from the function call.
Details
Downsampling reduces the sampling frequency by decimating data points.
The function automatically designs an anti-aliasing filter using the
lpfilt()
function with carefully chosen parameters:
ws
(stopband frequency) = Fs_new / 2 (Nyquist freq of new sampling rate)wp
(passband frequency) = ws - max(5, Fs_nq * 0.2)An error is raised if
wp < 4
to prevent loss of pupillary responses
The resulting time points will be: 0, 1/X, 2/X, 3/X, ..., etc. where X is the new sampling frequency.
Note
This function is part of the glassbox()
preprocessing pipeline and is not
intended for direct use in most cases. Provide parameters via
downsample = list(...)
.
Advanced users may call it directly if needed.
See also
glassbox()
for the recommended way to run this step as
part of the full eyeris glassbox preprocessing pipeline.
bin()
for binning functionality.
Examples
demo_data <- eyelink_asc_demo_dataset()
# downsample pupil data recorded at 1000 Hz to 100 Hz with the default params
demo_data |>
eyeris::glassbox(downsample = list(target_fs = 100)) |>
plot(seed = 0)
#> ✔ [ OK ] - Running eyeris::load_asc()
#> ℹ [ INFO ] - Processing block: block_1
#> ✔ [ OK ] - Running eyeris::deblink() for block_1
#> ✔ [ OK ] - Running eyeris::detransient() for block_1
#> ✔ [ OK ] - Running eyeris::interpolate() for block_1
#> ✔ [ OK ] - Running eyeris::lpfilt() for block_1
#> ✔ [ OK ] - Running eyeris::downsample() for block_1
#> ✔ [ INFO ] - Decimating sampling rate from 1000 Hz --> 100 Hz...
#> ! [ SKIP ] - Skipping eyeris::bin() for block_1
#> ! [ SKIP ] - Skipping eyeris::detrend() for block_1
#> ✔ [ OK ] - Running eyeris::zscore() for block_1
#>
#> Block processing summary:
#> block_1: OK (steps: 7, latest: pupil_raw_deblink_detransient_interpolate_lpfilt_downsample_z)
#>
#> ✔ [ OK ] - Running eyeris::summarize_confounds()
#> ! [ INFO ] - Plotting block 1 from possible blocks: 1
#> ℹ [ INFO ] - Plotting with sampling rate: 100 Hz