From 11cae695e959bd466c0082ba9e8d8cebf1832412 Mon Sep 17 00:00:00 2001 From: Nick Tustison Date: Wed, 20 Nov 2024 11:41:19 -0800 Subject: [PATCH] ENH: Rename 3-tissue brain extraction network. --- antspynet/utilities/brain_extraction.py | 15 ++++++++------- antspynet/utilities/deep_atropos.py | 4 ++-- antspynet/utilities/preprocess_image.py | 2 +- 3 files changed, 11 insertions(+), 10 deletions(-) diff --git a/antspynet/utilities/brain_extraction.py b/antspynet/utilities/brain_extraction.py index b3e0ca5..ed77a61 100644 --- a/antspynet/utilities/brain_extraction.py +++ b/antspynet/utilities/brain_extraction.py @@ -25,6 +25,8 @@ def brain_extraction(image, * "t1nobrainer": T1-weighted MRI---FreeSurfer-trained: h/t Satra Ghosh and Jakub Kaczmarzyk. * "t1combined": Brian's combination of "t1" and "t1nobrainer". One can also specify "t1combined[X]" where X is the morphological radius. X = 12 by default. + * "t1threetissue": T1-weighted MRI---originally developed from BrainWeb20 (and later expanded). + Label 1: parenchyma, label 2: meninges/csf, label 3: misc. head. * "flair": FLAIR MRI. Previous versions are specified as "flair.v0". * "t2": T2 MRI. Previous versions are specified as "t2.v0". * "t2star": T2Star MRI. @@ -140,7 +142,7 @@ def brain_extraction(image, weights_file_name_prefix = "brainExtractionInfantT1" elif modality == "t2infant": weights_file_name_prefix = "brainExtractionInfantT2" - elif modality == "bw20": + elif modality == "t1threetissue": weights_file_name_prefix = "brainExtractionBrainWeb20" is_standard_network = True else: @@ -154,14 +156,13 @@ def brain_extraction(image, if verbose: print("Brain extraction: retrieving template.") - if modality == "bw20": + if modality == "t1threetissue": reorient_template = ants.image_read(get_antsxnet_data("nki")) - resampled_image_size = reorient_template.shape else: reorient_template = ants.image_read(get_antsxnet_data("S_template3")) if is_standard_network and (modality != "t1.v1" and modality != "mra"): ants.set_spacing(reorient_template, (1.5, 1.5, 1.5)) - resampled_image_size = reorient_template.shape + resampled_image_size = reorient_template.shape number_of_filters = (8, 16, 32, 64) mode = "classification" @@ -171,9 +172,9 @@ def brain_extraction(image, mode = "sigmoid" unet_model = None - if modality == "bw20": + if modality == "t1threetissue": mode = "classification" - number_of_classification_labels = 4 # background, brain, skull, skin/misc. + number_of_classification_labels = 4 # background, brain, meninges/csf, misc. head unet_model = create_unet_model_3d((*resampled_image_size, channel_size), number_of_outputs=number_of_classification_labels, mode=mode, number_of_filters=number_of_filters, dropout_rate=0.0, @@ -218,7 +219,7 @@ def brain_extraction(image, xfrm_inv = xfrm.invert() - if modality == "bw20": + if modality == "t1threetissue": probability_images_warped = list() for i in range(number_of_classification_labels): probability_images_warped.append(xfrm_inv.apply_to_image( diff --git a/antspynet/utilities/deep_atropos.py b/antspynet/utilities/deep_atropos.py index 5490aa5..4ee634a 100644 --- a/antspynet/utilities/deep_atropos.py +++ b/antspynet/utilities/deep_atropos.py @@ -222,8 +222,8 @@ def deep_atropos(t1, rescale_intensities=True, verbose=verbose) if i == 0: - t1_bw20 = brain_extraction(input_images[0], modality="bw20", verbose=verbose) - t1_mask = t1_bw20['probability_images'][1] + t1_bext = brain_extraction(input_images[0], modality="t1threetissue", verbose=verbose) + t1_mask = t1_bext['probability_images'][1] n4 = n4 * t1_mask reg = ants.registration(hcp_t1_template, n4, type_of_transform="antsRegistrationSyNQuick[a]", diff --git a/antspynet/utilities/preprocess_image.py b/antspynet/utilities/preprocess_image.py index f0922ff..9f3e9ee 100644 --- a/antspynet/utilities/preprocess_image.py +++ b/antspynet/utilities/preprocess_image.py @@ -102,7 +102,7 @@ def preprocess_brain_image(image, print("Preprocessing: brain extraction.") bext = brain_extraction(preprocessed_image, modality=brain_extraction_modality, verbose=verbose) - if brain_extraction_modality == "bw20": + if brain_extraction_modality == "t1threetissue": mask = ants.threshold_image(bext['segmentation_image'], 1, 1, 1, 0) else: mask = ants.threshold_image(bext, 0.5, 1, 1, 0)