-
Notifications
You must be signed in to change notification settings - Fork 2
/
CAMcompute.m
61 lines (49 loc) · 1.84 KB
/
CAMcompute.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
function R = CAMcompute(Data,inputSize,net,netName,layerName,Dmat,Sample);
% R = CAMcomputeR(classActivationMap);
im = Data.XTrain(:,:,:,Sample); %cat(3,Data.XTrain(:,:,:,Sample),Data.XTrain(:,:,:,Sample),Data.XTrain(:,:,:,Sample));%imread('ngc6543a.jpg');
if inputSize(3)==3
if size(im,3)==1
im=cat(3,im,im,im);
end
end
imResized = imresize(im,[inputSize(1),inputSize(2)]);
%gpuDevice(1);
%options=trainingOptions('sgdm','ExecutionEnvironment','gpu');
imageActivations = activations(net.trainedNet,imResized,layerName);
scores = squeeze(mean(imageActivations,[1,2]));
if netName ~= "squeezenet"
fcWeights = net.trainedNet.Layers(end-2).Weights;
fcBias = net.trainedNet.Layers(end-2).Bias;
scores = fcWeights*scores + fcBias;
[~,classIds] = maxk(scores,3);
weightVector = shiftdim(fcWeights(classIds(1),:),-1);
CAM = sum(imageActivations.*weightVector,3);
else
[~,classIds] = maxk(scores,3);
CAM = imageActivations(:,:,classIds(1));
end
imSize = size(im);
CAM = imresize(CAM,imSize(1:2));
CAM = normalizeImage(CAM);
CAM(CAM<0.2) = 0;
cmap = jet(255).*linspace(0,1,255)';
CAM = ind2rgb(uint8(CAM*255),cmap)*255;
combinedImage = double(rgb2gray(im))/2 + CAM;
combinedImage = normalizeImage(combinedImage)*255;
if strcmp('r',lower(Dmat))==1
H=combinedImage(:,:,1); %let it do for 'R' or Red
DmatStr='Red';
elseif strcmp('g',lower(Dmat))==1
H=combinedImage(:,:,2); %let it do for 'G' or Green
DmatStr='Green';
elseif strcmp('b',lower(Dmat))==1
H=combinedImage(:,:,3); %let it do for 'B' or Blue
DmatStr='Blue';
else
disp('Error: 2Dmat not defined, use string R, G or B');
end
%## Find which pixels are expressed #### (by Alok)
% H=combinedImage(:,:,1); %let it do for 'R' only
R=H/255;
%##################################################
end