-
-
Notifications
You must be signed in to change notification settings - Fork 89
/
Copy pathresnet52_market_pseudo.m
executable file
·30 lines (27 loc) · 1.19 KB
/
resnet52_market_pseudo.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
function net = resnet52_market()
netStruct = load('./data/imagenet-resnet-50-dag.mat') ;
net = dagnn.DagNN.loadobj(netStruct) ;
net.removeLayer('fc1000');
net.removeLayer('prob');
for i = 1:numel(net.params)
if(mod(i,2)==0)
net.params(i).learningRate=0.02;
else net.params(i).learningRate=0.001;
end
net.params(i).weightDecay=1;
end
dropoutBlock = dagnn.DropOut('rate',0.75);
net.addLayer('dropout',dropoutBlock,{'pool5'},{'pool5d'},{});
fc751Block = dagnn.Conv('size',[1 1 2048 751],'hasBias',true,'stride',[1,1],'pad',[0,0,0,0]);
net.addLayer('fc751',fc751Block,{'pool5d'},{'prediction'},{'fc751f','fc751b'});
% Here we use pseudo loss. We will assign a dynamic label.
net.addLayer('loss_pseudo',dagnn.Pseudo_Loss(),{'prediction','label'},'objective_pseudo');
% The original softmax loss is used to train the first 20 epoches for stability.
net.addLayer('loss',dagnn.Loss('loss','softmaxlog'),{'prediction','label'},'objective');
net.addLayer('top1err', dagnn.Loss('loss', 'classerror'), ...
{'prediction','label'}, 'top1err') ;
net.addLayer('top5err', dagnn.Loss('loss', 'topkerror', ...
'opts', {'topK',5}), ...
{'prediction','label'}, 'top5err') ;
net.initParams();
end