-
Notifications
You must be signed in to change notification settings - Fork 1
/
getDatabase.m
90 lines (79 loc) · 3.03 KB
/
getDatabase.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 S = getDatabase()
%GETDATABASE assigns all .figs into a 2-D array
% function getDatabase creates a 2-D array by arranging each .fig in the
% database folder. It reshapes each 640-by-480 matrix into a matrix that
% has only 1 column.
% Building Database
% Get path to Database directory
% The pwd command displays the MATLAB® current folder. Therefore, please
% navigate to the root directory of this file before running this script.
raw = [pwd '\raw'];
% Check if directory exists
if ~isdir(raw)
errorMessage = sprintf('Error; The following directory does not exist: \n%s', raw);
uiwait(warndlg(errorMessage));
return;
end
% Select files using a specified pattern
filePattern = fullfile(raw, '*.fig');
% Lists out all required files which follows the pattern
reqFiles = dir(filePattern);
% Define empty matrix S, prevents "Undefined function or variable." error
databaseStateOpen = [];
state = [11:40 41:110 131:170 191:240];
for k = 1 : length(state)
%Index into the structure to access a particular item from reqFiles
baseFileName = reqFiles(state(k)).name;
%fullfile returns a string containing the full path to the file
baseFilePath = fullfile(raw, baseFileName);
fprintf(1, 'Accessing %s\n', baseFilePath);
imTemp1=openfig(baseFilePath,'invisible');
imTemp2=findobj(imTemp1,'type','image');
% Store depth image data into I
I=imTemp2.CData;
%%% SEGMENT OUT THE HAND
%%Normalize
% Replace depth value 0 to 4000. This eliminates IR shadow
I((I<=0)) = 4000;
% Minus all values in array I by the minimum value of itself
I = I - min(min(I));
%%Segmentation
% Readjust values above 90 to 4000.
I((I>90)) = 4000;
Z = cropImage_Open(I);
[irow,icol] = size(Z);
% Reshape a 80-by-50 matrix into a matrix that has only 1 column
Z=reshape(Z,irow*icol,1);
databaseStateOpen = [databaseStateOpen Z];
end
% For ['A' 'E' 'M' 'N' 'O' 'S' 'T']
databaseStateClosed = [];
state3 = [1:10 41:50 111:140 171:190];
for k = 1 : length(state3)
%Index into the structure to access a particular item from reqFiles
baseFileName = reqFiles(state3(k)).name;
%fullfile returns a string containing the full path to the file
baseFilePath = fullfile(raw, baseFileName);
fprintf(1, 'Accessing %s\n', baseFilePath);
imTemp1=openfig(baseFilePath,'invisible');
imTemp2=findobj(imTemp1,'type','image');
% Store depth image data into I
I=imTemp2.CData;
%%% SEGMENT OUT THE HAND
%%Normalize
% Replace depth value 0 to 4000. This eliminates IR shadow
I((I<=0)) = 4000;
% Minus all values in array I by the minimum value of itself
I = I - min(min(I));
%%Segmentation
% Readjust values above 90 to 4000.
I((I>90)) = 4000;
Z = cropImage_Closed(I);
[irow,icol]=size(Z);
% Reshape a 40-by-50 matrix into a matrix that has only 1 column
Z=reshape(Z,irow*icol,1);
databaseStateClosed = [databaseStateClosed Z];
end
S = {databaseStateOpen databaseStateClosed};
database = S;
save('database','database');