forked from ChristianGaser/cat12
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcat_batch_bids.sh
executable file
·76 lines (65 loc) · 3.03 KB
/
cat_batch_bids.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
#! /bin/bash
# Wrapper to call either CAT12 standard or longitudinal pipeline from shell for BIDS data
# Parallelization should be either done using standalone/cat_parallize.sh or any
# batch or queue system
# ______________________________________________________________________
#
# Christian Gaser, Robert Dahnke
# Structural Brain Mapping Group (https://neuro-jena.github.io)
# Departments of Neurology and Psychiatry
# Jena University Hospital
# ______________________________________________________________________
# $Id$
#
# all bids-folder have to be structured like this:
# sub-*/ses-*/anat/sub-*T1w.nii*
if [ "$1" = "" ]; then
echo usage: $0 bids_directoriy
exit
fi
subjid=$( basename $1 ) # note that only one subject id should be inputted at the time.
dirname=$(dirname $1 )
cat12_dir=$cwd
matlab=matlab # you can use other matlab versions by changing the matlab parameter
default="cat_defaults_bids.m" # define own defaults file here
model=2 # 0 - detect large changes with brain/head growth (i.e. developmental effects)
# 1 - detect small changes (i.e. due to plasticity)
# 2 - detect large changes (i.e. ageing or development)
# 3 - save results for both models 1 and 2
#no_surf=" --no-surf " # remove comment if you don't want to estimate surface
export_dartel=" --export-dartel " # export affine registered segmentations for Dartel (longitudinal data)
rp=" --rp " # additionally estimate affine registered segmentations (cross-sectional data)
bids_folder_cross="../derivatives/CAT12.8.1" # define BIDS path for cross-sectional data
bids_folder_long="../derivatives/CAT12.8.1_long" # define BIDS path for longitudinal data
fg=" --fg " # keep process in foreground which might be neccessary for batch/queue systems
log_folder="${dirname}/derivatives/logs_CAT12.8.1/${subjid}" # the directory for the log files.
# Must contain the subject id
for i in ${@}/; do
count=0 # count files
list="" # build list of files
# go through all session folders in subjects
for j in ${i}/ses-*/; do
t1=`ls ${j}/anat/sub*T1w.nii.gz 2>/dev/null`
# first check for nii.gz
if [ ! -n "$t1" ]; then
t1=`ls ${j}/anat/sub*T1w.nii 2>/dev/null`
# if not found then check for nii
fi
# update list and count if something is found
if [ -n "$t1" ]; then
list="${list} ${t1}"
count=`expr $count + 1`
fi
done
# nothing found
if [ "${count}" -eq "0" ]; then
echo "Could not found any *.nii* file in ${j}/anat/"
else
# use cross-sectional pipeline for single files
if [ "${count}" -eq "1" ]; then
${cat12_dir}/cat_batch_cat.sh $list -p 1 $fg --matlab $matlab --defaults $default $no_surf $rp --bids_folder $bids_folder_cross --logdir $log_folder
else # otherwise call longitudinal pipeline
${cat12_dir}/cat_batch_long.sh $list $fg --matlab $matlab --defaults $default --model $model $no_surf $export_dartel --bids_folder $bids_folder_long --logdir $log_folder
fi
fi
done