forked from rordenlab/spmScripts
-
Notifications
You must be signed in to change notification settings - Fork 0
/
nii_jaccard.m
executable file
·68 lines (59 loc) · 1.89 KB
/
nii_jaccard.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
function j = nii_jaccard(im1, im2, binarize, im1inten, im2inten);
%computes Jaccard Similarity Index
%http://en.wikipedia.org/wiki/Jaccard_index
% input
% im1: image
% im2: image
% binarize [optional]: if true Tanimoto's Similarity is computed
% output
% j: Jaccard Index (intersection vs union)
%j =nii_jaccard('c1head_1.nii','mask_gray.nii')
if nargin <1 %no im1
im1 = spm_select(1,'image','Select 1st image');
end;
if nargin <2 %no im2
im2 = spm_select(1,'image','Select 2nd image');
end;
if nargin <3 %no binarize
binarize = false;
end;
if ischar(im1), im1 = spm_vol(im1); end;
if ischar(im2), im2 = spm_vol(im2); end;
i1 = spm_read_vols(im1);
i2 = spm_read_vols(im2);
if nargin > 3 %filter im1
i1 = i1 == im1inten;
i1 = uint8(i1);
fprintf('A total of %d voxels in %s have an intensity of %f\n',sum(i1(:)), im1.fname, im1inten);
end;
if nargin > 4 %filter im2
i2 = i2 == im2inten;
i2 = uint8(i2);
fprintf('A total of %d voxels in %s have an intensity of %f\n',sum(i2(:)), im2.fname, im2inten);
end;
if binarize %scale intensity to 0..1, values less than 0.5 set to zero, others set to 1
mx=max(i1(:));
mn=min(i1(:));
i1 = (i1-mn)/mx;
i1 = uint8(round(i1));
mx=max(i2(:));
mn=min(i2(:));
i2 = (i2-mn)/mx;
i2 = uint8(round(i2));
end;
%we can compute intersection/union using vectors...
inter = sum(sum(sum(min(i1,i2)) ) ); %instersection: result only 1 when i1=1 and i2=1
union = sum(sum(sum(max(i1,i2)) ) ); %instersection: result only 1 when i1=1 and i2=1
%or we could compute the same values with for loops...
% inter = 0;
% union = 0;
% for i=1:size(i1,3),
% p1 = double(i1(:,:,i));
% p2 = double(i2(:,:,i));
% a= max(p1,p2);
% union = union + sum(a(:));
% a= min(p1,p2);
% inter = inter + sum(a(:));
% end;
j = inter/union;
fprintf('Jaccard of %s and %s is %f\n',im1.fname, im2.fname, j);