-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathloadhogvjeyesdata.m
58 lines (50 loc) · 1.24 KB
/
loadhogvjeyesdata.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
function loadajayhogdata()
y = load('Labels/emotion_labels.txt');
e = load('cropped_eyes.mat');
m = load('cropped_mouth.mat');
c = textscan(fopen('Labels/associated_pic_filenames.txt'),'%s');
N = length(c{1});
index = zeros(N,1);
x = zeros(N,81*2);
for i = 1:N
try
fprintf('image id: %d\n',i);
detector = buildDetector();
I = imread(strcat(['../.' char(c{1}(i))]));
bbox = detectFaceParts(detector,I);
Im = m.cropped_mouth{i};
if size(Im,1) == 0
Im = convertg(imcrop(I,bbox(end,13:16)));
end
Ie = e.cropped_eyes{i};
dm = extracthog(Im)
de = extracthog(Ie)
x(i,1:81) = dm;x(i,82:end) = de;
index(i) = 1;
catch er
disp(er)
end
end
partition(x(logical(index),:),y(logical(index)));
end
function I = convertg(I)
if size(I,3) ~= 1
I = rgb2gray(I);
end
end
function partition(x,y)
n = max(unique(y));
train_index = floor(length(y) * .7);
train_x = x(1:train_index,:);
test_x = x(train_index + 1:end,:);
train_y = zeros(size(train_x,1),n);
test_y = zeros(size(test_x,1),n);
for i = 1:length(y)
if i <= train_index
train_y(i,y(i)) = 1;
else
test_y(i - train_index,y(i)) = 1;
end
end
save('imagedata_a2hog.mat','train_x','train_y','test_x','test_y');
end