|
@@ -18,16 +18,20 @@ along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
import datetime
|
|
|
import os
|
|
|
|
|
|
+import numpy
|
|
|
import pandas.util.testing
|
|
|
import pytest
|
|
|
|
|
|
from conftest import SUBJECTS_DIR
|
|
|
from freesurfer_stats import CorticalParcellationStats
|
|
|
|
|
|
+
|
|
|
+
|
|
|
|
|
|
@pytest.mark.parametrize(
|
|
|
('path', 'headers', 'hemisphere',
|
|
|
- 'whole_brain_measurements', 'structural_measurements'),
|
|
|
+ 'whole_brain_measurements', 'structural_measurements_length',
|
|
|
+ 'structural_measurements_subset'),
|
|
|
[(os.path.join(SUBJECTS_DIR, 'fabian', 'stats', 'lh.aparc.DKTatlas.stats.short'),
|
|
|
{'CreationTime': datetime.datetime(2019, 5, 9, 21, 5, 54, tzinfo=datetime.timezone.utc),
|
|
|
'generating_program': 'mris_anatomical_stats',
|
|
@@ -56,6 +60,7 @@ from freesurfer_stats import CorticalParcellationStats
|
|
|
'supratentorial_volume_mm^3': 1172669.548920,
|
|
|
'supratentorial_volume_without_ventricles_mm^3': 1164180.548920,
|
|
|
'estimated_total_intracranial_volume_mm^3': 1670487.274486},
|
|
|
+ 3,
|
|
|
[{'structure_name': 'caudalanteriorcingulate',
|
|
|
'number_of_vertices': 2061,
|
|
|
'surface_area_mm^2': 1472,
|
|
@@ -115,6 +120,7 @@ from freesurfer_stats import CorticalParcellationStats
|
|
|
'supratentorial_volume_mm^3': 1172669.548920,
|
|
|
'supratentorial_volume_without_ventricles_mm^3': 1164180.548920,
|
|
|
'estimated_total_intracranial_volume_mm^3': 1670487.274486},
|
|
|
+ 2,
|
|
|
[{'structure_name': 'bankssts',
|
|
|
'number_of_vertices': 1344,
|
|
|
'surface_area_mm^2': 825,
|
|
@@ -134,9 +140,72 @@ from freesurfer_stats import CorticalParcellationStats
|
|
|
'integrated_rectified_mean_curvature_mm^-1': 0.110,
|
|
|
'integrated_rectified_gaussian_curvature_mm^-2': 0.021,
|
|
|
'folding_index': 3,
|
|
|
- 'intrinsic_curvature_index': 0.6}])],
|
|
|
+ 'intrinsic_curvature_index': 0.6}]),
|
|
|
+ (os.path.join(
|
|
|
+ SUBJECTS_DIR, 'soichi', 'stats', 'rh.aparc.stats'),
|
|
|
+ {'CreationTime': datetime.datetime(2020, 5, 4, 22, 20, 26, tzinfo=datetime.timezone.utc),
|
|
|
+ 'AnnotationFileTimeStamp': datetime.datetime(2020, 5, 4, 21, 58, 13),
|
|
|
+ 'AnnotationFile': '../label/rh.aparc.annot',
|
|
|
+ 'SUBJECTS_DIR': '/N/dc2/scratch/hayashis/bigred3-workflows'
|
|
|
+ '/5eb0689676c10ead933d673c/5eb068b076c10e7b013d673f',
|
|
|
+ 'anatomy_type': 'surface',
|
|
|
+ 'cmdline': 'mris_anatomical_stats -th3 -mgz -cortex ../label/rh.cortex.label '
|
|
|
+ '-f ../stats/rh.aparc.stats -b -a ../label/rh.aparc.annot -c '
|
|
|
+ '../label/aparc.annot.ctab output rh white',
|
|
|
+ 'cvs_version': '7.0.0',
|
|
|
+ 'generating_program': 'mris_anatomical_stats',
|
|
|
+ 'hemi': 'rh',
|
|
|
+ 'hostname': 'nid00762',
|
|
|
+ 'machine': 'x86_64',
|
|
|
+ 'mrisurf.c-cvs_version': '7.0.0',
|
|
|
+ 'subjectname': 'output',
|
|
|
+ 'sysname': 'Linux',
|
|
|
+ 'user': 'hayashis',
|
|
|
+ 'BrainVolStatsFixed': 'NotNeeded because voxelvolume=1mm3'},
|
|
|
+ 'right',
|
|
|
+ {'white_surface_total_area_mm^2': 83579.2,
|
|
|
+ 'mean_thickness_mm': 2.35815,
|
|
|
+ 'brain_segmentation_volume_mm^3': 1169408.0,
|
|
|
+ 'brain_segmentation_volume_without_ventricles_mm^3': 1157593.0,
|
|
|
+ 'brain_segmentation_volume_without_ventricles_from_surf_mm^3': 1157593.0,
|
|
|
+ 'total_cortical_gray_matter_volume_mm^3': 454587.696158,
|
|
|
+ 'supratentorial_volume_mm^3': 1023873.0,
|
|
|
+ 'supratentorial_volume_without_ventricles_mm^3': 1012058.0,
|
|
|
+ 'estimated_total_intracranial_volume_mm^3': 1420434.160521},
|
|
|
+ 34,
|
|
|
+ [{'structure_name': 'bankssts',
|
|
|
+ 'number_of_vertices': 1094,
|
|
|
+ 'surface_area_mm^2': 757,
|
|
|
+ 'gray_matter_volume_mm^3': 1725,
|
|
|
+ 'average_thickness_mm': 2.215,
|
|
|
+ 'thickness_stddev_mm': 0.544,
|
|
|
+ 'integrated_rectified_mean_curvature_mm^-1': 0.109,
|
|
|
+ 'integrated_rectified_gaussian_curvature_mm^-2': 0.025,
|
|
|
+ 'folding_index': 9,
|
|
|
+ 'intrinsic_curvature_index': 1.1},
|
|
|
+ {'structure_name': 'caudalanteriorcingulate',
|
|
|
+ 'number_of_vertices': 1137,
|
|
|
+ 'surface_area_mm^2': 780,
|
|
|
+ 'gray_matter_volume_mm^3': 2327,
|
|
|
+ 'average_thickness_mm': 2.842,
|
|
|
+ 'thickness_stddev_mm': 0.667,
|
|
|
+ 'integrated_rectified_mean_curvature_mm^-1': 0.116,
|
|
|
+ 'integrated_rectified_gaussian_curvature_mm^-2': 0.021,
|
|
|
+ 'folding_index': 11,
|
|
|
+ 'intrinsic_curvature_index': 1.0},
|
|
|
+ {'structure_name': 'caudalmiddlefrontal',
|
|
|
+ 'number_of_vertices': 3126,
|
|
|
+ 'surface_area_mm^2': 2218,
|
|
|
+ 'gray_matter_volume_mm^3': 5978,
|
|
|
+ 'average_thickness_mm': 2.447,
|
|
|
+ 'thickness_stddev_mm': 0.605,
|
|
|
+ 'integrated_rectified_mean_curvature_mm^-1': 0.122,
|
|
|
+ 'integrated_rectified_gaussian_curvature_mm^-2': 0.024,
|
|
|
+ 'folding_index': 28,
|
|
|
+ 'intrinsic_curvature_index': 3.1}])],
|
|
|
)
|
|
|
-def test_read(path, headers, hemisphere, whole_brain_measurements, structural_measurements):
|
|
|
+def test_read(path, headers, hemisphere, whole_brain_measurements, structural_measurements_length,
|
|
|
+ structural_measurements_subset):
|
|
|
stats = CorticalParcellationStats.read(path)
|
|
|
assert headers == stats.headers
|
|
|
assert hemisphere == stats.hemisphere
|
|
@@ -159,10 +228,63 @@ def test_read(path, headers, hemisphere, whole_brain_measurements, structural_me
|
|
|
'folding_index',
|
|
|
'intrinsic_curvature_index',
|
|
|
]
|
|
|
+ assert len(stats.structural_measurements) == structural_measurements_length
|
|
|
pandas.util.testing.assert_frame_equal(
|
|
|
- left=pandas.DataFrame(structural_measurements),
|
|
|
- right=stats.structural_measurements,
|
|
|
+ left=pandas.DataFrame(structural_measurements_subset),
|
|
|
+ right=stats.structural_measurements.iloc[:3],
|
|
|
check_like=True,
|
|
|
check_dtype=True,
|
|
|
check_names=True,
|
|
|
)
|
|
|
+
|
|
|
+
|
|
|
+@pytest.mark.parametrize(
|
|
|
+ ('path', 'structural_measurements_length'),
|
|
|
+ [(os.path.join(SUBJECTS_DIR, 'soichi', 'stats', 'lh.BA_exvivo.stats'), 14),
|
|
|
+ (os.path.join(SUBJECTS_DIR, 'soichi', 'stats', 'lh.BA_exvivo.thresh.stats'), 14),
|
|
|
+ (os.path.join(SUBJECTS_DIR, 'soichi', 'stats', 'lh.aparc.DKTatlas.stats'), 31),
|
|
|
+ (os.path.join(SUBJECTS_DIR, 'soichi', 'stats', 'lh.aparc.a2009s.stats'), 74),
|
|
|
+ (os.path.join(SUBJECTS_DIR, 'soichi', 'stats', 'lh.aparc.pial.stats'), 34),
|
|
|
+ (os.path.join(SUBJECTS_DIR, 'soichi', 'stats', 'lh.aparc.stats'), 34),
|
|
|
+ (os.path.join(SUBJECTS_DIR, 'soichi', 'stats', 'rh.BA_exvivo.stats'), 14),
|
|
|
+ (os.path.join(SUBJECTS_DIR, 'soichi', 'stats', 'rh.BA_exvivo.thresh.stats'), 14),
|
|
|
+ (os.path.join(SUBJECTS_DIR, 'soichi', 'stats', 'rh.aparc.DKTatlas.stats'), 31),
|
|
|
+ (os.path.join(SUBJECTS_DIR, 'soichi', 'stats', 'rh.aparc.a2009s.stats'), 74),
|
|
|
+ (os.path.join(SUBJECTS_DIR, 'soichi', 'stats', 'rh.aparc.pial.stats'), 34),
|
|
|
+ (os.path.join(SUBJECTS_DIR, 'soichi', 'stats', 'rh.aparc.stats'), 34)],
|
|
|
+)
|
|
|
+def test_read_structural_measurements_length(path, structural_measurements_length):
|
|
|
+
|
|
|
+ stats = CorticalParcellationStats.read(path)
|
|
|
+ assert len(stats.structural_measurements) == structural_measurements_length
|
|
|
+
|
|
|
+
|
|
|
+@pytest.mark.parametrize(
|
|
|
+ ("line", "expected_column_name", "expected_value"),
|
|
|
+ [
|
|
|
+ (
|
|
|
+ "Measure Cortex, CortexVol Total cortical gray matter volume, 553998.311189, mm^3",
|
|
|
+ "total_cortical_gray_matter_volume_mm^3",
|
|
|
+ 553998.311189,
|
|
|
+ )
|
|
|
+ ],
|
|
|
+)
|
|
|
+def test__parse_whole_brain_measurements_line(
|
|
|
+ line, expected_column_name, expected_value
|
|
|
+):
|
|
|
+
|
|
|
+ column_name, value = CorticalParcellationStats._parse_whole_brain_measurements_line(
|
|
|
+ line,
|
|
|
+ )
|
|
|
+ assert column_name == expected_column_name
|
|
|
+ assert numpy.allclose(value, [expected_value])
|
|
|
+
|
|
|
+
|
|
|
+@pytest.mark.parametrize(
|
|
|
+ "line",
|
|
|
+ ["Measure Cortex, CortexVol Total cortical gray matter volume, 553998.311189",],
|
|
|
+)
|
|
|
+def test__parse_whole_brain_measurements_line_parse_error(line):
|
|
|
+
|
|
|
+ with pytest.raises(ValueError):
|
|
|
+ CorticalParcellationStats._parse_whole_brain_measurements_line(line)
|