-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcr_maskf.m
90 lines (89 loc) · 2.52 KB
/
cr_maskf.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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
function mask = cr_maskf(roic,npx,dist,tol,iplt)
%CR_MASKF Creates an image mask based on the two-dimensional (2-D)
% coordinates of two lines. The region of interest (ROI) is
% defined as the space between the first and second line. The
% second line is assumed to be slightly longer than the first
% line.
%
% For creating masks for knee femur cartilage. The first line
% is usually cartilage and the second longer line is the
% underlying bone.
%
% MASK = CR_MASKF(ROIC,NPX) given the two-dimensional
% coordinates of two lines defining a region of interest in a
% two element cell array (one element for each line), ROIC,
% and the size of the image for the mask in array, NPX,
% creates a logical array mask for the region of interest,
% MASK. Note: If NPX has only one element, the image is
% assumed to be square (symmetrical) (NPX by NPX).
%
% NOTES: 1. M-files mk_tri_2d.m, lsect2a.m, near2.m, and
% mk_tri_2df.m must be in the current directory or
% path.
%
% 2. Similar to cr_mask.m except the slopes of the
% end points are in the opposite directions.
%
% 04-Nov-2022 * Mack Gardner-Morse
%
%#######################################################################
%
% Check for Inputs
%
if (nargin<2)
error(' *** ERROR in CR_MASKF: Two inputs are required!');
end
%
roic = roic(:);
[nr,nc] = size(roic);
if nr~=2&&nc~=1
error([' *** ERROR in CR_MASKF: Input cell array must have'
' two elements!']);
end
%
ndim = size(npx(:),1);
if ndim>2||ndim<1
error(' *** ERROR in CR_MASKF: Incorrect image dimensions!');
end
%
if ndim==1
npx = [npx; npx];
end
%
if nargin<3||isempty(dist)
dist = Inf; % No distance checking
end
%
if nargin<4||isempty(tol)
tol = 0.1;
end
%
if nargin<5
iplt = false;
end
%
% Create Triangle Meshes for the Region of Interest
%
[tri,xy] = mk_tri_2df(roic,dist,tol,iplt);
%
% Find Pixels within the Region of Interest
%
mask = false(npx(1)*npx(2),1);
%
minr = floor(min(xy));
if any(minr(:)==0) % Trap for zeros
minr(minr(:)==0) = 1;
end
maxr = ceil(max(xy));
idx = minr(:,1):maxr(:,1);
idy = minr(:,2):maxr(:,2);
[xg,yg] = meshgrid(idx,idy);
xym = [xg(:) yg(:)];
in_roi = in_tri2d(tri,xy,xym);
%
idr = sub2ind([npx(1) npx(2)],xym(:,2),xym(:,1));
idr = idr(in_roi);
%
mask(idr) = true;
%
return