= Tutorial 16: Average response = ''Authors: Francois Tadel, Elizabeth Bock, Sylvain Baillet'' All the epochs we have imported in the previous tutorial are represented by matrices that have the same size (same number of channels, same number of time points), therefore they can be averaged together by experimental condition. The result is called indifferently "'''evoked response'''", "'''average response'''", "'''event-related field'''" in MEG (ERF) or "'''event-related potential'''" in EEG (ERP). It shows the components of the brain signals that are strictly time-locked to the presentation of a stimulus. . {{attachment:average_slide.gif||width="390",height="185"}} <> == Averaging == We will now compute the average responses for both the "standard" and "deviant" conditions. Two constraints have to be taken into consideration at this stage. '''Averaging runs separately''': With MEG, it is not recommended to average sensor data across acquisition runs with different head positions (ie. different "channel files"). If the head of the subject moved between two blocks of recordings, the sensors do not record the same parts of the brain before and after, therefore the runs cannot be compared directly. With EEG, you can generally skip this recommendation. '''Number of trials''': When computing subject-level averages for experimental conditions with different number of trials, you have two options. You can either use the same number of trials for all the conditions and subjects (to make them "more comparable") or use all the available good trials (more samples lead to better estimations of the mean and variance). Here we will go with the second option, using all the trials. See this [[http://neuroimage.usc.edu/brainstorm/Tutorials/Averaging#Number_of_trials|advanced section]] for more details. * Drag and drop all the "'''standard'''" and "'''deviant'''" trials for '''both runs''' in Process1. * In the Process1 box, the number of imported trials (comment in the database explorer, eg. "40 files") does not match the number of files selected for processing (between brackets, eg. "[39]"). This difference is due to the '''bad trials''' that we have in these folders. The trials tagged with a red dot in the database explorer are ignored by all the processes. The total number of selected files is 457 instead of 479, it means that we have a total of 22 bad trials. * Select the process "'''Average > Average files'''".<
>Select the options: '''By trial group (folder)''', Arithmetic average, Keep all the event markers.<
><
> {{attachment:average_folder.gif||width="525",height="547"}} * You get two new files for each acquisition run. The number between parenthesis indicates how many good trials were used to compute each average. <
><
> {{attachment:average_files.gif||width="250",height="229"}} == Process options: Average == Description of all the options of the process: Average > Average files. * '''Everything''': Averages all the files selected in Process1 together, creates only one file in output. * '''By subject''': Groups the files by subject (ignoring the folders), creates one file per subject. * '''By folder (subject average)''': Groups by subject and by folder, ignoring the trial groups. <
>In the current configuration, it would produce two files, one for each acquisition run. * '''By folder (grand average)''': Groups by folder, across the subjects. All the files located in folders with the same name would be averaged together, no matter in what subject they are. * '''By trial group (folder average)''': Groups by set of trials with the same name, separately for each folder and each subject. Here it creates four groups (two folders x two trial groups). * '''By trial group (subject average)''': Groups by set of trials with the same name, for each subject. The separation in folders is ignored. Here it would produce two files (deviant and standard). * '''By trial group (grand average)''': Groups by set of trials with the same name, ignoring the classification by folder or subject. * '''Function''': Documented directly in the option panel. * '''Weighted average''': When averaging single trials, the number of files is saved in the field ''Leff'' of the average file. When re-averaging the averages across acquisition sessions or subjects, this field ''Leff'' can be used to weigh each file with the number of trials from which it was computed: <
>mean(x) = sum(''Leff''(i) * x(i)) / sum(''Leff''(i))<
>In most cases, this option should be selected when averaging within a subject and disabled when averaging across subjects. It has no impact in the current example (no averages, ''Leff''=1). * '''Keep all the event markers''': If this option is selected, all the event markers that were available in all the individual trials are reported to the average file. It can be useful to check the relative position of the artifacts or the subject responses, or quickly detect some unwanted configuration such as a subject who would constantly blink immediately after a visual stimulus. == Visual exploration == The average response contains interesting information about the brain operations that occur shortly after the presentation of the stimulus. We can explore two dimensions: the '''location''' of the various brain regions involved in the sensory processing and the precise '''timing''' of their activation. Because these two types of information are of equal interest, we typically explore the recordings with two figures at the same time, one that shows all the signals in time and one that shows their spatial distribution at one instant. * Open the MEG recordings for the '''deviant average''' in '''Run#01''': double-click on the file. * In the Record tab: Select the "butterfly" view more (first button in the toolbar). * In the Filter tab: Add a '''low-pass filter''' at '''40Hz'''. * In the Record tab: Delete the "cardiac" event type, we are not interested by their distribution.<
><
> {{attachment:deviant_ts.gif||width="661",height="176"}} * This figure shows a typical clean evoked response, with a high signal-to-noise ratio. This represents the brain response to a simple auditory stimulation, the large peak around '''90ms''' probably corresponds to the main response in the primary auditory cortex. * The green line represents the [[https://link.springer.com/article/10.1007/BF01128870|global field power]] ('''GFP'''), i.e. the standard deviation of all the sensors values at each time point. This measure is sometimes used to identify transient or stable states in ERP/ERF. You can hide it with the display options menu '''Extra > Show GFP'''. * This is the response to the deviant beeps (clearly higher in pitch), for which the subject is supposed to press a button to indicate that he/she detected the target. These responses are represented with the "button" events, distributed between 350ms and the end of the file (many responses happened after 500ms). Because of the variability in the response times, we can already anticipate that we won't be able to study correctly the motor response from this average. For studying the activity in the motor area, we need to epoch the recordings again around the "button" events. Add a spatial view: * Open a 2D topography for the same file (right-click on the figure > View topography, or Ctrl+T). * Review the average '''as a movie''' with the keyboard shortcuts (hold the left or right arrow key). * At '''90ms''', we can observe a typical topography for a bilateral auditory response. Both on the left sensors and the right sensors we observe field patterns which seem to indicate a dipolar-like activity in the temporal or central regions. <
><
> {{attachment:deviant_topo.gif||width="159",height="136"}} * Close everything with the button [X] in the top-right corner of the Brainstorm window. <
>Accept to save the modifications (you deleted the "cardiac" events). * Open the "standard" average in the same way and delete the "cardiac" markers. Repeat the same operations for '''Run#02''': * Open the MEG recordings for deviant and standard. * Delete the "cardiac" markers in both files. * Open a 2D topography and review the recordings. * Close everything. == Interpretation == Let's display the two conditions "'''standard'''" and "'''deviant'''" side-by-side, for '''Run#01'''. * Right-click on average > MEG > Display time series. * Right-click on average > MISC > Display time series (EEG electrodes Cz and Pz) * Right-click on average > MEG > 2D Sensor cap * In the Filter tab: add a '''low-pass filter''' at '''40Hz''' (it makes the figures easier to read). * In the Record tab: you can set a common amplitude scale for all the figures with the button '''[=]'''. * Here are the results for the standard (top) and deviant (bottom) beeps: <
><
> {{attachment:average_summary.gif||width="650"}} The legend in blue shows names often used in the EEG ERP literature: * '''P50''': 50ms, bilateral auditory response in both conditions. * '''N100''': 95ms, bilateral auditory response in both conditions. * '''MMN''': 230ms, mismatch negativity in the deviant condition only (detection of an abnormality). * '''P200''': 170ms, in both conditions but much stronger in the standard condition. * '''P300''': 300ms, deviant condition only (decision making in preparation of the button press). * Some seem to have a direct correspondence in MEG (N100) some don't (P300). Additional quality check with the event markers: * The standard average shows two unwanted events between 100ms and 200ms post-stimulus, one "blink" and one "button" response. The trials that contain them should be marked as bad and the average recomputed, because the subject is probably not doing the task correctly. * We will not do this here because the SNR is high enough anyway, but remember that this option "Keep all events" from the averaging process provides a good summary of the recordings and can help you identify some bad trials. <> == Averaging bad channels == The bad channels can be defined independently for each trial, therefore we can have different numbers of data points averaged for different electrodes. If we have a channel A considered good for N<A)>> trials, the corresponding channel in the average file is computed in this way: sum(N<A)>> trials) / N<A)>>. In the average file, a channel is considered good if it is good in at least one trial, and considered as bad if it is bad in all the trials. The entire file is then considered as if it were computed from the maximum number of good trials: N<max)>> = max(N<i)>>), i=1..N<trials)>>. This procedure allows the conservation of the maximum amount of data. However it may cause some unwanted effects across channels: the SNR might be higher for some channels than others. If you want to avoid this: mark the channels as bad in all the trials, or report all the bad channels to the average file. This can be done easily using the database explorer, see tutorial [[Tutorials/BadChannels|Bad channels]]. <> == Averaging across runs == As said previously, it is usually not recommended to average MEG recordings in sensor space across multiple acquisition runs because the subject might have moved between the sessions. Different head positions were recorded for each run, so we will reconstruct the sources separately for each each run to take into account these movements. However, in the case of event-related studies it makes sense to start our data exploration with an average across runs, just to evaluate the quality of the evoked responses. We have seen in tutorial #4 that the subject almost didn't move between the two runs, so the error would be minimal. . {{http://neuroimage.usc.edu/brainstorm/Tutorials/ChannelFile?action=AttachFile&do=get&target=channel_multiple.gif|channel_multiple.gif|height="218",width="438",class="attachment"}} Let's compute an approximate average across runs. We will run a formal average in source space later. * To run the same process again with different parameters: '''File > Reload last pipeline'''. Select: * '''By trial group (subject average)''': One average per experimental condition, across acquisition runs * '''Arithmetic average + Standard error''': Save the standard error across all the trials in the same file * '''Keep all the event markers''': Select this option, we are interested in the button press events. * The two averages are saved in the folder "'''Intra-subject'''". This is where all the results of processes involving multiple folders, within one subject, will be saved.<
><
> {{attachment:average_stderror.gif||width="268",height="119"}} <> == Standard error == If you computed the '''standard deviation''' or the '''standard error''' together with an average, it will be automatically represented in the time series figures. * Double-click on one of the AvgStderr files to display the MEG sensors.<
>The light-grey area around the sensors represent the maximum standard error around the maximum and minimum values across all the sensors. * Delete the useless events (cardiac and saccade). * Select two sensors and plot them separately (right-click > Channels > View selected, or "Enter").<
>The green and red areas represent, at each time point, the standard error around the signal.<
><
> {{attachment:stderror.gif||width="379",height="176"}} <> == Number of trials == You should always be careful when comparing averages computed from different numbers of trials. In most cases, you can safely include '''all the trials''' in your averages, even in the case of imbalanced designs. However, for very low numbers of trials or when comparing peak amplitudes, having the same number of trials becomes more critical. See the following references for more details: * Luck SJ (2010)<
>[[https://erpinfo.org/blog/2018/6/26/different-ntrials|Comparing conditions with different numbers of trials]] * Thomas DG, Grice JW, Najm-Briscoe RG, Miller JW (2004)<
>[[http://www.ncbi.nlm.nih.gov/pubmed/15525568|The influence of unequal numbers of trials on comparisons of average event-related potentials]] <> == Selecting equal numbers of trials == If you decided you want to use the same number of trials across all the experimental conditions and/or across all the subjects, you can use a process to select them easily from the database. * Drag and drop all the "'''standard'''" and "'''deviant'''" trials for '''both runs''' in Process1. * Select the process "'''Files > Select uniform number of trials'''".<
>Select the options: '''By trial group (folder)''' and '''Uniformly distributed'''.<
><
> {{attachment:select_process.gif||width="483",height="494"}} * If you click on [Run], it doesn't do anything but highlighting the first selected file in the database explorer. This process just performs a file selection, it needs to be followed by another process that uses the selected files for computing something. However, you can see what was done in the process report. The reports are displayed only when an error or a warning was reported, but you can open them manually to check for additional messages. Menu '''File > Report viewer'''.<
><
> {{attachment:select_report.gif||width="666",height="235"}} * The comment in the report shows the 4 groups of trials that were identified based on the option we selected (group "by trial group and folder"), with the number of good trials per group. <
>The process picked 39 trials in each group, uniformly distributed in the list of available trials. <
>Example of trial indices selected for Run01/standard: [1, 6, 11, 16, 21, 26, 31, 36, ..., 188, 193] * To average these selected trials together, you would just need to add the process "Average > Average files" after this selection process in the pipeline editor. <
><
> {{attachment:average_selected.gif||width="374",height="168"}} ==== Process options ==== Available options in the process: File > Select uniform number of trials. * '''By folder''': Groups by subject and by folder, ignoring the trial groups. <
>Here, it would identify two groups, one for each acquisition run: Run01, Run02. * '''By trial group (folder)''': Groups by set of trials with the same name, separately for each folder and each subject. Here it would identify four groups: Run01/deviant, Run01/standard, Run02/deviant, Run01/standard. * '''By trial group (subject)''': Groups by set of trials with the same name, for each subject. The separation in folders is ignored. Here it would identify two groups: deviant, standard. How many trials to select in each group: * '''Number of trials per group''': This number of trials must be available in all the groups. If set to 0, the group with the lowest number of good trials is identified and the same number of trials is selected from all the other groups. How to select trials in a group that contains more than the requested number (Nf files, selecting only Ns): * '''Random selection''': Select a random subset of Ns trials. Trial indices: randperm(Nf,Ns) * '''First in the list''': Select the first Ns trials. Trial indices: 1:Ns * '''Last in the list''': Select the last Ns trials. Trial indices: Nf-Ns+1:Nf * '''Uniformly distributed''': Select Ns equally spaced trials. Trial indices: round(linspace(1, Nf, Ns))) == On the hard drive == The average files have the same structure as the individual trials, described in the tutorial [[http://neuroimage.usc.edu/brainstorm/Tutorials/Epoching#On_the_hard_drive|Import epochs]]. . {{attachment:average_struct.gif||width="602",height="297"}} '''Differences with the imported epochs''' * '''F''': [Nchannels x Ntime] average recordings across all the trials, in Volts. * '''Std''': [Nchannels x Ntime] standard error or standard deviation across all the trials, in Volts. * '''Leff''': Effective number of averages = Number of good trials that were used to compute the file <)>> <> <>