-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbramila_framewiseDisplacement.m
73 lines (64 loc) · 2.6 KB
/
bramila_framewiseDisplacement.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
function [fwd,rms]=bramila_framewiseDisplacement(cfg)
% BRAMILA_FRAMEWISEDISPLACEMENT - Computes the framewise displacement
% metric as described in
% Power et al. (2012) doi:10.1016/j.neuroimage.2011.10.018 and also
% Power et al. (2014) doi:10.1016/j.neuroimage.2013.08.048
% - Usage:
% fwd = bramila_framewiseDisplacement(cfg)
% - Input:
% cfg is a struct with following parameters
% cfg.motionparam = the 6 time series of motion parameters (time in 1st dimension)
% cfg.prepro_suite = 'fsl-fs', 'spm' (default fsl-fs, fs = freesurfer)
% cfg.radius = radius of sphere in mm to convert degrees to motion,
% default = 50 as in Power et al 2014
% - Output:
% fwd = framewise displacement timeseries
% - Notes:
% Need to check that spm is indeed different, see end of Yan 2013 10.1016/j.neuroimage.2013.03.004
%
% Last edit: EG 2010-01-10
fprintf('Computing framewise displacement...');
temp_cfg=[];
ts = load(cfg.motionparam);
temp_cfg.vol=double(ts);
temp_cfg.write=0;
temp_cfg.detrend_type='linear-demean';
ts=bramila_detrend(temp_cfg); % demean and detrend as specified in Power et al 2014
if(size(ts,2)~=6)
error(['The motion time series must have 6 motion parameters in 6 columns; the size of the input given is ' num2str(size(ts))])
end
prepro_suite='fsl-fs'; % 1 is FSL, 2 is SPM
if(isfield(cfg,'prepro_suite'))
prepro_suite = cfg.prepro_suite;
end
radius=50; % default radius
if(isfield(cfg,'radius'))
radius = cfg.radius;
end
if(strcmp(prepro_suite,'fsl-fs'))
% convert radians into motion in mm
% in FSL the first 3 columns are rotations, in spm its viceversa
temp=ts(:,1:3);
temp=radius*temp;
ts(:,1:3)=temp;
elseif (strcmp(prepro_suite, 'meica')) %For MEICA output
% convert degrees into motion in mm;
temp=ts(:,1:3); %Rotations in degrees, columns 1:3 in motion.1D file. From 3dvolreg
temp=(2*radius*pi/360)*temp;
%temp=radius*temp;
ts(:,1:3)=temp;
else % (strcmp(prepro_suite,'spm')) % SPM way %Altered to compare to spm, 1/22/17 LTD
% convert degrees into motion in mm;
temp=ts(:,4:6);
%temp=(2*radius*pi/360)*temp; % UPDATE: it seems they are in radians afterall
temp=radius*temp;
ts(:,4:6)=temp;
end
dts=diff(ts);
dts=[
zeros(1,size(dts,2));
dts
]; % first element is a zero, as per Power et al 2014
fwd=sum(abs(dts),2);
rms=sqrt(mean(ts.^2,1)); % root mean square for each column
fprintf(' done\n');