1221
Comment:
|
10472
|
Deletions are marked like this. | Additions are marked like this. |
Line 1: | Line 1: |
In this tutorial we will compare the performance of the BEM, FEM forward computation in basic model (realistic head model 3 layer) and also within in a spherical head model with an analytical solution. | ''Authors: Takfarinas Medani ...'' '''[TUTORIAL UNDER DEVELOPMENT: NOT READY FOR PUBLIC USE]''' <<TableOfContents(2,2)>> == Introduction == In this tutorial, we review and compare the forward models computation methods available in brainstorm. We apply these mesthod in spherical head model and in realistic models. we caompare the forward solution in different scenarios. This is a qualitative comparaison and not advanced study. You can find at the end of this page a list of reference that investigate deeply the differents forwad models. At this time, the FEM implementation is available for the EEG and the MEG computation. We will integrate and test soon the FEM for sEEG and ECOG. == EEG within a spherical model == === The volume conductor or the head model: === In this part we used the spherical head model distributed by the duneuro team ([[https://gitlab.dune-project.org/duneuro/duneuro-tests/-/blob/master/src/test_sphere_tet.msh|sphere]]). The following figure shows on the left the surface model and on right the tetrahedral mesh. {{attachment:DuneuroModelMesh.JPG||height="300",width="600"}} The model has three layers, the brain (inner skull), the outer skull and the scalp. === The source space : === For the source space or dipole position, we will use a realistic cortex distributed with the ICBM default subject of brainstorm. {{attachment:DuneuroModelMeshAnCortex.JPG||height="300",width="600"}} === The sensor model === Regarding the electrode's positions, we use the same position defined in this [[https://gitlab.dune-project.org/duneuro/duneuro-tests/-/blob/master/src/test_sphere_electrodes.txt|file]]. The total number of electrodes is 200 regularly distributed on the outer layer. {{attachment:DuneuroModelElectrode.JPG||height="300",width="350"}} === The forward model === Now, we have all the components of the model, we can start the process to compute the head model. For the EEG, brainstorm offers three methods. We perform these three computations on this model. 1. 3-shell sphere: best-fitting sphere based on the scalp, then OK. 1. OpenMeeg BEM: use the conductivity 0.33, 0.004 and 0.33, and keep the default options. 1. DUNEuro FEM: use the default option with the same conductivity value as the previous method. {{attachment:protocolDuneuroSphereEEG.JPG||height="180",width="250"}} === Qualitative comparison of the methods === In this tutorial, we use the display of the lead field vector to compare visually the performances of the three methods. Right-click on the head model, and then select 'View lead field vector'. You can select more than the head model in order to overlay the vectors. {{attachment:rightClickLeadFieldView.JPG||height="250",width="350"}} In this figure, we show all of these methods and zoom to focus on the vectors. For more documentations about these lead field vectors, please refere to these pages ([[https://www.researchgate.net/publication/260603026_Biomagnetism|page1]], [[http://www.bem.fi/book/11/11x/1119x.htm|page2]]) {{attachment:ViewLeadFieldEEGAllMethod.JPG||height="300",width="350"}} {{attachment:leadVectorZoom.JPG||height="300",width="350"}} We can easily see that the three vectors are pointing in the same direction and have the same length. === The computation time === Regarding the computation time: * 3-shell sphere: less than 30 secondes * OpenMeeg BEM: ~ 12 minutes. * DUNEuro FEM: ~ 2 minutes. This example has 15000 dipoles (x3) and 200 electrodes. There are many studies and publications that compare these methods and highlights the advantages and weakness of each method. From the brainstorm side, we recommend to use either openmeeg or duneuro for a realistic head model. If you have the FEM mesh*, Duneuro is faster for the same mesh resolution as the surface (OpenMeeg). Duneuro can be used for a more realistic model (more than 3 layers with the complex shape). *You can generate the FEM if you have the surfaces or the MRI, this process is explained in this '''tutorial'''. == EEG within brainstorm template (3 layers) == In this example, we will present the process of FEM mesh generation from surface model and highlight the effect of the mesh resolution. === The head model === We will use the default subject, then right-click and generate FEM mesh, and follow the same steps as explained in this [[https://neuroimage.usc.edu/brainstorm/Duneuro?highlight=FEM%20head%20model#FEM_head_model|section]]. We repeated this process four times, and hen we generate four FEM head models with four different values of the 'Max tetrahedral volume'. Here is a view of the obtained mesh with MaxVol = 10, 1, 0.1 and 0.01 (clockwise order). Let's give the name V10, V1, V01, and V001 respectively for these head models. MaxVol: is the maximum volume of the tetrahedral, in this example, we use the ctf coordinate system, therefore MaxVol here is a volume with units of cm3. The FEM generation time is quite fast, it varies from 15 secondes (V10) to less than 2 minutes (V001). {{attachment:femMeshModels.JPG||height="400",width="700"}} === The source and sensor space === We use a protocol with EEG data, you can reproduce with any protocol with available channels position and EEG recording, this is not important in this tutorial. For the source space, we use the default cortex with 15000 dipoles. The number of channels is 31, regularly distributed on the scalp surface, the model is shown on this figure. {{attachment:sourceSpaceAndChannels.JPG||height="350",width="700"}} === The forward model & lead field visualisation === Switch to the "functional data" view, right click on the subject => Compute Head model => Duneuro FEM ==> keep the defaults parameters and set the conductivity to 0.33, 0.04 and 0.33. Repeat the same process for four head models. The computation time in these models is not expensive, it varies from 1 minute (V10) to 6 minutes(V001). As in the previous example, we will display the lead field vectors for these head models. With the FEM, it's known that increasing the mesh increases the accuracy of the solution. Therefore we will use the V001 as a reference solution and we compare the other model to this reference. {{attachment:V001vsAll.JPG||height="200",width="700"}} From visual checking and for different electrodes configurations(tap H for more help on the figure), we observe that there is less or difference between the V001 and V01. Also, we noticed differences in the model V1 and higher difference in the model V10 (coarse mesh). These basics observations are expected regarding the quality of the mesh. === source estimation === In this section, we perform a source estimation using the previous four head models. Right-click on the head model ==> compute source [2018] and keep all the parameters as they are. We repeat the process for the four head models and then we display the results on the cortex. We select a time point to highlight cortical activation. {{attachment:MNLocalisationVsMeshResolution.JPG||height="450",width="700"}} The name of each figure is displayed on the title bare. We notice that the V01 and V001 have the same range on the scaling (0-300), whereas the V1 and V10 are lower (0-200). V001 and V01 give almost the same regions and are more focal than V1 and V10. === Comparaison between the different forward methods === In this section, we compute the forward model using the three available methods (3-shell, OpenMeeg, and DUNEuro). For these three methods, we use the same head model, with the same source and sensor space (as shown on the previous sections). For the Duneuro FEM, we select the head model V01 (the default value for the mesh generation). === Lead field visualisation === the BEM, FEM forward computation in basic model (realistic head model 3 layer) and also within a spherical head model with an analytical solution. When the forward computation is completed with the three methods, we can display the lead vector. {{attachment:LeadFielOnTemplateHead.JPG||height="450",width="700"}} We can see that the LF arrows of Duneuro and 3-shell are pointing in the same direction. Whereas, for OpenMeeg, there are some outliers (big blue arrows) pointing on wrongs and random directions. When we check closely the values of the OpenMeeg LF, we notice that the vectors are pointing in the correct direction in most of the source points. The outliers have big value and could not be displayed on the same scale ([[https://github.com/brainstorm-tools/brainstorm3/issues/185#issuecomment-606886284|we are working on that]]). These point are some dipoles which are to close from the interface. The OpenMeeg BEM solution is not accurate in these position. In litterature, similar problems are observed even with the FEM, however, this kind of instability are investigated and Duneuro offers many source model to avoid/minimize these errors. === source estimation === Following the same logic as in the previous section, we performs source localisation using the three head model described below. We select the Minimum norm and we keep the default parameters. {{attachment:MNLocalisationVsMethods.JPG||height="450",width="700"}} In this, basic example, we show that all the methods point to same area with more or less precision. As said, in this tutorial the objectify is to present how to use these tools. |
Line 5: | Line 150: |
Compare the performance of the mesh resolution vs the leadfield approximation v10, v1, v0.1 and v0.01 {{attachment:femMeshModels.JPG||height="400",width="700"}} |
|
Line 11: | Line 152: |
difference appears on v10 | the difference appears on v10 |
Line 15: | Line 156: |
in spherical head model | in the spherical head model |
Line 19: | Line 160: |
difference appears on the v1 and worse for v10 | the difference appears on the v1 and worse for v10 |
Line 21: | Line 162: |
== EEG forward within 3 layers head model : == In this example we compute the head model for the ICBM head model using the openmeeg method and then we generate the fem mesh for the same subject, then we compute the the leadfield using the Duneuro method v = 0.1 default value. MNorm {{attachment:sourcelocalisation.JPG||height="400",width="700"}} |
From these observations, we recommend using MaxVol = 0.1 and we set is as the default value for mesh resolution. |
Line 24: | Line 164: |
sloreta {{attachment:sourcelocalisationloreta.JPG||height="400",width="700"}} {{attachment:sourcelocalisationloreta2.JPG||height="400",width="700"}} |
== EEG forward within 3 layers head model: == In this example, we compute the head model for the ICBM head model using the openmeeg method and then we generate the fem mesh for the same subject, then we compute the lead field using the Duneuro method v = 0.1 default value. MNorm {{attachment:sourcelocalisation.JPG||height="400",width="700"}} sloreta {{attachment:sourcelocalisationloreta.JPG||height="400",width="700"}} {{attachment:sourcelocalisationloreta2.JPG||height="400",width="700"}} |
Authors: Takfarinas Medani ...
[TUTORIAL UNDER DEVELOPMENT: NOT READY FOR PUBLIC USE]
Contents
Introduction
In this tutorial, we review and compare the forward models computation methods available in brainstorm.
We apply these mesthod in spherical head model and in realistic models. we caompare the forward solution in different scenarios.
This is a qualitative comparaison and not advanced study. You can find at the end of this page a list of reference that investigate deeply the differents forwad models.
At this time, the FEM implementation is available for the EEG and the MEG computation. We will integrate and test soon the FEM for sEEG and ECOG.
EEG within a spherical model
The volume conductor or the head model:
In this part we used the spherical head model distributed by the duneuro team (sphere). The following figure shows on the left the surface model and on right the tetrahedral mesh.
The model has three layers, the brain (inner skull), the outer skull and the scalp.
The source space :
For the source space or dipole position, we will use a realistic cortex distributed with the ICBM default subject of brainstorm.
The sensor model
Regarding the electrode's positions, we use the same position defined in this file. The total number of electrodes is 200 regularly distributed on the outer layer.
The forward model
Now, we have all the components of the model, we can start the process to compute the head model. For the EEG, brainstorm offers three methods. We perform these three computations on this model.
- 3-shell sphere: best-fitting sphere based on the scalp, then OK.
OpenMeeg BEM: use the conductivity 0.33, 0.004 and 0.33, and keep the default options.
- DUNEuro FEM: use the default option with the same conductivity value as the previous method.
Qualitative comparison of the methods
In this tutorial, we use the display of the lead field vector to compare visually the performances of the three methods.
Right-click on the head model, and then select 'View lead field vector'. You can select more than the head model in order to overlay the vectors.
In this figure, we show all of these methods and zoom to focus on the vectors. For more documentations about these lead field vectors, please refere to these pages (page1, page2)
We can easily see that the three vectors are pointing in the same direction and have the same length.
The computation time
Regarding the computation time:
- 3-shell sphere: less than 30 secondes
OpenMeeg BEM: ~ 12 minutes.
- DUNEuro FEM: ~ 2 minutes.
This example has 15000 dipoles (x3) and 200 electrodes.
There are many studies and publications that compare these methods and highlights the advantages and weakness of each method.
From the brainstorm side, we recommend to use either openmeeg or duneuro for a realistic head model. If you have the FEM mesh*, Duneuro is faster for the same mesh resolution as the surface (OpenMeeg).
Duneuro can be used for a more realistic model (more than 3 layers with the complex shape).
*You can generate the FEM if you have the surfaces or the MRI, this process is explained in this tutorial.
EEG within brainstorm template (3 layers)
In this example, we will present the process of FEM mesh generation from surface model and highlight the effect of the mesh resolution.
The head model
We will use the default subject, then right-click and generate FEM mesh, and follow the same steps as explained in this section.
We repeated this process four times, and hen we generate four FEM head models with four different values of the 'Max tetrahedral volume'.
Here is a view of the obtained mesh with MaxVol = 10, 1, 0.1 and 0.01 (clockwise order).
Let's give the name V10, V1, V01, and V001 respectively for these head models.
MaxVol: is the maximum volume of the tetrahedral, in this example, we use the ctf coordinate system, therefore MaxVol here is a volume with units of cm3.
The FEM generation time is quite fast, it varies from 15 secondes (V10) to less than 2 minutes (V001).
The source and sensor space
We use a protocol with EEG data, you can reproduce with any protocol with available channels position and EEG recording, this is not important in this tutorial.
For the source space, we use the default cortex with 15000 dipoles. The number of channels is 31, regularly distributed on the scalp surface, the model is shown on this figure.
The forward model & lead field visualisation
Switch to the "functional data" view, right click on the subject => Compute Head model => Duneuro FEM ==> keep the defaults parameters and set the conductivity to 0.33, 0.04 and 0.33.
Repeat the same process for four head models.
The computation time in these models is not expensive, it varies from 1 minute (V10) to 6 minutes(V001).
As in the previous example, we will display the lead field vectors for these head models.
With the FEM, it's known that increasing the mesh increases the accuracy of the solution. Therefore we will use the V001 as a reference solution and we compare the other model to this reference.
From visual checking and for different electrodes configurations(tap H for more help on the figure), we observe that there is less or difference between the V001 and V01. Also, we noticed differences in the model V1 and higher difference in the model V10 (coarse mesh). These basics observations are expected regarding the quality of the mesh.
source estimation
In this section, we perform a source estimation using the previous four head models.
Right-click on the head model ==> compute source [2018] and keep all the parameters as they are.
We repeat the process for the four head models and then we display the results on the cortex. We select a time point to highlight cortical activation.
The name of each figure is displayed on the title bare. We notice that the V01 and V001 have the same range on the scaling (0-300), whereas the V1 and V10 are lower (0-200). V001 and V01 give almost the same regions and are more focal than V1 and V10.
Comparaison between the different forward methods
In this section, we compute the forward model using the three available methods (3-shell, OpenMeeg, and DUNEuro). For these three methods, we use the same head model, with the same source and sensor space (as shown on the previous sections). For the Duneuro FEM, we select the head model V01 (the default value for the mesh generation).
Lead field visualisation
the BEM, FEM forward computation in basic model (realistic head model 3 layer) and also within a spherical head model with an analytical solution.
When the forward computation is completed with the three methods, we can display the lead vector.
We can see that the LF arrows of Duneuro and 3-shell are pointing in the same direction. Whereas, for OpenMeeg, there are some outliers (big blue arrows) pointing on wrongs and random directions.
When we check closely the values of the OpenMeeg LF, we notice that the vectors are pointing in the correct direction in most of the source points. The outliers have big value and could not be displayed on the same scale (we are working on that).
These point are some dipoles which are to close from the interface. The OpenMeeg BEM solution is not accurate in these position. In litterature, similar problems are observed even with the FEM, however, this kind of instability are investigated and Duneuro offers many source model to avoid/minimize these errors.
source estimation
Following the same logic as in the previous section, we performs source localisation using the three head model described below.
We select the Minimum norm and we keep the default parameters.
In this, basic example, we show that all the methods point to same area with more or less precision. As said, in this tutorial the objectify is to present how to use these tools.
Describe femVSbem here.
v0.1 and V0.01 are almost the same ....
the difference appears on v10
in the spherical head model
same observation on the lf view
the difference appears on the v1 and worse for v10
From these observations, we recommend using MaxVol = 0.1 and we set is as the default value for mesh resolution.
EEG forward within 3 layers head model:
In this example, we compute the head model for the ICBM head model using the openmeeg method and then we generate the fem mesh for the same subject, then we compute the lead field using the Duneuro method v = 0.1 default value. MNorm
sloreta