Skip to content

Latest commit

 

History

History
147 lines (95 loc) · 9.72 KB

README.md

File metadata and controls

147 lines (95 loc) · 9.72 KB

tFUS_neuronavigation

Objective: We develop and disseminate a model-based navigation (MBN) tool for acoustic dose delivery in the presence of skull aberrations that is easy to use by non-specialists.

Please cite our paper at:

tFUS_gui_figures_v15

Methods

Dependencies

This program requires the following dependencies: MATLAB (ver. R2023a), iso2mesh Library (included in download, GitHub found here), FreeSurfer, and a Linux Environment. For pre-calculation, a minimumm of 8-core CPU and 8 GB of RAM is required (≥20-core CPU and 32 GB of RAM preferred). Whereas the pre-calculation GUI should be run on a large, powerful computer, the planning GUI is best run on a local machine to avoid display lag. We recommend transferring the entire solution dataset on the local machine for a smooth viewing experience.

T1 Pre-processing

This program requires a T1-weighted MRI volume for each subject. This script also uses the Freesurfer routine, which to be used within Matlab needs to be sourced on the terminal used to launch Matlab, e.g.: source /usr/local/freesurfer/nmr-dev-env (replace with your Freesurfer installation path).

Next, run SAMSEG (~10 minutes on 10 threads), this creates a segmentation volumes (seg.mgz) used hereafter. In a Linux terminal with Freesurfer sourced, type:

mri_convert  <your_T1_volume_name.any_extension>  T1.nii  --conform
samseg --i T1.nii  --o ./  --threads 10  % adjust the # of threads to your computer' hardware
mri_convert  seg.mgz  seg.nii

Porosity Option 1: Assume uniform bone porosity (simplest, least accurate)

Assume uniform bone porosity within the SAMSEG skull mask. This ignores the pores and assumes 100% bone density everywehere in the skull.

header = load_nifti( 'seg.nii' );
smask = double( header.vol == 165);  % create skull mask from SAMSEG segmentation output
poro = 1 - double(smask);  % all skull is 100% bone
header.vol = poro;
save_nifti( header , 'poro.nii' );

Porosity Option 2: Niftiweb pCT tool

Go to the Niftiweb pCT tool, and upload the transformed T1 volume T1.nii and run the code below in MATLAB:

header = load_nifti( 'pct_0001.nii' );  % load Niftiweb pCT result
poro = 1 - header.vol / 1000;  % porosity calculation based on Aubry et al. "Experimental demonstration of noninvasive transskull adaptive focusing based on prior computed tomography scans." The Journal of the Acoustical Society of America 113.1 (2003): 84-93.
poro( find(poro>1) ) = 1;  % ensure porosity is between 0 and 1
poro( find(poro<0) ) = 0;
header.vol = poro;
save_nifti( header , 'poro.nii' )

Porosity Option 3: mri-to-ct deep learning tool

mri-to-ct details can be found here. The first step is to compute a liberal mask of the skull as shown below (input needed to mri-to-ct). In MATLAB:

header = load_mgh( 'seg.nii' );
smask = double( header.vol == 165);  % create skull mask from SAMSEG segmentation output
smask = imclose( smask , strel('sphere',5) );  % close the skull mask
smask = thickenbinvol( smask , 3 );  % make sure the mask covers a bit more than the actual skull (liberal mask)
header.vol = smask;
save_nifti( header , 'skull_mask.nii' );  % save skull mask as NIFTI to be used as input to mri-to-ct

Create the head mask and prepare input volumes

After creating the porosity nifti (poro.nii), run the following lines to create the porosity, head mask, and aseg files.

header = load_nifti( 'seg.nii' );
hmask = header.vol > 0;
hmask = imclose( hmask , strel('sphere',5) );  % close the mask, fill holes and smooth
for ii = 1 : size(hmask,3)
    hmask(:,:,ii) = imfill( hmask(:,:,ii) , 'holes' );
end
hmask = smooth3( double(hmask) , 'box' , 3 ) > 0.5;
header.vol = hmask;
save_nifti( header , 'hmask.nii' )

A = load_nifti( 'poro.nii' );
B = load_nifti( 'hmask.nii' );
C = load_nifti( 'aseg.nii' );

