#!/usr/bin/env bash # Exit at any error set -e # Make sure FreeSurfer is sourced [ ! -e "$FREESURFER_HOME" ] && echo "error: freesurfer has not been properly sourced" && exit 1 # If requesting help if [ $# == 1 ] && [ $1 == "--help" ] then echo " " echo "Bayesian segmentation with histological whole brain atlas." echo " " echo "Next-Generation histological atlas for high-resolution segmentation of human brain MRI" echo "Casamitjana et al. (in preparation)" echo " " echo "Usage:" echo " mri_histo_atlas_segment INPUT_SCAN OUTPUT_DIRECTORY ATLAS_MODE GPU THREADS [BF_MODE] [GMM_MODE]" echo " " echo "INPUT SCAN: scan to process, in mgz or nii(.gz) format" echo "OUTPUT_DIRECTORY: directory with segmentations, volume files, etc" echo "ATLAS_MODE: must be full (all 333 labels) or simplified (simpler brainstem protocol; recommended)" echo "GPU: set to 1 to use the GPU (*highly* recommended but requires a 24GB GPU!)" echo "THREADS: number of CPU threads to use (use -1 for all available threads)" echo "BF_MODE (optional): bias field model: dct (default), polynomial, or hybrid" echo "GMM_MODE (optional): must be 1mm (default) unless you define your own (see documentation)" echo " " exit 0 fi # If number of arguments is incorrect if [ $# -lt 5 ] || [ $# -gt 7 ] then echo " " echo "Incorrect number of arguments." echo "Usage: " echo " " echo " mri_histo_atlas_segment INPUT_SCAN OUTPUT_DIRECTORY ATLAS_MODE GPU THREADS BF_MODE GMM_MODE" echo " " echo "Or, for help" echo " " echo " mri_histo_atlas_segment --help" echo " " exit 1 fi # Parse arguments INPUT=$1 OUTPUT_DIR=$2 ATLAS_MODE=$3 if !( [ "$ATLAS_MODE" == "full" ] || [ "$ATLAS_MODE" == "simplified" ] ) then echo "ATLAS_MODE must be full or simplified" exit 1 fi CPU_FLAG=' ' if [ $4 -eq 0 ] then CPU_FLAG='--cpu' fi THREADS=$5 BF_MODE='dct' if [ $# -gt 5 ] then BF_MODE=$6 fi GMM_MODE='1mm' if [ $# -gt 6 ] then GMM_MODE=$7 fi # Find path to shell script BASEPATH="$FREESURFER_HOME/python/packages/ERC_bayesian_segmentation/" # Try to find atlas data ATLAS_DIR="$BASEPATH/atlas_${ATLAS_MODE}" if [ ! -f "$ATLAS_DIR/size.npy" ]; then echo " " echo " Atlas files not found for mode ${ATLAS_MODE}. Please download atlas from: " echo " https://ftp.nmr.mgh.harvard.edu/pub/dist/lcnpublic/dist/Histo_Atlas_Iglesias_2023/atlas_${ATLAS_MODE}.zip " echo " and uncompress it into: " echo " $BASEPATH/ " echo " You only need to do this once for mode ${ATLAS_MODE}. You can use the following three commands (may require root access): " echo " 1: cd $BASEPATH" echo " 2a (in Linux): wget https://ftp.nmr.mgh.harvard.edu/pub/dist/lcnpublic/dist/Histo_Atlas_Iglesias_2023/atlas_${ATLAS_MODE}.zip " echo " 2b (in MAC): curl -o atlas.zip https://ftp.nmr.mgh.harvard.edu/pub/dist/lcnpublic/dist/Histo_Atlas_Iglesias_2023/atlas_${ATLAS_MODE}.zip " echo " 3. unzip atlas_${ATLAS_MODE}.zip" echo " " echo " After correct extraction, the directory: " echo " $ATLAS_DIR " echo " should contain files: size.npy, label_001.npz, label_002.npz, ..." echo " " exit 1 fi # Create command line arguments and run! SYNTHSEG="$OUTPUT_DIR/SynthSeg.mgz" SYNTHSEGCSV="$OUTPUT_DIR/SynthSeg.vols.csv" FIELD="$OUTPUT_DIR/MNI_registration.mgz" OUTPUT_SEG="$OUTPUT_DIR/seg_left.mgz" OUTPUT_VOL="$OUTPUT_DIR/vols_left.csv" BFCORR="$OUTPUT_DIR/bf_corrected.mgz" # Create output directory if it isn't there echo " " if [ -d $OUTPUT_DIR ]; then echo "Output directory already exists, no need to create it" else mkdir $OUTPUT_DIR fi echo " " echo "******************************" echo "* Working on left hemisphere *" echo "******************************" echo " " cmd="fspython $BASEPATH/scripts/segment.py --i $INPUT --atlas_mode $ATLAS_MODE --gmm_mode $GMM_MODE --bf_mode $BF_MODE --i_seg $SYNTHSEG --o_synthseg_vols $SYNTHSEGCSV --i_field $FIELD --atlas_dir $ATLAS_DIR --hemi l --o_bf_corr $BFCORR --o $OUTPUT_SEG --o_vol $OUTPUT_VOL --threads $THREADS $CPU_FLAG " echo "Running command:" echo $cmd echo " " $cmd OUTPUT_SEG="$OUTPUT_DIR/seg_right.mgz" OUTPUT_VOL="$OUTPUT_DIR/vols_right.csv" echo " " echo "*******************************" echo "* Working on right hemisphere *" echo "*******************************" echo " " cmd="fspython $BASEPATH/scripts/segment.py --i $INPUT --atlas_mode $ATLAS_MODE --gmm_mode $GMM_MODE --bf_mode $BF_MODE --i_seg $SYNTHSEG --o_synthseg_vols $SYNTHSEGCSV --i_field $FIELD --atlas_dir $ATLAS_DIR --hemi r --o $OUTPUT_SEG --o_vol $OUTPUT_VOL --threads $THREADS $CPU_FLAG " echo "Running command:" echo $cmd echo " " $cmd # Copy lookup table, for convenience cp $BASEPATH/data_${ATLAS_MODE}/AllenAtlasLUT $OUTPUT_DIR/lookup_table.txt touch $OUTPUT_DIR/done echo " " echo "*****************" echo "* All done!!!!! *" echo "*****************" echo " "