forked from netstim/leaddbs
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathea_coregpostopct_ants.m
29 lines (24 loc) · 1.28 KB
/
ea_coregpostopct_ants.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
function varargout=ea_coregpostopct_ants(options)
% Wrapper function for ANTs registration of post-op CT
% __________________________________________________________________________________
% Copyright (C) 2015 Charite University Medicine Berlin, Movement Disorders Unit
% Andreas Horn
if ischar(options) % return name of method.
varargout{1}='ANTs (Avants 2008)';
return
end
disp('Coregistering postop CT to preop MRI...');
transform = ea_ants_linear(options.subj.preopAnat.(options.subj.AnchorModality).coreg,...
options.subj.postopAnat.CT.preproc,...
options.subj.postopAnat.CT.coreg);
ea_mkdir(fullfile(options.subj.coregDir, 'transformations'));
movefile(transform{1}, [options.subj.coreg.transform.CT.forwardBaseName, 'ants.mat']);
movefile(transform{2}, [options.subj.coreg.transform.CT.inverseBaseName, 'ants.mat']);
% convert ANTS matrices to 4x4
load([options.subj.coreg.transform.CT.forwardBaseName, 'ants.mat'])
tmat = ea_antsmat2mat(AffineTransform_float_3_3,fixed);
save([options.subj.coreg.transform.CT.forwardBaseName, 'ants44.mat'],'tmat')
load([options.subj.coreg.transform.CT.inverseBaseName, 'ants.mat'])
tmat = ea_antsmat2mat(AffineTransform_float_3_3,fixed);
save([options.subj.coreg.transform.CT.inverseBaseName, 'ants44.mat'],'tmat')
disp('Coregistration done.');