This is an EEGLAB plugin.
I dreamed of a day when I did not have to interact with prompts while using EEGLAB. As I created newer and newer functions, and modified EEGLAB original scripts, I made this dream come true! This plugin is a love letter to EEGLAB, and what EEGLAB UI could be.
The original idea was to run EEGLAB functions quickly, without having to interact with prompts. It turnout to be much more. It contains various EEGLAB functions with prompt removed, but also and importantly, it contains an extremely modified version of EEG scroll plot + and TBT plugins. I recreated an UI were one can perform most EEGLAB functions at an EEG data without leaving the data scroll, and without having to interact with prompts!
The Data Scroll Pro is primarily useful for people with small datasets with low channels and low epochs, that need desperate cleaning that could not be done automatically. This allows you to clean each file meticulosuly, removing any and all artifacts. It can also help you learn about your dataset, and teach students how to clean and dataset and what a clean and dirty dataset look like.
Here's an example:
In this picture you can see the Data Scroll Pro in action. Two epochs (green) contained two channels that needed to be interpolated, but just for that epoch. One epoch (red) needed to be rejected as it contained a blink. I highlighted the functionalities added to the right panel in various colors, and will explain them below in this text.
Here’s a short list of functionalities added compared to Scrollplot and Scrollplot+
- Toggle between channel and component data (keyboard: W)
- Toggle between rejection and interpolation (keyboard: S)
- Scroll in data right or left (keyboard right: D, left A)
- Go to the beginning and ending of the data (Kb: Q start E: end)
- Normalize data (Kb: R)
- Left click selects an epoch for rejection (red) or interpolation (green)
- Right click selects a channel for interpolation (no channel rejection in this mode)
- For full interpolation: right click channel outside of any selected epoch.
- For partial interpolation: right click inside green selected epochs.
- Kb: Z on a channel select mouse-hovered channel for rejection, regardless or whether there are epochs selected or not.
- IMPORTANT: One can perform partial of COMPONENTS. This is extremely useful for components with unique spikes and data with small ranks (low number of components). It allows one to keep the max data rank while removing artifacts identified by the components.
- It's quite simple: I reject the components, but just for that selected epoch. This way, the rank is mostly untouched and the data is cleaner. Sometimes you can even GAIN rank, depending on how many components you have below the true data rank.
- Middle click:
- In Channel mode: display the headmodel at the clicked time on the right panel.
- In Component mode: open the component in a new figure (pop_prop_extended_ql).
- Kb: V, B, N, M, H, G: display various headmodel based on V: epoch Variance, B: epoch Std, N:Mean, M: MeanLog10, H: Variance difference from the rest of the data, G: Variance of the whole data.
- These options will help you see if this epoch is trouble or not, and what channels are creating the trouble.
- Headmodel and Data Matrix will trade with each other without any hiccups.
- Right panel:
- All data information displayed on top: Channel - Reference, Frames - Frame-Rate, Epochs - Events, Start and end of epoch, ICA (Number of Components) - Max Rank
- Added Arrows to advance to start and end of file
- Added Quick way to change the number of channels to display
- Select Library of Functions to perform
- TBT
- A library of functions that select, trial by trial, based on Abnormal values (and all other EEGLAB trial rejection options) and based on given attributes, to reject or interpolate channels and epochs.
- You can change the percentage of trials that require a Channel to be fully interpolated
- You can change the number of channels on an epoch that selects that epoch for rejection (instead of interpolating the channels)
- Detect flat line, a function from Cleanline, selects channels that are flat.
- Detect channel pops is a function that I made. It allows you to run a moving window and detect changes in data variation, based on mean, std, etc. It’s very simple, very weird, but may be useful to detect channel spikes. Here are the variables: 0. Size of window in bins/pnts 0. Number of standard deviations from that epoch (is it weird IN this epoch?) 0. Max Rej. window: A maximum size of change window. Helps reduce rejection of slow channels or Alpha/Theta waves. If the “spike” change is larger than 100 bins (default) it will consider it a normal change, not a spike. 0. Select specific channel or components . [] = all chans/comps 0. Options: select between mean, median, std. dev, and a few more options. 0. In conclusion, it identifies channels that have high mean (or median) velocity/acceleration of change that surpass a number of standard deviations based on that window, based on that epoch. I.e. spike detection.
- QuickLab
- ICA
- Number of components, [] for max rank
- Icatype
- Display components with viewprops+: 0 or 1
- BSS EMG (from AAR library) 0. Window size and window shift
- Re-reference (beta) 0. Select a channel to reference to, or select AVG LE or Original (beta)
- Re-epoch (beta) 0. Time 1 and time 2
- DipFit(par) 0. Number of components, number of dipoles (1 or 2)
- Any script 0. This is marvelous: run ANY SCRIPT on the current data. Have a function that you want to run? Copy, paste, and run. As long as it outputs EEG, it will work.
- ICA
- IClabel
- Runs all IClabel functions for component rejection. The best one is all but brain at 80% or more. This can be used for a quick and dirty cleaning of a data.
- QuickLab plots:
- For more nuanced selection of plots of FFTs, IClabel, or Component ERP
- TBT
- A matrix displaying currently selected channels and epochs for interpolation and rejection:
- Red vertical lines: epoch rejection
- Green vertical lines: epoch selected for interpolation
- Black lines: partial channels to be interpolated in each epoch
- Yellow lines: full channel interpolation
- You can click on a highlighted epoch and it will take you to that epoch!
- Right panel buttons:
- Apply Changes:
- Runs a program (eegrej_adv) that interpolates and reject and selected channels OR components (it does not run both at the same time). It saves a backup of the file with all selections, and creates a new file with a small description of changes made (number of channels, components, and epochs rejected).
- FFT(avg): allows you to click on a time and it will display the headmodel at that time.
- IClabel: runs IClabel and opens Viewprops+, which has been modified to allow you to select components for rejection by click the tick box OR by clicking on the headmodel
- Viewprops+ plots ALL components at once, in parallel (if par is available)
- You can save components to use on CORRMAP
- You can reject components and run a PCA reducing number of components by 1
- Plotted components have the option for time-frequency display
- Dipfitted components have the strongest BA area at the name
- Plot the component scroll
- Show ICA/Show Channel: toggle between ICA and Channel data
- Hide Epoch: If data is epoched, you can toggle the epoch display on or off.
- It doesn’t remove the epoching, just display the data AS IF it is not epoched.
- This allows one to interpolate spikes of data that are smaller than an epoch, if necessary.
- Useful to interpolate components that have very sharp and unique spikes that are dominating the component
- Interpolation Mode/Rejection Mode: toggle between interpolation and rejection.
- Load file from Folder: This is a list of all files in the folder. Changing this will RELOAD eegplot_adv and a new file will be displayed.
- Enter text to Add to Filename: Adding text here, then pressing Save File with Text, will automatically save the file, at the file’s folder, with the added text at the end. This way you can continue processing the data now in a new file, with a new add-on.
- Transfer to EEGLAB: reloads the current file in EEGLAB’s original UI.
- Apply Changes:
- Events have been changed: now you can toggle events on and off. This only removes the display of the events, not the events themselves.
- All EEGLAB tabs are added to the UI. This theoretically allows one to perform Any EEGLAB operation on the current data. This may not work all the time, not all functions work. Some functions with display may crash, but as far as I can tell, most common functions will work. These functions are encapsulated in a way that eegplot_adv collects the EEG output from the EEGLAB functions and plots in the UI. I have not tested all of them, so they may break. Keep me updated with any bugs and we’ll find a way to work around.
Quicklab contains a lot of other functions. Here are some:
- Edit QuickLab defaults: Not an exhaustive list, but I added here a way to change the majority of the defaults of QuickLab. It’s supposed to be suitable for anyone and anyone’s defaults, so that you can process your dataset as quickly as possible.
- Quick Plots: Viewprops + and Spectopo_ql, as described above.
Example of Viewprops+ Additions include selecting components for removal directly in the UI by clicking on the headmodel or in the box, as well saving the component for corrmap. All maps plotted in parallel if available, which is in general faster.
Example of Spectopo_ql Additions include display of any headmodel at any clicked frequency, as well as the frequency and power as selected on the right panel. Also, a convenient save figure button. Headmaps plotted in parallel as well.
- Other:
- FFT plots using LE or default reference. I only plot FFT using average reference as it is the most useful. LE needs to be set in default, it also may not work
- ERP plots+. This allows one to plot the ERP of every component, projected to a specific channel and selected from a specific event. If you need to see your components in ERP style, this is the way. Not very useful, but can give an interesting perspective on a dataset.
- Quick PCA: This just run a PCA using the default function (CUDAICA or BINICA or whatever you set on Quicklab Defaults). I have non-exhaustive list to quickly run a PCA from the menu without having to interact with ANY prompts.
- BSS menu: the defaults BSS from AAR library is incorrect and breaks the data. Here you can select to run BSS selected every 2 epochs, the full file, or full file in parallel. Basically, when BSS runs in anything BUT full file, Components become very inconsistent as they are partially rejected based on, say, every 2 epochs. Full file is the most consistent one, but it is slow, so I also added a parallel version – which runs super-fast.
- Quick Channel Edit:
- Re-reference data to AVG
- Reduce channels (ignore): my personal scripts for my dissertation where I removed channels from below the crown.
- Quick Filter: Let’s you quickly run a highpass or lowpass on the data, without any prompts.
- Quick Epoch Edits:
- Re-epoch data every X seconds. No prompts.
- Un-epoch data: a simple script that removed the epoching on the data. This can be useful in special circumstances.
- Quick Corrmap:
- My own version of CORRMAP. This is made to be run on individual files. The idea is simple: You can select topoplots from components using the viewprops+. Save them in a folder. Then, you can run the corrmap rejection here. My version of Corrmap is SUPER fast, but can’t be run on STUDY as far as I know.
- Maps are saved in folders based on number of channels, and only run the corrmaps in the correct folder for that number of channels you selected.
- Runs in parallel if available.
- Quick Parallel Processes: Here, DipFit 1 or 2 dipoles is re-written to be run in parallel. Again, runs super-fast, with no prompts.
There's also a dark-mode feature! Change the colors in the QuickLab Defaults for your convenience!