-
Notifications
You must be signed in to change notification settings - Fork 99
/
ea_coregimages.m
105 lines (95 loc) · 3.97 KB
/
ea_coregimages.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
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
function affinefile = ea_coregimages(options,moving,fixed,ofile,otherfiles,writeoutmat,masks,interp)
% Generic function for image coregistration
%
% 1. Moving image will keep untouched unless the output points to the same
% image.
% 2. 'otherfiles' will always be overwritten. If you don't want them to be
% overwritten, use 'ea_apply_coregistration' afterwards to apply the
% returned forward transform ('affinefile{1}') to 'otherfiles' rather
% than supply 'otherfiles' parameter here.
if ~exist('otherfiles','var')
otherfiles = {};
elseif isempty(otherfiles) % [] or {} or ''
otherfiles = {};
elseif ischar(otherfiles) % single file, make it to cell string
otherfiles = {otherfiles};
end
if ~exist('writeoutmat','var') || isempty(writeoutmat)
writeoutmat = 0;
end
affinefile = {};
if ~exist('masks','var') || isempty(masks)
masks={};
end
% Only effective for SPM, 4th degree BSpline by default.
% ANTs and BRAINSFit use Linear interpolation, FSL use Sinc interpolation.
if ~exist('interp','var') || isempty(interp)
interp = 4;
end
switch lower(options.coregmr.method)
case lower({'ANTs (Avants 2008)', 'ANTs'})
affinefile = ea_ants_linear(fixed,...
moving,...
ofile,writeoutmat,otherfiles,masks);
case lower({'BRAINSFit (Johnson 2007)', 'BRAINSFit'})
affinefile = ea_brainsfit(fixed,...
moving,...
ofile,writeoutmat,otherfiles);
case lower({'FLIRT (Jenkinson 2001 & 2002)', 'FLIRT'})
affinefile = ea_flirt(fixed,...
moving,...
ofile,writeoutmat,otherfiles);
case lower({'FLIRT BBR (Greve and Fischl 2009)', 'FLIRT BBR', 'FLIRTBBR'})
affinefile = ea_flirtbbr(fixed,...
moving,...
ofile,writeoutmat,otherfiles);
case lower({'Hybrid SPM & ANTs', 'HybridSPMANTs'})
% Copy moving image to out image first, since SPM will change
% the header of the moving image.
copyfile(moving, ofile);
ea_spm_coreg(options,ofile,fixed,'nmi',0,otherfiles,writeoutmat)
affinefile = ea_ants_linear(fixed,...
ofile,...
ofile,writeoutmat,otherfiles);
case lower({'Hybrid SPM & BRAINSFIT', 'HybridSPMBRAINSFIT'})
% Copy moving image to out image first, since SPM will change
% the header of the moving image.
copyfile(moving, ofile);
ea_spm_coreg(options,ofile,fixed,'nmi',0,otherfiles,writeoutmat)
affinefile = ea_brainsfit(fixed,...
ofile,...
ofile,writeoutmat,otherfiles);
case lower({'Hybrid SPM & FLIRT', 'HybridSPMFLIRT'})
% Copy moving image to out image first, since SPM will change
% the header of the moving image.
copyfile(moving, ofile);
ea_spm_coreg(options,ofile,fixed,'nmi',0,otherfiles,writeoutmat)
affinefile = ea_flirt(fixed,...
ofile,...
ofile,writeoutmat,otherfiles);
case lower({'SPM (Friston 2007)', 'SPM'})
affinefile = ea_spm_coreg(options,moving,fixed,'nmi',1,otherfiles,writeoutmat,interp);
[fpth, fname, ext] = ea_niifileparts(moving);
spmoutput = [fileparts(fpth), filesep, 'r', fname, ext];
if ~strcmp(spmoutput, ofile)
movefile(spmoutput, ofile);
end
for ofi=1:length(otherfiles)
[fpth, fname, ext] = ea_niifileparts(otherfiles{ofi});
spmoutput = [fileparts(fpth), filesep, 'r', fname, ext];
movefile(spmoutput, [fpth, ext]);
end
case lower({'ANTs Nonlinear Coregistration', 'ANTsNonLinear'})
transforms = ea_ants_nonlinear_coreg(fixed, moving, ofile, ...
options.prefs.machine.normsettings, 'NULL', 'NULL', 'ea_antspreset_ants_wiki');
ea_delete(transforms);
otherwise
warning('Coregistrion method not recognized...');
return;
end
% Reslice images if needed (fix qform/sform issues)
V1 = ea_open_vol(fixed);
V2 = ea_open_vol(ofile);
if ~isequal(V1.mat, V2.mat)
ea_conformspaceto(fixed, ofile, 1);
end