-
Notifications
You must be signed in to change notification settings - Fork 0
/
matlab_tfce_transform_forbts.m
64 lines (59 loc) · 1.79 KB
/
matlab_tfce_transform_forbts.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
function [tfced] = matlab_tfce_transform_forbts(img,H,E,C,dh, varargin)
%MATLAB_TFCE_TRANSFORM performs threshold free cluster enhancement
% [tfced] = matlab_tfce_transform(img,H,E,C,dh) performs threshold
% free cluster enhancement on 'img' as per Smith & Nichols (2009).
% -- img the 3D image to be transformed
% -- H height exponent, H = 2
% -- E extent exponent, E = 0.5
% -- C connectivity, C = 26
% -- dh size of steps for cluster formation dh = 0.1
% https://github.com/markallenthornton/MatlabTFCE/blob/master/matlab_tfce_transform.m
if nargin > 5 && size(img,3) == 1
gridall = varargin{1};
dims = varargin{2};
img_temp = zeros(size(gridall));
img_temp(gridall == 1) = img;
img_temp = reshape(img_temp, dims);
img = img_temp;
end
for rep = 1:2
if rep == 2 % Do negative values
img = -img;
end
% set cluster thresholds
threshs = 0:dh:max(img(:));
threshs = threshs(2:end);
ndh = length(threshs);
% find positive voxels (greater than first threshold)
nvox = length(img(:));
% find connected components
vals = zeros(nvox,1);
cc = arrayfun(@(x) bwconncomp(bsxfun(@ge,img,x),C), threshs);
for h = 1:ndh
clustsize = zeros(nvox,1);
ccc = cc(h);
voxpercc = cellfun(@numel,ccc.PixelIdxList);
for c = 1:ccc.NumObjects
clustsize(ccc.PixelIdxList{c}) = voxpercc(c);
end
% calculate transform
curvals = (clustsize.^E).*(threshs(h)^H);
vals = vals + curvals;
end
tfce_temp = NaN(size(img));
tfce_temp(:) = vals.*dh;
if rep == 1
tfced = tfce_temp;
else
tfced = tfced - tfce_temp;
end
end
tfced = tfced(:);
if nargin > 5
tfced = tfced(gridall==1);
end
if nargin == 8
ii = varargin{3};
tfced = tfced(ii);
end
end