forked from rordenlab/spmScripts
-
Notifications
You must be signed in to change notification settings - Fork 0
/
nii_mask.m
executable file
·48 lines (45 loc) · 1.79 KB
/
nii_mask.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
function nii_mask(imgNames, maskName, thresh, val)
%Masks images imgName with image maskName: values less that thresh in mask are set to val in imgNames
%if a voxel in the mask is less than thresh corresponding voxel in input is set to val
% imgNames : Filenames of image(s) to mask
% maskName : Mask filename
% thresh : Change voxels darker than this in the template image
% val : Value to set dark voxels to
%Output:
% masked images with 'm' prefix
%Example
% nii_mask('T1.nii','lesion.nii',0.5, 0.0); %voxels darker than 0.5 in mask set to 0.0 in images
if nargin<1, imgNames = spm_select(Inf,'image','Select images for masking'); end
if nargin<2, maskName = spm_select(1,'image','Select mask'); end
if nargin<3, thresh = 0.025; end
%if nargin<4, val = 0; end
hdrM = spm_vol(maskName);
if numel(hdrM) > 1
error('Error: mask has multiple volumes, please explicitly specify masking volume, e.g. ''~/tpm.nii,1'' ');
end
imgM = spm_read_vols(hdrM);
for j=1:size(imgNames,1)
fnm = deblank(imgNames(j,:));
hdr = spm_vol(fnm);
nvol = numel(hdr);
if hdr(1).dim ~= hdrM.dim
disp('mask and source must have same dimensions!');
break;
end
img4d = spm_read_vols(hdr);
hdr = hdr(1);
[pth,nm,xt, ~] = spm_fileparts(hdr.fname);
hdr.fname = fullfile(pth, ['m' nm xt]);
if nargin<4, val = min(img4d(:)); end
clipped = sum(imgM(:) < thresh);
for vol=1:nvol
hdr.n(1)=vol;
img = img4d(:,:,:,vol);
img(imgM < thresh) = val;
img(isnan(img)) = val; % use ~isfinite instead of isnan to replace +/-inf with zero
spm_write_vol(hdr,img);
spm_write_vol(hdr,img);
end;
fprintf('Image %s had %d voxels per volume set to %f because they were < %f in %s\n',hdr.fname, clipped, val, thresh, hdrM.fname);
end
%end nii_mask()