Welp, that's the end of Google Summer of Code 2014, but not the end of this project. I didn't blog as much as I would have liked to, but I think I accomplished a lot overall.
Regarding the last post, the problem I encountered was that the source spaces were in "head" coordinates, which happens when the forward solution is computed. "Head" coordinates refers to the coordinate space of the MEG or EEG sensors. To resolve this, I had to transform the grid of mri voxels to "head" coordinates as well when mri_resolution=True. This wasn't an issue when mri_resolution=False because the volume source space was also converted to "head" coordinates.
Now the class SourceSpaces has a method called export_volume, which saves the source spaces as a nifti or mgz file that can be viewed in freeview. This only works for mixed source spaces with at least one volume source space, since the volume source space is responsible for setting up the 3d grid.
The source estimate can also be computed from a mixed source space. I wasn't able to implement code to view the source estimate as a 4d image, but that will build largely on the export_volume code previously described.
In addition, I created an example file to generate mixed source spaces. This example outputs the following figures.
The first figure shows the cortical surface with the additional volume source space of the left cerebellum. The locations of the dipoles are in yellow. The second figure shows the .nii file in freeview, where source spaces are in red.
Future work that needs to be done is creating these visualizations for source estimates, add options to fix the orientation of surface but not volume dipoles, and continue testing the accuracy of these combined source spaces using simulated data.
This blog is a space primarily for python programming and neuroscience research, with an emphasis on translating these concepts into everyday language.
Monday, August 18, 2014
Wednesday, August 6, 2014
Day 56: Checking In
Its been awhile since I wrote a post. There haven't been a lot of changed to the actual source localization, but I've spent a lot of time trying to integrate my work into the existing MNE repository.
For the past 2 weeks or so, I've been struggling with visualizing source spaces. This is an integral part of visualizing the source estimates. While I've been having success plotting the exact locations of source dipoles in down-sampled source spaces (e.g. volumes with 5 mm spacing, or surfaces with 6 mm spacing), when I try to interpolate onto a higher resolution image, I can't seem to get the right transformations for the surface sources.
For instance, the image below shows the source spaces for the cerebellum (blue) and the cortex (white). They look pixellated because they're lower resolution than the mri image.
But when I try to create higher resolution images of the source spaces, the cerebellum lines up but the cortex does not.
The goal now is to go through the code and find out exactly what coordinate frames the surfaces and volumes are generated in and then figure out how to transform from one coordinate system to another.
If you're interested in more details, the nitty gritty details have been on this pull request on github.
For the past 2 weeks or so, I've been struggling with visualizing source spaces. This is an integral part of visualizing the source estimates. While I've been having success plotting the exact locations of source dipoles in down-sampled source spaces (e.g. volumes with 5 mm spacing, or surfaces with 6 mm spacing), when I try to interpolate onto a higher resolution image, I can't seem to get the right transformations for the surface sources.
For instance, the image below shows the source spaces for the cerebellum (blue) and the cortex (white). They look pixellated because they're lower resolution than the mri image.
But when I try to create higher resolution images of the source spaces, the cerebellum lines up but the cortex does not.
The goal now is to go through the code and find out exactly what coordinate frames the surfaces and volumes are generated in and then figure out how to transform from one coordinate system to another.
If you're interested in more details, the nitty gritty details have been on this pull request on github.
Subscribe to:
Posts (Atom)