poro = reslice_( A.vol );
hmask = reslice_( B.vol );
aseg = reslice_( C.vol );

save  poro_resliced.mat  poro;
save  aseg_resliced.mat  aseg;
save  hmask_resliced.mat  hmask;

Pre-Calculation GUI

Start the GUI by running "precalculations_GUI_Fin" in the MATLAB Command Window

Screen Shot 2024-02-09 at 9 35 22 AM

Step 1: Load Data

First, load the data. The indicators next to each button should turn green after the file is loaded. Then, use the display to check for any inconsitences or mistakes with the headmask, porosity, and aseg files.

Screen Shot 2024-02-15 at 6 56 24 AM

Step 2: Generate Mesh

This step generates the mesh. The edge length is the average length of triangle discretization of the scalp mesh. In other words, a small edge length (4 mm) yields dense discrete triangles while a large edge length (16 mm) yields a coarse mesh. We have found 8 mm balances the accuracy of a dense mesh with computational efficiency of a course mesh. After generating the mesh, remove the faces below and including the ears and eyes. This should ideally yield a mesh with 2000-3000 faces. Lastly, check that all normals are pointing away from the mesh.

Screen Shot 2024-02-15 at 7 05 35 AM

Step 3: Choose Transducer Model

In this step, either select a pre-existing transducer model or design custom parameters.

Screen Shot 2024-02-15 at 7 41 00 AM

Step 4: Run Acoustic Intensity Calculations

In this step, pick the number of parallel processing units and indicate the file path. For parallel processing units, we recommend 20 parallel units which gives a pre-computation time of ~0.5 hours for 2500 faces. Computational time will increase with the density of the scalp mesh. Lastly, specify the absolute path for the output folder (using / to separate directories). Then, click "Run."

Screen Shot 2024-02-15 at 7 52 24 AM

Step 5: Check the Data Output

The output folder should include four .mat files: app_data, mSOUND_inputs, SOL_Beams, SOL_ScalpMaps. app_data.mat and mSOUND_inputs.mat are both input files into the pre-calculation. SOL_Beams.mat is the largest file (a few GB depending on the density of the mesh) and stores the beam calculations. SOL_ScalpMaps.mat includes the scalp maps generated from the beams.

Neuronavigation Planning GUI

Whereas the pre-calculation GUI should be run on a large, powerful computer, the planning GUI is best run on a local machine to avoid display lag. We recommend transferring the entire solution dataset on the local machine for a smooth viewing experience.

First, load the folder with the pre-calculation results. You must load the entire folder, rather than individual .mat files. On the bottom of the GUI in red text, the progress of loading the pre-calculation results will be indicated. Then, select the desired nuclei and click "Display scalp map."

Screen Shot 2024-02-18 at 12 11 48 PM

The main display window is interactive. The scalp map can me moved either using pre-determined options on the left under "NAVIGATE" or using traditional MATLAB figure controls on the top right of the display. Nuclei visibility can be modified in the bottom left with the light blue nuclei the current target. The head mesh can also be displayed along with only showing a single side of the scalp map.

Screen Shot 2024-02-18 at 12 19 34 PM

Additionally, you can click on a scalp map position and the display upbates the transducer, beam, and intensity bar graph at the new location. MATLAB tools in the upper right corner must be inactivated in order to change the transducer location. For easier positioning of the coil, it is best to click on the outside of the scalp map.

Screen Shot 2024-02-18 at 12 28 38 PM

The power distribution and scalp map figures can be saved using the "Save figures" button. This saves two figures in a single Matlab file, which can then be loaded using the load command. The .mat file saved will be located in the originally loaded folder with the following naming convention: FIG_NUCLEI_transdLOCATIONNUMBER.mat. For example, a saved figure for the left thalamus at trandsducer location #1505 will be saved as: FIG_LeftThalamus_transd1505.mat. Unlike in the GUI, the transducer location cannot be changed.

Screen Shot 2024-02-18 at 12 38 07 PM

The visibility of objects in the scalp map figure can be changed by opening the plot browser in View > Plot Browser:

Screen Shot 2024-02-18 at 12 41 48 PM