How to get the gradient with respect to the output of a specific layer in a deep learning model?
4 ビュー (過去 30 日間)
古いコメントを表示
Hi,
I have a model myModel which is a simple 2 Layers model (i.e. input size: 3; Layer_1 size: 7; Layer_2 size: 4).
That is, the layer's output is a
and the loss is
.
data:image/s3,"s3://crabby-images/d9952/d99526ca020e81ceba626ab68aef8187390d8b38" alt=""
data:image/s3,"s3://crabby-images/d7244/d7244fd14b00f7b53edf3a53c4415c442b05b4cb" alt=""
From below code, now I have the
whose dimention is 60 since there are 60 parameters in the model (i.e. (3+1)*7+(7+1)*4 = 60). Nis the number of data points (i.e.
in my code)
data:image/s3,"s3://crabby-images/05476/05476c9796b279c15591babed0184ca5617f7dd7" alt=""
data:image/s3,"s3://crabby-images/5bb19/5bb1981108800debe85ca8724a9a50cbae8231a2" alt=""
But want I want is the gradient with respect to the layer 2's output, instead of the loss. That is, I want
instead, whose dimention would be
since
.
data:image/s3,"s3://crabby-images/49342/493423bdaf46d5776680a44cbdf366eca34fef0d" alt=""
data:image/s3,"s3://crabby-images/17b2d/17b2d08d68718dc963978b2a26ce8830e3a40159" alt=""
data:image/s3,"s3://crabby-images/61350/61350d6475934e2e4e5ce56a84722cd35e4ff6d2" alt=""
How can I get
? Many thanks!
data:image/s3,"s3://crabby-images/1dc72/1dc724e833af8de6a58d07f4d225c1a9a5352dcc" alt=""
My code
rng(123); % seed
X_ori=[4,163,80;5,164,75]; % data; #(number) = 2; #(features) = 3;
X=permute(X_ori,[3,4,2,1]);
dlX = dlarray(X, 'SSCB');
Y_ori=[0, 0, 0, 1; 0, 1, 0, 0]; % data labels (i.e. one-hot vectors for 4 classes)
myModel = [
imageInputLayer([1 1 3],'Normalization','none','Name','in')
fullyConnectedLayer(7,'Name','Layer 1')
fullyConnectedLayer(4,'Name','Layer 2')];
MyLGraph = layerGraph(myModel);
myDLnet = dlnetwork(MyLGraph);
gradients = dlfeval(@modelGradients, myDLnet, dlX, Y_ori);
function [gradients] = modelGradients(myModel, modelInput, CorrectLabels)
CorrectLabels_transpose=transpose(CorrectLabels);
[modelOutput,state] = forward(myModel,modelInput);
loss = -sum(sum(CorrectLabels_transpose.*log(sigmoid(modelOutput/100))));
gradients = dlgradient(loss, myModel.Learnables);
end
Thanks
0 件のコメント
回答 (1 件)
Athul Prakash
2019 年 11 月 25 日
You could try looking at the source code for the fullyConnectedLayer that you're using; and then customizing that code to return the gradients you're looking for.
Alternatively, try creating your own custom layer to achieve this. See the doc below for that:
Hope it Helps!
0 件のコメント
参考
カテゴリ
Help Center および File Exchange で Deep Learning Toolbox についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!