--- title: "Usage" output: rmarkdown::html_vignette vignette: > %\VignetteIndexEntry{Usage} %\VignetteEngine{knitr::rmarkdown} %\VignetteEncoding{UTF-8} --- ```{r, include = FALSE} knitr::opts_chunk$set( collapse = TRUE, comment = "#>" ) ``` ```{r setup} library(eyelinkReader) ``` The main function is `read_edf()` that imports an EDF file (or throws an error, if EDF API is not installed). By default it will import all events and attempt to extract standard events: saccades, blinks, fixations, logged variables, etc. ```r library(eyelinkReader) gaze <- read_edf('eyelink-recording.edf') ``` Events and individual event types are stored as tables inside the `eyelinkRecording` object with `trial` column identifying individual trials. Trial 0 correspond to events (e.g, `DISPLAY_COORDS` message, etc.) sent to the eye tracker before the first trial. ```r View(gaze$saccades) ``` ## Working with samples To import samples, add `import_samples = TRUE` and, optionally, specify which sample attributes need to be imported, e.g., `sample_attributes = c('time', 'gx', 'gy')`. All attributes are imported if `sample_attributes` is not specified. See package and EDF API documentation for the full list of attribute names. ```r # import samples with all attributes gaze <- read_edf('eyelink-recording.edf', import_samples = TRUE) # import samples with selected attributes gaze <- read_edf('eyelink-recording.edf', import_samples = TRUE, sample_attributes = c('time', 'gx', 'gy')) ``` You can convert makes samples _cyclopean_. In case of a binocular recording, a single column would represent an average between to eyes. E.g., $gx = (gxL + gxR) / 2$. In case of a monocular recording, a single column will contain information for a recorded eye. This is particularly useful, if you have multiple monocular recordings but some for the right eye and some for the left. ```r cyclopean_samples <- compute_cyclopean_samples(gaze$samples) ``` ## Utility functions The package includes various utility functions that need to be called separately. For example, to parse non-standard events: recorded areas of interest (`extract_AOIs`) and trigger events that help to time events (`extract_triggers`). ```r gaze <- extract_AOIs(gaze) gaze <- extract_triggers(gaze) ``` or, tidyverse-style ```r library(tidyverse) gaze <- read_edf('eyelink-recording.edf') %>% extract_AOIs() %>% extract_triggers() ``` Function `adjust_message_time()` alters time stamps of messages that are prefixed by a numeric offset that makes synchronization easier for e E-Prime / Presentation. I.e., a message `"-50 TARGET_ONSET"` that was sent at `105600` becomes a message `"TARGET_ONSET"` and its time stamp is `105550`. ```r gaze <- adjust_message_time(gaze) ```