Size: 18902
Comment:
|
Size: 18903
Comment:
|
Deletions are marked like this. | Additions are marked like this. |
Line 70: | Line 70: |
1. Click on '''Auto''' to automatically detect the positions and labels for the cap. '''''Just a note that this is an experimental feature. Please verify the results carefully'''''. Click '''OK''' on the disclaimer that pops up.<<BR>><<BR>> {{attachment:revogui12.png||width="600"}} | 1. Click on '''Auto''' to automatically detect the positions and labels for the cap. '''''Just a note that this is an experimental feature. Please verify the results carefully'''''. Click '''Yes '''on the disclaimer that pops up.<<BR>><<BR>> {{attachment:revogui12.png||width="600"}} |
Digitize EEG sensor locations and head shape using 3D scanners
Authors: Chinmay Chinara, Wayne Mead, Yash Shashanka Vakilna, Anand Joshi, Takfarinas Medani, Raymundo Cassani, John Mosher, Richard Leahy
This page describes the 3D scanner Digitize GUI for the legacy version
For the 2024 (updated) version, visit:
https://neuroimage.usc.edu/brainstorm/Tutorials/TutDigitize3dScanner
Background
EEG allows the monitoring and recording of electrical brain activity from multiple electrodes placed on the scalp. EEG-based cortical current density mapping requires accurate knowledge of the locations of the electrodes on the scalp. The number and placement of electrodes vary from a few to high-density models with hundreds of electrodes. Researchers and clinicians have developed some solutions for precise electrode localization. The most common approach uses an electromagnetic digitizer (e.g. Polhemus). However, these methods are typically not easy to use, require skilled technicians, and the procedures are time-consuming and subject to errors.
This study presents Revopoint Range 2, an affordable and advanced 3D scanner that uses structured light approach for mapping the scalp surface (with the EEG cap on) and automatically identifying each electrode's 3D location and label.
Digitize using 3D scanner
Example dataset
The example dataset can be downloaded from here.
sub1/
sub1_mesh_tex.obj: The obj mesh file.
sub1_mesh_tex.jpg: The texture file associated with the mesh.
sub1_mesh_tex.mtl: The material file associated with the mesh.
- The mesh has been defaced.
NOTE: Jump to Acquiring using 3D scanner section to generate your own data.
Loading the mesh
If running from source code, we recommend having MATLAB R2018b or higher for best performance.
Create a new protocol called Tutorial_Digitizer.
Go to File>Digitize>3D scanner.
Enter the Subject ID in the pop-up window that opens up. Make sure that it is unique and does not match to any other subject in the same protocol. We will call it sub1.
The subject gets created with the Default Anatomy.
From the Import surfaces... window, do the following:
File type: Wavefront OBJ (*.obj)
Choose sub1_mesh_tex.obj
Click Open.
Adjust the scale based on the prompt. Choose 0.001.
The mesh gets loaded into the protocol for the subject and the Digitize GUI opens up along with the mesh loaded. The Brainstorm GUI will be hidden during the use of the application and will reappear after exiting Digitize GUI.
- This application allows you to collect:
- Three head localization coils (HPI) for computing the head coordinate system
- Three anatomical landmarks for Sensor-MRI co-registration
- EEG sensor locations
- Scalp points for head shape
- When complete the coordinates can be save in a variety of formats including CTF (*.pos), megDraw (*.eeg) or tab-delimited ASCII text.
Configure EEG cap point collection
Go to File>Edit Settings.... This opens up the 3DScanner configuration window.
Digitize MEG HPI coils: This will allow for collection of the positions of the HPI coils. This is important for CTF users since the data collected from the MEG system is saved in HPI coil coordinate system. Users collecting only EEG sensors or just head shape will not collect these points. For this example, we set it to 0 as we are just collecting anatomical fiducials.
Number of times to collect the three fiducials: These collections will occur at the beginning of the session and will be averaged together to compute the transformation to the HPI or head coordinate system. For this example, we set it to 1.
Beep: This will generate a beep sound with each point collection (this is often helpful to realize a click while collecting a point from the mesh). For this example, we set it to 1.
Configure EEG montage
The next step is to configure EEG montage to select the cap layout we want to select. Brainstorm by default has a bunch of cap layouts already predefined. For this example, we use the ANT Waveguard 65 cap.
Go to EEG montage>Add EEG Montage...>Use default EEG cap>ICBM152>ANT>ANT Waveguard 65 to add load the layout to the Coordinates section where the collected points will also be updated.
Collect the required number of Anatomical Fiducials
Click on the mesh, and press Ctrl+P to activate collection mode (you will see the mouse cursor change to a crosshair). Click on the desired location on the mesh and press key 'C' to collect the Nasion, LPA and RPA fiducials in order. Check Coordinate Systems tutorial for selecting the correct locations. The change can be seen in the Coordinates panel under each label.
When collecting more than one set of fiducials, an error message is displayed if the difference between the sets is > 5mm
- If the MEG HPI coils are not used, then the head coordinate system is computed with the anatomical fiducials and the points are plotted on the 3D point display. Unless the user changes the anatomy for the brainstorm Digitize subject, the default anatomy is used. It may not match exactly the subject being digitized, but should be a good quality control image to ensure the points are positioned where expected.
Note that the 3D figure is a standard Brainstorm window, where you can use all the mouse operations (rotation, zoom, popup menu) and the keyboard shortcuts (predefined view, screen capture...) introduced in the previous tutorials.
The coordinates are displayed in the coordinate list in cm
Once the fiducials are collected, the collection automatically moves to EEG positions
Collect the required number of EEG points
- Make sure collection mode is active (crosshair visible as per Step-1 in the previous section).
We are going to automatically detect and label the electrodes in the cap, but for that we need a minimal set of manual points that will help detect the rest of the electrodes. For this example, we are going to manually collect Fpz, T7, T8, Oz in order from the mesh based on the layout above. The 4 figures below (top to bottom) correspond to the order Fpz, T7, T8, Oz respectively.
At this point we can continue collecting points manually (which can get time consuming). Instead, you can see the Auto button gets activated (after the relevant electrodes have been manually marked in Step-2 above).
Click on Auto to automatically detect the positions and labels for the cap. Just a note that this is an experimental feature. Please verify the results carefully. Click Yes on the disclaimer that pops up.
NOTE: If the electrode detection does not work as expected with those initial marking of electrodes, try to manually set few more electrodes before pressing the 'Auto' button.
Edit EEG points
If there are any bad detections, you can manually select and press Delete key to delete these points from the Coordinates list and the figure one at a time. Then in the point selection mode (press Ctrl+P while on the figure) click on the correct location on the mesh and press key C to remark them manually which also updates the Coordinates list.
Collect the desired number of head shape points
- In order to take full advantage of the Sensor-MRI co-registration algorithms in Brainstorm, it is recommended to collect approximately 100-150 points from the head: 5-10 points from the boney part of the nose, 10-15 points across the eyebrows, then an even coverage of the scalp from the eyebrows to the inion. It is NOT recommended to collect points below the inion on the neck, since the shape of the neck can change between lying in the MRI scanner and sitting during point collection. Even coverage is more important that dense coverage.
To automatically choose 150 random points, click on Random. These can be seen as the green points in the figure and the numbered 001-150 in the Coordinates list on the GUI.
If user wants to add head shape points manually, it can be done by clicking on the figure, and press Ctrl+P to activate collection mode. Click on the desired location on the mesh and press key 'C' to collect. The points 151-155 in the figure below were collected manually.
- Each point is displayed on the 3D points display.
- The counter is incremented each time a point is collected and therefore indicates which point will to be collected next.
Save
- The user can save the points to a text file in a variety of formats.
The points can be saved as a POS file for import into CTF datasets or your Brainstorm database. Select Save as... and confirm the file name and location.
When exiting the program, select File > Save and exit to ensure the points are saved in the Brainstorm database.
View on scalp surface
Once saved, go to the functional tab, you can see the channel created under the subject name with all the electrodes assigned. Double click on it to see the electrodes on the default scalp (top row image below). Right click on the channel file, MRI Registration>Check to see how well the alignment is (bottom row image below). There will be some errors due to the scalp not matching the head shape of the subject.
To align it, right click on the channel file, MRI Registration>Refine using head points to align it to the default head shape. Refer to Automatic Registration for more details.
Acquiring using 3D scanner
The Hardware
Revopoint hardware package comes with the 3D scanner with tripod and a USB to USB-C cable. More details on the hardware can be found in their website.
System requirements
- Windows: Windows 10/11 (64-bit)
- RAM: 8 GB or better
- Processor: Intel Core i5 10th Generation or better
- Mac OS X: 10.7+
Prepare the EEG cap
- The EEG cap can be made of shiny materials and these can lead to bad scanning. To reduce the effect of shine make sure to spray it with any commercially available dry shampoo before each subject scan.
Prepare the subject
- Make sure the subject has no glasses on. Since the scanning involves use of flashing white light, the reflections from the glasses could lead to bad scanning.
- Minimize structures floating over the cap such as additional wires or hair. If the cap has removable electrodes with exposed wires, scan the cap without electrodes attached. A stocking over the cap can be used if exposed wires cannot be removed.
- While the scanning is on, make sure the subject sits as steady as possible and has his eyes closed.
Revo Scan software
Revopoint uses the Revo Scan software to do the scanning of a subject wearing EEG cap and generate a 3D mesh. This mesh can then be imported into Brainstorm to automatically detect and label the electrodes in it.
Installation
Download the software from their webpage based on your Operating System (OS).
Install it by keeping the defaults. After it has finished installing click on Complete.
Start new project
Connect the 3D scanner to your PC and launch the RevoScan software. It will take few seconds to initialize and show Scanner Connected as under.
- If you are connecting it for the first time, it might ask for calibration of the device which is a very essential step. Calibrating a Revopoint 3D scanner resets its internal parameters to ensure accurate scanning data and alignment. Follow the onscreen steps and prompts to complete the calibration.
Click on New Project and give it a File Name and Location. Click New. Make sure to start a new project per subject.
This should now take you to the scanning window.
Pre-scanning setup (Scan Mode)
Depth Camera exposure (top left section): Use the plus/minus buttons behind the scanner to increase/decrease the exposure. Blue/Red artefacts in this window indicate under/over exposed camera. Use the buttons to adjust the exposure so that there are minimal/no artefacts. For e.g. in the scan below, the exposure of 1 was gave underexposed artefacts and increasing it to 2 gave good results. This exposure depends largely on the environment your scanning is done in and can vary from case to case.
Scan Settings (right section):
- Accuracy: High Accuracy
- Tracking Mode: Feature Tracking
- Object Type: Body
- Color Scanning: On
- Base Removal: Default (90%)
Scanning Distance: ~ 400 mm to 900 mm
Get a good scanning distance: Pointing the camera to the subject, move close and away from them. You can see the range meter on the right just to the left of the Scan Settings going from Too Near to Too Far. You want to be in the Excellent range to get the best results. Note/mark this distance.
Scanning
From the marked position above, click on the Play button on the back of the Revopoint to start the scanning. Move the camera continuously with a steady hand, balance speed and stability to improve the quality of your scans. Most scans for the entire head can be accomplished in 30 seconds. The green color on the scanning mesh being generated indicate that the scan is going correctly and in Excellent range. If otherwise, then pause the scanning at that instant by pressing the Play button again. There are 2 things that can be done from here:
If you want to resume over the same scan, pressing Play again will resume the scan and automatically start aligning to the already generated scan. This is not recommended as the result might contain a lot of over scanning artefacts.
The other option is to click on Complete and start a new scan and then later you can choose to merge multiple scans together. This is recommended as this reduces the creation of artefacts.
Processing
This section covers the cleaning and processing of the scanned mesh required before it can be exported.
Fusion: This merges the raw point cloud mesh to a more unified and accurate point cloud model.
Fusion Method: Advanced
Point distance(mm): 1
Click on Apply
Clean the mesh using the clipping tool on the right to remove unwanted mesh area. We do not need any area other than the cap and face.
Isolation: This identifies and removes and floating or noisy points that are isolated from the main point cloud data to make it more clean.
Isolation Rate: 50%
Click on Apply
Overlap Detection: This is to remove any misalignments or overlapping data in the point cloud for a more accurate and consistent model.
Overlap distance(mm): 3
Click on Detect
Mesh: It converts the point cloud data to a solid 3D model.
Turn off the color by pressing the color icon
on the top for better visualization of the meshing process
Quality: 5.8
Hole Filling(Auto): Turned off
Click on Apply
Simplify: This makes the mesh more manageable for storage and processing. We do not require a very dense mesh for working with in Brainstorm so anything around 100000-200000 vertices would be sufficient.
Ratio: 50%
Click on Apply
Texture Mapping: Maps the texture to the 3D model
- Turn on the color back by pressing the grayed out color icon on the top
Texture: Color image
Click on Apply
Saving and exporting
Click on Export>Texture Model and save as .obj. This will save 3 files to the disk:
.obj: The obj mesh file.
.jpg: The texture file associated with the mesh.
.mtl: The material file associated with the mesh.