forked from netstim/leaddbs
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathea_coregpostopmr.m
90 lines (76 loc) · 4.29 KB
/
ea_coregpostopmr.m
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
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
function done = ea_coregpostopmr(options)
% Entry function to coregister post-op MRI to pre-op MRI
done = 0;
% Set fixed anchor image
anchor = options.subj.preopAnat.(options.subj.AnchorModality).coreg;
% Post-op MR modalities
postopModality = fieldnames(options.subj.postopAnat);
% Set moving and output image
moving = cellfun(@(x) options.subj.preproc.anat.postop.(x), postopModality, 'Uni', 0);
output = cellfun(@(x) options.subj.coreg.anat.postop.(x), postopModality, 'Uni', 0);
% Check moving image existence
moving_exists = cellfun(@(x) isfile(x), moving);
% Check registration lock/approval status
output_approved = cellfun(@(x) logical(ea_reglocked(options, x)), output);
% Remove non-existing moving image and approved output image
moving(~moving_exists | output_approved) = [];
output(~moving_exists | output_approved) = [];
% Return if no image remains
if isempty(moving)
return;
end
% Setup log
if options.prefs.diary
ea_mkdir(fileparts(options.subj.coreg.log.logBaseName));
diary([options.subj.coreg.log.logBaseName, 'MR', datestr(now, 'yyyymmddTHHMMss'), '.log']);
end
if strcmp(options.coregmr.method, 'ANTs Nonlinear Coregistration')
warning('off', 'backtrace');
warndlg(sprintf('ANTs nonlinear coregistration only supports pre-op to pre-op!\nFalling back to ANTs linear coregistration for post-op to pre-op now.'))
warning('on', 'backtrace');
options.coregmr.method = 'ANTs';
end
% Do coregistration
ea_mkdir(fullfile(options.subj.coregDir, 'transformations'));
for i=1:length(moving)
ea_dumpmethod(options, 'coreg', ea_getmodality(moving{i}));
affinefile = ea_coregimages(options, moving{i}, anchor, output{i}, [], 1);
%% save Transforms
modality = ea_getmodality(moving{i});
switch lower(options.coregmr.method)
case lower({'ANTs (Avants 2008)', 'ANTs'})
movefile(affinefile{1},[options.subj.coreg.transform.(modality).forwardBaseName, 'ants.mat']);
movefile(affinefile{2},[options.subj.coreg.transform.(modality).inverseBaseName, 'ants.mat']);
% convert ANTS matrices to 4x4
load([options.subj.coreg.transform.(modality).forwardBaseName, 'ants.mat'])
tmat = ea_antsmat2mat(AffineTransform_float_3_3,fixed);
save([options.subj.coreg.transform.(modality).inverseBaseName, 'ants44.mat'],'tmat')
load([options.subj.coreg.transform.(modality).forwardBaseName, 'ants.mat'])
tmat = ea_antsmat2mat(AffineTransform_float_3_3,fixed);
save([options.subj.coreg.transform.(modality).inverseBaseName, 'ants44.mat'],'tmat')
case lower({'FLIRT (Jenkinson 2001 & 2002)', 'FLIRT'})
movefile(affinefile{1},[options.subj.coreg.transform.(modality).forwardBaseName, 'flirt.mat']);
movefile(affinefile{2},[options.subj.coreg.transform.(modality).inverseBaseName, 'flirt.mat']);
% convert affinefile from txt to tmat
tmat = readmatrix([options.subj.coreg.transform.(modality).forwardBaseName, 'flirt.mat'],'FileType','text');
save([options.subj.coreg.transform.(modality).forwardBaseName, 'flirt44.mat'],'tmat');
tmat = readmatrix([options.subj.coreg.transform.(modality).inverseBaseName, 'flirt.mat'],'FileType','text');
save([options.subj.coreg.transform.(modality).inverseBaseName, 'flirt44.mat'],'tmat');
case lower({'SPM (Friston 2007)', 'SPM'})
movefile(affinefile{1},[options.subj.coreg.transform.(modality).forwardBaseName, 'spm.mat']);
movefile(affinefile{2},[options.subj.coreg.transform.(modality).inverseBaseName, 'spm.mat']);
% also store tmat separatly analogous to the the other methods
load([options.subj.coreg.transform.(modality).forwardBaseName, 'spm.mat'],'tmat')
save([options.subj.coreg.transform.(modality).forwardBaseName, 'spm44.mat'],'tmat')
load([options.subj.coreg.transform.(modality).inverseBaseName, 'spm.mat'],'tmat')
save([options.subj.coreg.transform.(modality).inverseBaseName, 'spm44.mat'],'tmat')
end
end
if options.prefs.diary
diary off;
end
if options.overwriteapproved && isfolder(options.subj.brainshiftDir)
ea_delete(options.subj.brainshiftDir);
ea_cprintf('CmdWinWarnings', 'Postop MR coregistration has been rerun. Please also rerun brain shift correction!\n');
end
done = 1;