| Size: 12729 Comment:  | Size: 19293 Comment:  | 
| Deletions are marked like this. | Additions are marked like this. | 
| Line 1: | Line 1: | 
| = Tutorial 7: Scouts = This tutorial uses Sabine Meunier's somatotopy experiment, called ''TutorialCTF ''in your Brainstorm database. | '''[WARNING: This page is part of the old tutorials, please refer to the [[Tutorials|new documentation]]]'''<<BR>><<BR>><<BR>> | 
| Line 4: | Line 3: | 
| In Brainstorm jargon, a ''scout '' is a region of interest defined on the cortical surface, consisting of a subset of vertices of this surface. This document explains how to create one or several scouts, use them to retrieve the activity in pre-defined brain regions, and compare between conditions. | = Tutorial 9: Scouts = ''Authors: Francois Tadel, John C Mosher, Richard Leahy, Sylvain Baillet'' | 
| Line 6: | Line 6: | 
| <<TableOfContents(2)>> | In Brainstorm jargon, a ''scout '' is a region of interest (ROI) defined on the cortical surface: a subset of vertices of this surface. This document explains how to create one or several scouts, use them to retrieve the activity in specific brain regions, and compare between conditions. <<TableOfContents(2,2)>> | 
| Line 9: | Line 11: | 
| Almost all the features related to the scouts manipulation are accessible in the Scouts tab in main Brainstorm window. We are going to use this panel to create a scout that includes the cortical area that we observed in the previous tutorial: the one that responds to the stimulation of the right thumb. | Almost all the features related to the scouts manipulation are accessible in the ''Scout'' tab in the main Brainstorm window. We are going to use this panel to create a scout that includes the cortical area that we observed in the previous tutorial: the one that responds to the stimulation of the right thumb. The scouts are automatically saved in the surface file from which they are created, and they are loaded and automatically displayed each time the surface is loaded. An ''atlas'' designates in this context a list of scouts. It is possible to have one or more ''atlases'' saved for each file, that can be automatically generated from Brainstorm, from an external software like FreeSurfer (see [[Tutorials/LabelFreeSurfer|this page]]), or created manually scout by scout. All the cortex surfaces contain by default an empty atlas called "User scouts", for the user to create new regions of interest. | 
| Line 12: | Line 18: | 
| 1. Select the protocol ''TutorialCTF'', and display the times series for ''Subject01 / !StimRightThumb / ERP'' (double-click). | 1. Select the protocol ''TutorialCTF'', and display the times series for ''Subject01 / Right / ERF'' (double-click). | 
| Line 14: | Line 20: | 
| 1. Go to 46ms, and set the data threshold around 80%. 1. Switch to the ''Scouts'' tab, click on the first button (a big cross), and then click in the middle of the red stain in left hemisphere in the 3D figure (rotate and zoom before if necessary). A small dot with the label "1" appears where you clicked. Your first scout is created, and contains only one vertex for the moment. It is now referenced in ''Available scouts'' list.<<BR>><<BR>> {{attachment:panelScouts.gif}} - {{attachment:scouts1.gif}} 1. Rename the scout into "'''LeftSS'''", for left somatosensory cortex: double-click on it in the ''Available scouts'' list, or scouts menu ''Edit > Rename scout''. | 1. Go to 48ms, and set the data threshold around 90%. 1. Switch to the ''Scout'' tab, click on the first button in the toolbar (the big cross), and then click in the middle of the red area in left hemisphere in the 3D figure (rotate and zoom before if necessary). A small dot with the label "1" appears where you clicked. Your first scout is created in the ''User scouts'' atlas, and contains only one vertex for the moment. <<BR>><<BR>> {{attachment:firstScout.gif}} 1. Rename the scout into "'''LeftSS'''", for left somatosensory cortex: double-click on it in the ''Available scouts'' list, or scouts menu ''Edit > Rename''. | 
| Line 20: | Line 26: | 
| In this case, the source is so focal that we could even use only the first vertex we selected to represent this area. But most of the time, the aim of a scout is to get the average activity of a larger region; so for the example, let's grow this scout. | In this case, the source is so focal that we could even use only the first vertex we selected to represent this area. But most of the time, the aim of a scout is to get the average activity over a larger region; so for the example, let's grow this scout. The buttons in the ''Scout size'' panel offer basic operations to define the scout extension. | 
| Line 22: | Line 28: | 
| * The buttons in in the ''Scout size'' panel offer basic operations to define scout extension. * ''''>'''': Add the closest vertex (respect to the seed) to the current scout. * ''''<'''': Remove the farthest vertex (respect to the seed) from the current scout. | * ''''>'''': Add the closest vertex (with respect to the seed) to the current scout. * ''''<'''': Remove the furthest vertex (with respect to the seed) from the current scout. | 
| Line 28: | Line 33: | 
| * Last method to add points to a scout: select the ''Select point'' button (big cross, first in toolbar), and then '''select '''again the "LeftSS" scout. All the points you will click on the cortex will be added to the selected scout. | * '''Add vertex manually''': Select the ''Select point'' button, then '''select again''' the "LeftSS" scout. When you click on a vertex on the surface, it is added to the selected scout. * '''Remove vertex manually''': Same as previously, but holding the '''SHIFT''' key at the same time. | 
| Line 30: | Line 36: | 
| For demonstration purpose, you can add about 15 vertices to scout ''LeftSS'', '''not '''in ''Constrained ''mode, and display it again. | Now: add about 15-20 vertices with button '>>', '''not '''in ''Constrained ''mode, and display the scout values again. You can notice that the overall shape is the same as the scout with only one vertex, but the amplitudes are much lower. This is because the time series of all the sources in this scout have been averaged. And as we averaged the maximum values with lower values, the result is lower. | 
| Line 32: | Line 38: | 
| . {{attachment:scoutsLeftSS.gif||height="169",width="273"}} - {{attachment:scoutsTSLeftSS.gif||height="168",width="369"}} | {{attachment:scoutGrow.gif}} | 
| Line 34: | Line 40: | 
| You can notice that the overall shape is the same as the scout with only one vertex, but the amplitudes are much lower. This is because the time series of all the sources in this scout have been averaged. And as we averaged the maximum values with lower values, the result is lower.<<BR>><<BR>> | == Display options == In the toolbar on the right side of scouts tab, you can find a list display options. Leave your mouse over it for a few seconds to get a description of each of them. * {{attachment:buttonLoad.gif}} Load Atlas * {{attachment:buttonSave.gif}} Save selected scouts * {{attachment:buttonSel.gif}} Show all the scouts * {{attachment:buttonSel2.gif}} Show only the selected scouts * If both previous buttons are unselected: no scouts are displayed in the 3D figure. It can be interesting to hide all the scouts if you are working with atlases on hi-resolution surfaces and if it takes to long to open a surface. * {{attachment:buttonContour.gif}} Show / hide the contour line * {{attachment:buttonLabel.gif}} Show / hide the scouts labels * {{attachment:buttonOpaque.gif}} Scout patch: Opaque * {{attachment:buttonTransp.gif}} Scout patch: Transparent * {{attachment:buttonNone.gif}} Scout patch: None * {{attachment:buttonRegion.gif}} Display the color of the region instead of the scout color (only for anatomical atlases) * {{attachment:buttonMri.gif}} Center MRI on scout (opens the MRI viewer and set the position to the current scout) == Scout function == How are the scouts time series calculated? For the scout LeftSS we have 15 signals, coming from 15 different dipoles with different orientations, that are combined into one unique signal. In the list of available scouts, you can see the indication "[mean]" next to the name of the scout. It represents the name of the function that is used for combined all the time series into one. This function can be changed individually for each scout, with the menu ''Scout > Set function'' in the Scout tab. ==== List of the functions ==== Here is a description of the different options. In the case of unconstrained sources (3 signals for each vertex, one for each orientation), the function is applied separately for each orientation and produces 3 time series instead of one. For more details, see the code of bst_scout_value.m. * '''Mean''': Average all the signals * '''PCA''': Take the first mode of the PCA decomposition of all the signals. * '''Fast PCA''': Same as ''PCA'' function, but computes the first PCA decomposition based only on a subset of the most powerful signals. It gives very similar results, but its computation is much faster for scouts that group a large number of dipoles (>50). * '''Mean(norm)''': Average the absolute values of all the signals * '''Max''': For each time point, get the maximum across all the vertices [signed maximum in amplitude value: m = max(abs(signal)), scout = sign(signal(m)) * m] * '''Power''': Average the power of all the signals (signal^2) * '''All''': Do not apply any operation on the scouts signals, and display the time series of all the sources at the same time. ==== "Absolute" display option ==== As said in the previous tutorial, the minimum norm current amplitudes can positive or negative. Which means that the values of the scouts, depending on the function that is used, may be positive or negative too. Most of the time we are interested in visualizing the absolute values of the scouts time series, to compare the activation level in different conditions or subjects. For this purpose, at the bottom of the Scout tab, you can choose to display either ''Absolute ''or ''Relative ''values. The effect of this options depends if you are processing sources with constrained (1 signal per vertex) or unconstrained (3 signals per vertex) orientations: * '''Constrained''': Applies the scout function ''sfunction'' to all the N sources time series, and then apply or not an absolute value * '''Absolute''': abs(sfunction(sources)) * '''Relative''': sfunction(sources) * '''Unconstrained''': Applies the scout function ''sfunction ''to the N sources time series for each orientation (x,y,z) separately, and then returns either the norm of the 3 orientations, or each orientation separately * '''Absolute''': Returns __one__ time series: <<BR>>sqrt( sfunction(sources_x).<<HTML(^)>>2 + sfunction(sources_y).<<HTML(^)>>2 + sfunction(sources_z).<<HTML(^)>>2) * '''Relative''': Returns __three__ time series: <<BR>>sfunction(sources_x), sfunction(sources_y), sfunction(sources_z) Change the selection to ''Relative ''and display again the activation of scout LeftSS for condition Right. {{attachment:absButton.gif}} The effect of the function depends if you are processing sources with constrained (1 signal per vertex) or unconstrained (3 signals per vertex) orientations. Note that it is a display option, it is not saved in the scouts themselves. It is used ONLY when displaying the scouts time series with the "Display" button of the Scout tab. In all other cases, like the extraction of the scouts values from a script, this relative/absolute option is going to be ignored. ==== Testing the functions ==== Now, leave this ''Relative'' option selected for testing all the scouts functions one by one. {{attachment:compFunc.gif}} Select again the "''Absolute''" display again, and keep it for the rest of the tutorial. | 
| Line 37: | Line 98: | 
| We are going to create an other scout for the other condition: the stimulation of the left thumb. | We are going to create another scout for the other condition: the stimulation of the '''left thumb'''. | 
| Line 40: | Line 101: | 
| 1. Display the times series for ''Subject01 / !StimLeftThumb / ERP'' (double-click). | 1. Display the times series for ''Subject01 / '''Left '''/ ERF'' (double-click). | 
| Line 42: | Line 103: | 
| 1. Go to the main response peak (45.6 ms). 1. Adjust the threshold value to get only a very focal point (about 85%). 1. Create a new scout at this point. Name it ''RightSS'', for Right Somato-Sensory cortex. | 1. Go to the main response peak (46 ms). 1. Adjust the threshold value to get only a very focal point (about 60%). 1. Create a new scout at this point. Name it ''RightSS'', for Right SomatoSensory cortex. | 
| Line 46: | Line 107: | 
| 1. Select both scouts (Ctrl+click) and click on ''Display scouts time series'' button (second button in toolbar).<<BR>><<BR>> {{attachment:panelScouts_LR.gif}} - {{attachment:scouts_LR.gif}} <<BR>><<BR>> {{attachment:scoutsTS_LR.gif}} 1. You can also display the values of the two scouts on the same graph. Just check the ''Overlay > Scouts'' checkbox in the Scout tab.<<BR>><<BR>> {{attachment:panelOverlayScouts.gif}} - {{attachment:scoutsTS_LR_overlay.gif||height="131",width="288"}} 1. You can observe something that we expected: the activity in the '''right somatosensory cortex''' is much higher than in the left somatosensory cortex for a stimulation of the '''left thumb'''. The scout RightSS we created | 1. Select both scouts (Ctrl+click) and click on ''Display scouts time series'' button (second button in toolbar).<<BR>><<BR>> {{attachment:scouts2.gif}} <<BR>><<BR>> {{attachment:scoutsTS_LR.gif}} 1. You can display the values of the two scouts on the same graph. Check the ''Overlay > Scouts'' checkbox in the Scout tab, and hit the ''Display scouts time series'' button again.<<BR>><<BR>> {{attachment:scoutsTS_LR_overlay.gif}} 1. You can observe something that we expected: the activity in the '''right somatosensory cortex''' is much higher than in the left somatosensory cortex for a stimulation of the '''left thumb'''. | 
| Line 50: | Line 111: | 
| == Load/Save scouts == In case you close the Brainstorm window, delete or unload your scouts (and this will happen in the next few minutes), save the scouts before going further. * Select both scouts at the same time (Ctrl+click), and click the ''Save scouts'' button.<<BR>><<BR>> {{attachment:saveScouts.gif}} * All the scouts will be saved in the same .mat file, in the subject's anatomy folder (same directory as the MRI and surfaces). * To load them later, just click the ''Load scouts'' button, and select the file. == Display scouts time series from the database tree == | == Display scouts from the database explorer == | 
| Line 60: | Line 114: | 
| 1. Close all the figures (button in toolbar). 1. Select the first scout (LeftSS) 1. Right-click on the sources file for !StimRightThumb condition > Cortical activations > Scouts time series.<<BR>><<BR>> {{attachment:treeRight.gif}} - {{attachment:treeRight_TS.gif||height="152",width="269"}} 1. You can also display many sources files at the same time. Try doing the same selecting both results file at the time<<BR>><<BR>> {{attachment:treeLR.gif}} - {{attachment:treeLR_TS.gif||height="132",width="272"}} 1. You can superimpose the two traces by selecting the ''Overlay > Conditions'' checkbox in ''Scout ''panel.<<BR>><<BR>> {{attachment:panelOverlayCond.gif||height="98",width="176"}} 1. This menu "Scouts time series" is present at all the levels. Try right-clicking on Subject01.<<BR>><<BR>> {{attachment:treeSubj.gif}} - {{attachment:treeSubj_TS.gif||height="164",width="291"}} 1. If you select a node in the database tree and click on the ''Display scouts time series'' button in the ''Scout ''tab, it would have exactly the same effect. <<BR>>Try selecting '''both scouts''' in the list, select '''Subject01 '''in the tree, and then click on this button. You will observe the reponse for each scout in both conditions.<<BR>><<BR>> {{attachment:scoutsOverlayBoth.gif}} | 1. Close all the figures (button in toolbar) 1. Select the options "values: absolute" and "overlay: scouts" 1. Right-click on '''Right '''/ ERF / MN > Cortical activations > Scouts time series.<<BR>>By default it shows all the scouts that are available in the current atlas.<<BR>><<BR>> {{attachment:treeRight.gif}} <<BR>> {{attachment:treeRight_TS.gif}} 1. Note that if a surface is loaded, and at least one scout selected in the ''Scout'' tab, this popup menu would display only the selected scouts. 1. You can also display the scout values for many source files at the same time. Now keep the previous figure opened, so you have access to the scouts list in the ''Scout'' tab. Select only the ''LeftSS'' scout. In the database explorer, select at the same time the source files from condition Left and Right > right-click > Cortical activations > Scouts time series.<<BR>><<BR>> {{attachment:treeLR.gif}} <<BR>> {{attachment:treeLR_TS.gif}} 1. You can superimpose the two traces from the two experimental conditions by selecting the ''Overlay > Conditions'' checkbox in ''Scout ''panel. Select again the two files > Right click > Scouts time series. We see now the activation of the LeftSS scout for the stimulation of both thumbs.<<BR>><<BR>> {{attachment:panelOverlayCond.gif}} 1. This menu "Scouts time series" is present at all the levels in the tree. Try right-clicking on Subject01 > Scouts time series. 1. If you select a node in the database tree and click on the ''Display scouts time series'' button in the ''Scout ''tab, it would have exactly the same effect. <<BR>>Try selecting '''both scouts''' in the list, select '''Subject01 '''in the tree, overlay / conditions, and then click on this button. You will see the response for each scout in both conditions.<<BR>><<BR>> {{attachment:scoutsOverlayBoth.gif}} | 
| Line 69: | Line 125: | 
| Let's spend a few minutes to explore all the menus in the ''Scout ''tab. Please click on all of them, it's the best way to remember. If you delete or alter the scouts LeftSS and RightSS: just reload them from the file you've just created. | Let's spend a few minutes to explore all the menus in the ''Scout ''tab. Don't hesitate to click on all of them, it's the best way to remember what they do. | 
| Line 71: | Line 127: | 
| === Menu: New === | === Menu: Atlas === | 
| Line 74: | Line 130: | 
| * '''Define in 3D view''': Same as clicking on the first button of the toolbar (Select point / big cross). * '''Define in MRI slices''': Open an interface to draw a 3D ROI, slice by slice. * Define the 3D mask using the different drawing tools. * Adjust the MRI contrast with right-click+move on the MRI image. * Move throught the slices with the mouse wheel, the small image on the lift, or the slider. * Once you are done, click on ''Ok''. A new scout is created, including all the vertices that are located inside the 3D mask. * __Warning__: The 3D mask is reinterpolated on the surface, all the volume information is lost. It means that the mask you intedend to draw might be really different from what you get as a scout at the end...<<BR>><<BR>> {{attachment:menuEditMriMask.gif}} * '''Find maximal value''': Find the vertex with the maximal intensity at the current time, and create a scout centered on it. * You can delete all the scouts you have created by selecting them and pressing ''Delete ''key.<<BR>> | * '''New atlas''': Create a new empty atlas. | 
| Line 84: | Line 132: | 
| === Menu: Edit === | * '''Load atlas''': Load ROIs or a cortical parcellation coming from FreeSurfer or BrainSuite as a new atlas. * '''Rename atlas''': Change the name that appears in the atlas list to refer to the selected atlas * '''Delete atlas''': Delete the atlas and all the scouts in contains. The "User scouts" entry cannot be deleted. * '''Add scouts to atlas''': Load ROIs or a cortical parcellation and add them to the current atlas. * '''Copy atlas''': Duplicates an atlas and all the scouts * '''Copy selected scouts''': Copy the selected scouts, and paste them in a new empty atlas. * '''Subdivide atlas''': Splits all the scouts of the current atlas in smaller ROIs. Available options:<<BR>><<BR>> {{attachment:scoutSubdivide.gif}} * '''Subdivide selected scouts''': Same thing, but processes only the selected scouts. * '''Surface clustering''': Create a parcellation of the cortex surface and saves it as a new atlas. Can be useful for studying the connectivity between different regions of the brain. Only the "Homogeneous parcellation" options are currently reliable. === Menu: Scout === | 
| Line 87: | Line 153: | 
| * '''Rename''': Rename the selected scout. <<BR>>Shortcut: double-click. | * '''Add vertices''': The user can select some points on the cortex surface and add them to the scout.<<BR>>Equivalent: Click on ''Select point'' (first toolbar button), then select the scout in list, and select 3d points. * '''Edit in MRI''': Open an interface to edit the select scout as a 3D ROI, slice by slice. * Define the 3D mask using the drawing tools (read the tooltips of the buttons for help). * Adjust the MRI contrast with right-click+move on the MRI image. * Move through the slices with the mouse wheel, the small image on the left, or the slider. * __Warning__: Only the vertices contained in the 3D mask are kept, all the volume information is lost. It means that the mask you intendend to draw might be very different from what you get as a scout at the end...<<BR>><<BR>> {{attachment:menuEditMriMask.gif}} * '''Set function''': Set the scout function for the selected scouts. * '''Set region''': Set the cortical region for the selected scouts. This information is useful when representing functional connectivity graphs. * '''Rename''': Rename the selected scout. Shortcut: ''double-click''. | 
| Line 89: | Line 167: | 
| * '''Remove''': Delete selected scouts. | * '''Delete''': Delete selected scouts. Shortcut: ''Delete'' key | 
| Line 91: | Line 169: | 
| * '''Deselect all''': Deselect all the scouts in the list.<<BR>>Shortcut:Escape key. * '''Add vertices''': The user can select some points on the cortex surface and add them to the scout.<<BR>>Equivalent:Click on ''Select point'' (first toolbar button), then select the scout in list, and slect 3d points. * '''Edit in MRI''': Open the same interface as menu New > Define in MRI slices, in order to edit the scout. * '''Expand (correlation)''': Computes the correlation between the values at the scout's seed (first point) and all the other sources. The sources that have correlation coefficient superior to a given threshold are added to the scout. <<BR>>Correlation is computed with the Matlab ''corrcoef ''function. * '''Find maximal value''': Move the scout's seed to the source that has the maximum amplitude '''in the scout''', at current time. * '''Remove vertices''': Remove the scout's vertices permanently from the cortex surface. <<BR>>__Warning__: This is a menu that can be used only when defining the subject's anatomy. Never do that if you already have headmodels or sources based on this surface... * '''Simulation''': Forward model of selected scouts. Simulate the scalp data that would be recorded if only the selected cortex region was activated. Create a new "source" file in the database.<<BR>>If no scout is selected: simulate recordings produced by the activity of the whole cortex. | * '''Export to Matlab''': Export the structures of the selected scouts to  the Matlab environment, and makes them accessible from the command  window. This menu can be useful to get quickly the list of vertices in  the scout. * '''Import from Matlab''': Import scouts structures that you modified manually from your Matlab command window directly as new scouts. * '''Edit surface''': Create a new surface containing only the desired parts (remove or keep only the selected scouts). This is useful for instance for selecting one sub-cortical region from the Aseg FreeSurfer atlas (see the [[Tutorials/LabelFreeSurfer|FreeSurfer tutorial]]). | 
| Line 99: | Line 173: | 
| === Menu: View === | === Menu: Sources === | 
| Line 101: | Line 175: | 
| * '''Simulate recordings''': Multiply the selected scouts with the forward model. Simulate the scalp data that would be  recorded if only the selected cortex region was activated; all the other  sources are set to zero. Create a new data file in the database.<<BR>>If no scout selected: simulate recordings produced by the activity of the entire cortex. * '''Correlation with sensor''': Create a new scout with all the sources that are strongly correlated with a given sensor. * '''Expand with correlation''': Computes the correlation between the values for the scout's seed (first point) and all the other sources. The sources that have correlation coefficient superior to a given threshold are added to the scout. Correlation is computed with the Matlab ''corrcoef ''function. * '''Maximal value (new scout)''': Find the vertex with the maximal intensity at the current time, and create a scout centered on it. * '''Maximal value (selected scout)''': Move the scout's seed to the source that has the maximum amplitude in the scout, at the current time. | |
| Line 102: | Line 181: | 
| * '''View time series''': Same as the ''View time series'' button i nthe toolbar. * '''View on cortex''': Open a 3D figure with the cortex and the selected scout (if such a figure does not exist yet). * '''View in MRI Viewer''': Display the scout as a 3D mask in the MRI Viewer (anatomy only, no sources information)<<BR>><<BR>> {{attachment:scoutInMriViewer.gif}} * '''Center MRI on scout''': When a MRI figure (3D or MRI Viewer) is opened: center view on the scout's seed. | == Scout region == A scout is defined by its name, and it has several properties: a list of vertices and an aggregating function. These are usually enough to explore the activity at the cortex level the way we did it in these tutorials. An extra property can be defined on the scout: the explicit classification in a brain region. This property is used only in more advanced functional connectivity analysis, for the representation of the NxN connection graphs. It is introduced here for reference purpose. | 
| Line 107: | Line 184: | 
| === Menu: View > 3D display options === . To test this menu: open first a view of the sources in the MRI Viewer.<<BR>>Right-click on sources file > Cortical activations > Display on MRI (MRI Viewer), and go to intersting time point (around 45ms), and slices (around somato-sensory cortex). | A brain region in Brainstorm is following a hierarchy with three levels: hemisphere / lobe / sub-region. The definition at each level is optional: a region can be classified only at the hemisphere level, or at the hemisphere+lobe level, or none of them. It depends on level or hierarchy you are interested in to explore the connectivity graphs. | 
| Line 110: | Line 186: | 
| . {{attachment:menuDisplayOptions.gif}} | The region for a scout can be set with the ''Scout > Set region'' menus, and is encoded in a string that contains at least 2 characters: "'''HLxxx'''". H represents the hemisphere (L,R,U), L stands for the lobe (F,PF,C,P,T,O,L,U), and xxx for the sub-region name (optional). For both the hemisphere and the lobe, the value "U" stands for "Undefined", meaning that the classification is simply not set. The menu ''Set region>Custom region...'' lets you edit this string directly. The menu ''Set region>Undefined ''sets the region string to "UU" (undefined hemisphere, undefined lobe). | 
| Line 112: | Line 188: | 
| * '''Show selected scouts''': If selected, only the scouts that are selected are displayed in the 3D figures. Useful when you have many scouts defined, or if you want to produce MRI images with just one area coloured. * '''Show all scouts''': If selected, all the scouts are displayed in all the figures, whether they are selected or not. Default. * '''Show scout patch''': Display full scout patch in MRI/3D figures. If not selected: display only the seed of the scout. * '''Limit MRI sources to scouts''': In all MRI views: display only sources values for the visible scouts. If not selected, display the sources for all the cortical surface. | When set, the region string is shown before the scout name in the list, representing only the defined levels. It doesn't show the letters U for "undefined", therefore the scouts you create manually, that are by default set to "UU", do not show any extra string. | 
| Line 117: | Line 190: | 
| === Menu: View > Time series options... === . {{attachment:menuTSOptions.gif}} * '''Relative / Absolute values''': Extract to the sources values in absolute or relative values (before applying any other function). * '''Sources''': ... : Selection of the function to apply to the values of all the sources included in a scout. ''Mean'', ''Max'' and ''Power ''return only one value per time (taking for instance the average of all the sources), while ''All ''displays the time series for sources in the scout. This last menu is not available when more than one condition or scout is selected. * Try all the configurations for the scout '''LeftSS '''on condition '''!StimRightThumb'''.<<BR>>Absolute / Mean:<<BR>> {{attachment:optionsMean.gif}} <<BR>>Absolute / Max: (same shape, different amplitudes)<<BR>> {{attachment:optionsMax.gif}} <<BR>>Absolute / Power: {{attachment:optionsPower.gif}} <<BR>>Relative / Mean:<<BR>> {{attachment:optionsRelative.gif}} | . {{attachment:menuRegions.gif}} | 
| Line 127: | Line 193: | 
| Next step, the [[Tutorials/TutProcesses|graphical batching interface]]. <<EmbedContent(http://neuroimage.usc.edu/brainstorm3_register/get_feedback.php?Tutorials/TutScouts)>> | 
[WARNING: This page is part of the old tutorials, please refer to the new documentation]
 
Tutorial 9: Scouts
Authors: Francois Tadel, John C Mosher, Richard Leahy, Sylvain Baillet
In Brainstorm jargon, a scout is a region of interest (ROI) defined on the cortical surface: a subset of vertices of this surface. This document explains how to create one or several scouts, use them to retrieve the activity in specific brain regions, and compare between conditions.
Contents
Creating a scout
Almost all the features related to the scouts manipulation are accessible in the Scout tab in the main Brainstorm window. We are going to use this panel to create a scout that includes the cortical area that we observed in the previous tutorial: the one that responds to the stimulation of the right thumb.
The scouts are automatically saved in the surface file from which they are created, and they are loaded and automatically displayed each time the surface is loaded.
An atlas designates in this context a list of scouts. It is possible to have one or more atlases saved for each file, that can be automatically generated from Brainstorm, from an external software like FreeSurfer (see this page), or created manually scout by scout. All the cortex surfaces contain by default an empty atlas called "User scouts", for the user to create new regions of interest.
First vertex (seed)
- Select the protocol TutorialCTF, and display the times series for Subject01 / Right / ERF (double-click). 
- Display the associated sources (try it from the time series figure: Ctrl+S, or figure popup menu)
- Go to 48ms, and set the data threshold around 90%.
- Switch to the Scout tab, click on the first button in the toolbar (the big cross), and then click in the middle of the red area in left hemisphere in the 3D figure (rotate and zoom before if necessary). A small dot with the label "1" appears where you clicked. Your first scout is created in the User scouts atlas, and contains only one vertex for the moment. 
 
   
- Rename the scout into "LeftSS", for left somatosensory cortex: double-click on it in the Available scouts list, or scouts menu Edit > Rename. 
- Click on the second button in the Scouts panel toolbar, tooltip: Display scouts time series. And you will get the time course of this particular source for the whole time window (-50ms to 250ms). 
 
   
Growing a scout
In this case, the source is so focal that we could even use only the first vertex we selected to represent this area. But most of the time, the aim of a scout is to get the average activity over a larger region; so for the example, let's grow this scout. The buttons in the Scout size panel offer basic operations to define the scout extension.
- '>': Add the closest vertex (with respect to the seed) to the current scout. 
- '<': Remove the furthest vertex (with respect to the seed) from the current scout. 
- '>>': Grow scout in all directions 
- '<<': Shrink scout in all directions 
- 'Constrained': If this button is pressed, only the vertices that have a sources value above the threshold will be added to the scout (its growth will be limited to the red patch on the surface). 
- Add vertex manually: Select the Select point button, then select again the "LeftSS" scout. When you click on a vertex on the surface, it is added to the selected scout. 
- Remove vertex manually: Same as previously, but holding the SHIFT key at the same time. 
Now: add about 15-20 vertices with button '>>', not in Constrained mode, and display the scout values again. You can notice that the overall shape is the same as the scout with only one vertex, but the amplitudes are much lower. This is because the time series of all the sources in this scout have been averaged. And as we averaged the maximum values with lower values, the result is lower.
 
 
Display options
In the toolbar on the right side of scouts tab, you can find a list display options. Leave your mouse over it for a few seconds to get a description of each of them.
 Load Atlas Load Atlas
 Save selected scouts Save selected scouts
 Show all the scouts Show all the scouts
 Show only the selected scouts Show only the selected scouts
- If both previous buttons are unselected: no scouts are displayed in the 3D figure. It can be interesting to hide all the scouts if you are working with atlases on hi-resolution surfaces and if it takes to long to open a surface.
 Show / hide the contour line Show / hide the contour line
 Show / hide the scouts labels Show / hide the scouts labels
 Scout patch: Opaque Scout patch: Opaque
 Scout patch: Transparent Scout patch: Transparent
 Scout patch: None Scout patch: None
 Display the color of the region instead of the scout color (only for anatomical atlases) Display the color of the region instead of the scout color (only for anatomical atlases)
 Center MRI on scout (opens the MRI viewer and set the position to the current scout) Center MRI on scout (opens the MRI viewer and set the position to the current scout)
Scout function
How are the scouts time series calculated? For the scout LeftSS we have 15 signals, coming from 15 different dipoles with different orientations, that are combined into one unique signal. In the list of available scouts, you can see the indication "[mean]" next to the name of the scout. It represents the name of the function that is used for combined all the time series into one. This function can be changed individually for each scout, with the menu Scout > Set function in the Scout tab.
List of the functions
Here is a description of the different options. In the case of unconstrained sources (3 signals for each vertex, one for each orientation), the function is applied separately for each orientation and produces 3 time series instead of one. For more details, see the code of bst_scout_value.m.
- Mean: Average all the signals 
- PCA: Take the first mode of the PCA decomposition of all the signals. 
- Fast PCA: Same as PCA function, but computes the first PCA decomposition based only on a subset of the most powerful signals. It gives very similar results, but its computation is much faster for scouts that group a large number of dipoles (>50). 
- Mean(norm): Average the absolute values of all the signals 
- Max: For each time point, get the maximum across all the vertices [signed maximum in amplitude value: m = max(abs(signal)), scout = sign(signal(m)) * m] 
- Power: Average the power of all the signals (signal^2) 
- All: Do not apply any operation on the scouts signals, and display the time series of all the sources at the same time. 
"Absolute" display option
As said in the previous tutorial, the minimum norm current amplitudes can positive or negative. Which means that the values of the scouts, depending on the function that is used, may be positive or negative too. Most of the time we are interested in visualizing the absolute values of the scouts time series, to compare the activation level in different conditions or subjects.
For this purpose, at the bottom of the Scout tab, you can choose to display either Absolute or Relative values. The effect of this options depends if you are processing sources with constrained (1 signal per vertex) or unconstrained (3 signals per vertex) orientations:
- Constrained: Applies the scout function sfunction to all the N sources time series, and then apply or not an absolute value - Absolute: abs(sfunction(sources)) 
- Relative: sfunction(sources) 
 
- Unconstrained: Applies the scout function sfunction to the N sources time series for each orientation (x,y,z) separately, and then returns either the norm of the 3 orientations, or each orientation separately - Absolute: Returns one time series: 
 sqrt( sfunction(sources_x).^2 + sfunction(sources_y).^2 + sfunction(sources_z).^2)
- Relative: Returns three time series: 
 sfunction(sources_x), sfunction(sources_y), sfunction(sources_z)
 
Change the selection to Relative and display again the activation of scout LeftSS for condition Right.
 
 
The effect of the function depends if you are processing sources with constrained (1 signal per vertex) or unconstrained (3 signals per vertex) orientations.
Note that it is a display option, it is not saved in the scouts themselves. It is used ONLY when displaying the scouts time series with the "Display" button of the Scout tab. In all other cases, like the extraction of the scouts values from a script, this relative/absolute option is going to be ignored.
Testing the functions
Now, leave this Relative option selected for testing all the scouts functions one by one.
 
 
Select again the "Absolute" display again, and keep it for the rest of the tutorial.
Multiple scouts
We are going to create another scout for the other condition: the stimulation of the left thumb.
- Close all figures (toolbar button).
- Display the times series for Subject01 / Left / ERF (double-click). 
- Display the associated sources (Ctrl+S).
- Go to the main response peak (46 ms).
- Adjust the threshold value to get only a very focal point (about 60%).
- Create a new scout at this point. Name it RightSS, for Right SomatoSensory cortex. 
- Grow it to the same number of vertices as the LeftSS scout (about 15 vertices). 
- Select both scouts (Ctrl+click) and click on Display scouts time series button (second button in toolbar). 
 
   
 
   
- You can display the values of the two scouts on the same graph. Check the Overlay > Scouts checkbox in the Scout tab, and hit the Display scouts time series button again. 
 
   
- You can observe something that we expected: the activity in the right somatosensory cortex is much higher than in the left somatosensory cortex for a stimulation of the left thumb. 
Display scouts from the database explorer
You have to display the sources on the cortex to create the scouts. But once they are created, you can directly display the scouts time series from the tree. It means that you can quickly compare the values for a scout between many different conditions without having to open them all.
- Close all the figures (button in toolbar)
- Select the options "values: absolute" and "overlay: scouts"
- Right-click on Right / ERF / MN > Cortical activations > Scouts time series. 
 By default it shows all the scouts that are available in the current atlas.
 
   
   
- Note that if a surface is loaded, and at least one scout selected in the Scout tab, this popup menu would display only the selected scouts. 
- You can also display the scout values for many source files at the same time. Now keep the previous figure opened, so you have access to the scouts list in the Scout tab. Select only the LeftSS scout. In the database explorer, select at the same time the source files from condition Left and Right > right-click > Cortical activations > Scouts time series. 
 
   
   
- You can superimpose the two traces from the two experimental conditions by selecting the Overlay > Conditions checkbox in Scout panel. Select again the two files > Right click > Scouts time series. We see now the activation of the LeftSS scout for the stimulation of both thumbs. 
 
   
- This menu "Scouts time series" is present at all the levels in the tree. Try right-clicking on Subject01 > Scouts time series. 
- If you select a node in the database tree and click on the Display scouts time series button in the Scout tab, it would have exactly the same effect. 
 Try selecting both scouts in the list, select Subject01 in the tree, overlay / conditions, and then click on this button. You will see the response for each scout in both conditions.
 
   
Scout toolbar and menus
Let's spend a few minutes to explore all the menus in the Scout tab. Don't hesitate to click on all of them, it's the best way to remember what they do.
Menu: Atlas
  
- New atlas: Create a new empty atlas. 
- Load atlas: Load ROIs or a cortical parcellation coming from FreeSurfer or BrainSuite as a new atlas. 
- Rename atlas: Change the name that appears in the atlas list to refer to the selected atlas 
- Delete atlas: Delete the atlas and all the scouts in contains. The "User scouts" entry cannot be deleted. 
- Add scouts to atlas: Load ROIs or a cortical parcellation and add them to the current atlas. 
- Copy atlas: Duplicates an atlas and all the scouts 
- Copy selected scouts: Copy the selected scouts, and paste them in a new empty atlas. 
- Subdivide atlas: Splits all the scouts of the current atlas in smaller ROIs. Available options: 
 
   
- Subdivide selected scouts: Same thing, but processes only the selected scouts. 
- Surface clustering: Create a parcellation of the cortex surface and saves it as a new atlas. Can be useful for studying the connectivity between different regions of the brain. Only the "Homogeneous parcellation" options are currently reliable. 
Menu: Scout
  
- Add vertices: The user can select some points on the cortex surface and add them to the scout. 
 Equivalent: Click on Select point (first toolbar button), then select the scout in list, and select 3d points.
- Edit in MRI: Open an interface to edit the select scout as a 3D ROI, slice by slice. - Define the 3D mask using the drawing tools (read the tooltips of the buttons for help).
- Adjust the MRI contrast with right-click+move on the MRI image.
- Move through the slices with the mouse wheel, the small image on the left, or the slider.
- Warning: Only the vertices contained in the 3D mask are kept, all the volume information is lost. It means that the mask you intendend to draw might be very different from what you get as a scout at the end... 
 
   
 
- Set function: Set the scout function for the selected scouts. 
- Set region: Set the cortical region for the selected scouts. This information is useful when representing functional connectivity graphs. 
- Rename: Rename the selected scout. Shortcut: double-click. 
- Set color: Change the display color of scout patch in 3D figures. 
- Delete: Delete selected scouts. Shortcut: Delete key 
- Merge: Join two or more selected scouts. 
- Export to Matlab: Export the structures of the selected scouts to the Matlab environment, and makes them accessible from the command window. This menu can be useful to get quickly the list of vertices in the scout. 
- Import from Matlab: Import scouts structures that you modified manually from your Matlab command window directly as new scouts. 
- Edit surface: Create a new surface containing only the desired parts (remove or keep only the selected scouts). This is useful for instance for selecting one sub-cortical region from the Aseg FreeSurfer atlas (see the FreeSurfer tutorial). 
Menu: Sources
  
- Simulate recordings: Multiply the selected scouts with the forward model. Simulate the scalp data that would be recorded if only the selected cortex region was activated; all the other sources are set to zero. Create a new data file in the database. 
 If no scout selected: simulate recordings produced by the activity of the entire cortex.
- Correlation with sensor: Create a new scout with all the sources that are strongly correlated with a given sensor. 
- Expand with correlation: Computes the correlation between the values for the scout's seed (first point) and all the other sources. The sources that have correlation coefficient superior to a given threshold are added to the scout. Correlation is computed with the Matlab corrcoef function. 
- Maximal value (new scout): Find the vertex with the maximal intensity at the current time, and create a scout centered on it. 
- Maximal value (selected scout): Move the scout's seed to the source that has the maximum amplitude in the scout, at the current time. 
Scout region
A scout is defined by its name, and it has several properties: a list of vertices and an aggregating function. These are usually enough to explore the activity at the cortex level the way we did it in these tutorials. An extra property can be defined on the scout: the explicit classification in a brain region. This property is used only in more advanced functional connectivity analysis, for the representation of the NxN connection graphs. It is introduced here for reference purpose.
A brain region in Brainstorm is following a hierarchy with three levels: hemisphere / lobe / sub-region. The definition at each level is optional: a region can be classified only at the hemisphere level, or at the hemisphere+lobe level, or none of them. It depends on level or hierarchy you are interested in to explore the connectivity graphs.
The region for a scout can be set with the Scout > Set region menus, and is encoded in a string that contains at least 2 characters: "HLxxx". H represents the hemisphere (L,R,U), L stands for the lobe (F,PF,C,P,T,O,L,U), and xxx for the sub-region name (optional). For both the hemisphere and the lobe, the value "U" stands for "Undefined", meaning that the classification is simply not set. The menu Set region>Custom region... lets you edit this string directly. The menu Set region>Undefined sets the region string to "UU" (undefined hemisphere, undefined lobe).
When set, the region string is shown before the scout name in the list, representing only the defined levels. It doesn't show the letters U for "undefined", therefore the scouts you create manually, that are by default set to "UU", do not show any extra string.
Next
Next step, the ?graphical batching interface.

