123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195 |
- % Batch file of CAT12 segmentation for SPM12 standalone installation
- % modified parameters for ENIGMA
- %
- %_______________________________________________________________________
- % $Id: cat_standalone_segment_enigma.m 1842 2021-06-01 14:41:58Z gaser $
- % first undefined data field, that will be dynamically replaced by cat_standalone.sh
- matlabbatch{1}.spm.tools.cat.estwrite.data = '<UNDEFINED>';
- % Entry for choosing TPM
- % Remove comments and edit entry if you would like to change the parameter.
- % Otherwise the default value from cat_defaults.m is used.
- % Or use 1st parameter field, that will be dynamically replaced by cat_standalone.sh
- %matlabbatch{1}.spm.tools.cat.estwrite.opts.tpm = '<UNDEFINED>';
- % Entry for choosing shooting template
- % Remove comments and edit entry if you would like to change the parameter.
- % Otherwise the default value from cat_defaults.m is used.
- % Or use 2nd parameter field, that will be dynamically replaced by cat_standalone.sh
- %matlabbatch{1}.spm.tools.cat.estwrite.extopts.registration.regmethod.shooting.shootingtpm = '<UNDEFINED>';
- % Strength of Shooting registration: 0 - Dartel, eps (fast), 0.5 (default) to 1 (accurate) optimized Shooting, 4 - default Shooting; default 0.5
- %matlabbatch{1}.spm.tools.cat.estwrite.extopts.registration.regmethod.shooting.regstr = 0.5;
- % voxel size for normalized data (EXPERIMENTAL: inf - use Tempate values)
- matlabbatch{1}.spm.tools.cat.estwrite.extopts.registration.vox = 1.5;
- % additional bounding box
- matlabbatch{1}.spm.tools.cat.estwrite.extopts.registration.bb = 12;
- % Affine regularisation (SPM12 default = mni) - '';'mni';'eastern';'subj';'none';'rigid'
- matlabbatch{1}.spm.tools.cat.estwrite.opts.affreg = 'mni';
- % Strength of the bias correction that controls the biasreg and biasfwhm parameter (CAT only!)
- % 0 - use SPM parameter; eps - ultralight, 0.25 - light, 0.5 - medium, 0.75 - strong, and 1 - heavy corrections
- % job.opts.biasreg = min( 10 , max( 0 , 10^-(job.opts.biasstr*2 + 2) ));
- % job.opts.biasfwhm = min( inf , max( 30 , 30 + 60*job.opts.biasstr ));
- matlabbatch{1}.spm.tools.cat.estwrite.opts.biasstr = 0.5;
- % Affine PreProcessing (APP) with rough bias correction and brain extraction for special anatomies (nonhuman/neonates)
- % 0 - none; 1070 - default; [1 - light; 2 - full; 1144 - update of 1070, 5 - animal (no affreg)]
- matlabbatch{1}.spm.tools.cat.estwrite.extopts.segmentation.APP = 1070;
- % Strength of the local adaptation: 0 to 1; default 0.5
- matlabbatch{1}.spm.tools.cat.estwrite.extopts.segmentation.LASstr = 0.5;
- % Strength of the noise correction: 0 to 1; 0 - no filter, -Inf - auto, 1 - full, 2 - ISARNLM (else SANLM), default -Inf
- matlabbatch{1}.spm.tools.cat.estwrite.extopts.segmentation.NCstr = -Inf;
- % Strength of skull-stripping: 0 - SPM approach; eps to 1 - gcut; 2 - new APRG approach; -1 - no skull-stripping (already skull-stripped); default = 2
- matlabbatch{1}.spm.tools.cat.estwrite.extopts.segmentation.gcutstr = 2;
- % Strength of the cleanup process: 0 to 1; default 0.5
- matlabbatch{1}.spm.tools.cat.estwrite.extopts.segmentation.cleanupstr = 0.5;
- % resolution handling: 'native','fixed','best', 'optimal'
- matlabbatch{1}.spm.tools.cat.estwrite.extopts.segmentation.restypes.optimal = [1 0.3];
- % use center-of-mass approach for estimating origin
- matlabbatch{1}.spm.tools.cat.estwrite.extopts.segmentation.setCOM = 1;
- % modify affine scaling
- matlabbatch{1}.spm.tools.cat.estwrite.extopts.segmentation.affmod = 0;
- % use k-means AMAP approach or SPM segmentation for initial segmentation
- matlabbatch{1}.spm.tools.cat.estwrite.extopts.segmentation.spm_kamap = 0;
- % Correction of WM hyperintensities: 0 - no correction, 1 - only for Dartel/Shooting
- % 2 - also correct segmentation (to WM), 3 - handle as separate class; default 1
- matlabbatch{1}.spm.tools.cat.estwrite.extopts.segmentation.WMHC = 2;
- % Stroke lesion correction (SLC): 0 - no correction, 1 - handling of manual lesion that have to be set to zero!
- % 2 - automatic lesion detection (in development)
- matlabbatch{1}.spm.tools.cat.estwrite.extopts.segmentation.SLC = 0;
- % surface options
- matlabbatch{1}.spm.tools.cat.estwrite.extopts.surface.pbtres = 0.5;
- matlabbatch{1}.spm.tools.cat.estwrite.extopts.surface.pbtmethod = 'pbt2x';
- matlabbatch{1}.spm.tools.cat.estwrite.extopts.surface.reduce_mesh = 1;
- matlabbatch{1}.spm.tools.cat.estwrite.extopts.surface.scale_cortex = 0.7;
- matlabbatch{1}.spm.tools.cat.estwrite.extopts.surface.add_parahipp = 0.1;
- matlabbatch{1}.spm.tools.cat.estwrite.extopts.surface.close_parahipp = 0;
- matlabbatch{1}.spm.tools.cat.estwrite.extopts.surface.SRP = 22;
- % set this to 1 for skipping preprocessing if already processed data exist
- matlabbatch{1}.spm.tools.cat.estwrite.extopts.admin.lazy = 0;
- % catch errors: 0 - stop with error (default); 1 - catch preprocessing errors (requires MATLAB 2008 or higher);
- matlabbatch{1}.spm.tools.cat.estwrite.extopts.admin.ignoreErrors = 1;
- % verbose output: 1 - default; 2 - details; 3 - write debugging files
- matlabbatch{1}.spm.tools.cat.estwrite.extopts.admin.verb = 2;
- % display and print out pdf-file of results: 0 - off, 2 - volume only, 2 - volume and surface (default)
- matlabbatch{1}.spm.tools.cat.estwrite.extopts.admin.print = 2;
- % surface and thickness creation: 0 - no (default), 1 - lh+rh, 2 - lh+rh+cerebellum,
- % 3 - lh, 4 - rh, 5 - lh+rh (fast, no registration, only for quick quality check and not for analysis),
- % 6 - lh+rh+cerebellum (fast, no registration, only for quick quality check and not for analysis)
- % 9 - thickness only (for ROI analysis, experimental!)
- % +10 to estimate WM and CSF width/depth/thickness (experimental!)
- matlabbatch{1}.spm.tools.cat.estwrite.output.surface = 0;
- % BIDS output
- matlabbatch{1}.spm.tools.cat.estwrite.output.BIDS.BIDSno = 1;
- % define here volume atlases
- matlabbatch{1}.spm.tools.cat.estwrite.output.ROImenu.atlases.neuromorphometrics = 0;
- matlabbatch{1}.spm.tools.cat.estwrite.output.ROImenu.atlases.lpba40 = 0;
- matlabbatch{1}.spm.tools.cat.estwrite.output.ROImenu.atlases.cobra = 0;
- matlabbatch{1}.spm.tools.cat.estwrite.output.ROImenu.atlases.hammers = 0;
- matlabbatch{1}.spm.tools.cat.estwrite.output.ROImenu.atlases.ibsr = 0;
- matlabbatch{1}.spm.tools.cat.estwrite.output.ROImenu.atlases.aal3 = 0;
- matlabbatch{1}.spm.tools.cat.estwrite.output.ROImenu.atlases.mori = 0;
- matlabbatch{1}.spm.tools.cat.estwrite.output.ROImenu.atlases.thalamus = 0;
- matlabbatch{1}.spm.tools.cat.estwrite.output.ROImenu.atlases.anatomy3 = 0;
- matlabbatch{1}.spm.tools.cat.estwrite.output.ROImenu.atlases.julichbrain = 0;
- matlabbatch{1}.spm.tools.cat.estwrite.output.ROImenu.atlases.Schaefer2018_100Parcels_17Networks_order = 0;
- matlabbatch{1}.spm.tools.cat.estwrite.output.ROImenu.atlases.Schaefer2018_200Parcels_17Networks_order = 0;
- matlabbatch{1}.spm.tools.cat.estwrite.output.ROImenu.atlases.Schaefer2018_400Parcels_17Networks_order = 0;
- matlabbatch{1}.spm.tools.cat.estwrite.output.ROImenu.atlases.Schaefer2018_600Parcels_17Networks_order = 0;
- matlabbatch{1}.spm.tools.cat.estwrite.output.ROImenu.atlases.ownatlas = {''};
- % Writing options (see cat_defaults for the description of parameters)
- % native 0/1 (none/yes)
- % warped 0/1 (none/yes)
- % mod 0/1/2/3 (none/affine+nonlinear/nonlinear only/both)
- % dartel 0/1/2/3 (none/rigid/affine/both)
- % GM/WM/CSF/WMH
- matlabbatch{1}.spm.tools.cat.estwrite.output.GM.native = 1;
- matlabbatch{1}.spm.tools.cat.estwrite.output.GM.warped = 1;
- matlabbatch{1}.spm.tools.cat.estwrite.output.GM.mod = 1;
- matlabbatch{1}.spm.tools.cat.estwrite.output.GM.dartel = 2;
- matlabbatch{1}.spm.tools.cat.estwrite.output.WM.native = 1;
- matlabbatch{1}.spm.tools.cat.estwrite.output.WM.warped = 0;
- matlabbatch{1}.spm.tools.cat.estwrite.output.WM.mod = 0;
- matlabbatch{1}.spm.tools.cat.estwrite.output.WM.dartel = 2;
- matlabbatch{1}.spm.tools.cat.estwrite.output.CSF.native = 0;
- matlabbatch{1}.spm.tools.cat.estwrite.output.CSF.warped = 0;
- matlabbatch{1}.spm.tools.cat.estwrite.output.CSF.mod = 0;
- matlabbatch{1}.spm.tools.cat.estwrite.output.CSF.dartel = 0;
- matlabbatch{1}.spm.tools.cat.estwrite.output.WMH.native = 0;
- matlabbatch{1}.spm.tools.cat.estwrite.output.WMH.warped = 0;
- matlabbatch{1}.spm.tools.cat.estwrite.output.WMH.mod = 0;
- matlabbatch{1}.spm.tools.cat.estwrite.output.WMH.dartel = 0;
- % stroke lesion tissue maps (only for opt.extopts.SLC>0) - in development
- matlabbatch{1}.spm.tools.cat.estwrite.output.SL.native = 0;
- matlabbatch{1}.spm.tools.cat.estwrite.output.SL.warped = 0;
- matlabbatch{1}.spm.tools.cat.estwrite.output.SL.mod = 0;
- matlabbatch{1}.spm.tools.cat.estwrite.output.SL.dartel = 0;
- % Tissue classes 4-6 to create own TPMs
- matlabbatch{1}.spm.tools.cat.estwrite.output.TPMC.native = 0;
- matlabbatch{1}.spm.tools.cat.estwrite.output.TPMC.warped = 0;
- matlabbatch{1}.spm.tools.cat.estwrite.output.TPMC.mod = 0;
- matlabbatch{1}.spm.tools.cat.estwrite.output.TPMC.dartel = 0;
- % atlas maps (for evaluation)
- matlabbatch{1}.spm.tools.cat.estwrite.output.atlas.native = 0;
- % label
- % background=0, CSF=1, GM=2, WM=3, WMH=4 (if opt.extopts.WMHC==3), SL=1.5 (if opt.extopts.SLC>0)
- matlabbatch{1}.spm.tools.cat.estwrite.output.label.native = 1;
- matlabbatch{1}.spm.tools.cat.estwrite.output.label.warped = 0;
- matlabbatch{1}.spm.tools.cat.estwrite.output.label.dartel = 0;
- % bias and noise corrected, global intensity normalized
- matlabbatch{1}.spm.tools.cat.estwrite.output.bias.native = 0;
- matlabbatch{1}.spm.tools.cat.estwrite.output.bias.warped = 0;
- matlabbatch{1}.spm.tools.cat.estwrite.output.bias.dartel = 0;
- % bias and noise corrected, (locally - if LAS>0) intensity normalized
- matlabbatch{1}.spm.tools.cat.estwrite.output.las.native = 0;
- matlabbatch{1}.spm.tools.cat.estwrite.output.las.warped = 0;
- matlabbatch{1}.spm.tools.cat.estwrite.output.las.dartel = 0;
- % jacobian determinant 0/1 (none/yes)
- matlabbatch{1}.spm.tools.cat.estwrite.output.jacobianwarped = 0;
- % deformations, order is [forward inverse]
- matlabbatch{1}.spm.tools.cat.estwrite.output.warps = [0 0];
- % registration matrix
- matlabbatch{1}.spm.tools.cat.estwrite.output.rmat = 1;
- % deface native intensity normalized images in native space
- matlabbatch{2}.spm.util.deface.images(1) = cfg_dep('CAT12: Segmentation: Native Bias Corr. Image', substruct('.','val', '{}',{1}, '.','val', '{}',{1}, '.','val', '{}',{1}, '.','val', '{}',{1}), substruct('()',{1}, '.','biascorr', '()',{':'}));
- matlabbatch{2}.spm.util.deface.images(2) = cfg_dep('CAT12: Segmentation: Native LAS Bias Corr. Image', substruct('.','val', '{}',{1}, '.','val', '{}',{1}, '.','val', '{}',{1}, '.','val', '{}',{1}), substruct('()',{1}, '.','ibiascorr', '()',{':'}));
- % and remove images that are not defaced
- matlabbatch{3}.cfg_basicio.file_dir.file_ops.file_move.files(1) = cfg_dep('CAT12: Segmentation: Native Bias Corr. Image', substruct('.','val', '{}',{1}, '.','val', '{}',{1}, '.','val', '{}',{1}, '.','val', '{}',{1}), substruct('()',{1}, '.','biascorr', '()',{':'}));
- matlabbatch{3}.cfg_basicio.file_dir.file_ops.file_move.files(2) = cfg_dep('CAT12: Segmentation: Native LAS Bias Corr. Image', substruct('.','val', '{}',{1}, '.','val', '{}',{1}, '.','val', '{}',{1}, '.','val', '{}',{1}), substruct('()',{1}, '.','ibiascorr', '()',{':'}));
- matlabbatch{3}.cfg_basicio.file_dir.file_ops.file_move.action.delete = false;
|