Issue with batch normalization layer of saved CNN

15 ビュー (過去 30 日間)
Kjetil Kveim
Kjetil Kveim 2019 年 3 月 21 日
回答済み: Sam Leeney 2022 年 12 月 15 日
When loading a previously trained CNN, I got an issue with the batch normalization layers. When looking into the loaded CNN model the trainable mean and variance are empty.
Name: 'batchnorm_1'
TrainedMean: []
TrainedVariance: []
So the checkpoint doesn't seem to save these parameters. Are there any workarounds for this issue? I am using Matlab R2018b.
  1 件のコメント
Wes Baldwin
Wes Baldwin 2020 年 7 月 29 日
Doesn't this mean using checkpoints on networks with a batchnorm layer is useless??? Kinda a big deal for long training!!! You could potentially lose days or weeks of training with no option but to start from the beginning.

サインインしてコメントする。

採用された回答

Vivek Singh
Vivek Singh 2019 年 3 月 22 日
We were able to reproduce the issue. We will inform you once the issue is fixed.
Since TrainedMean and TrainedVariance are calculated after the training is finished, therefore as a workaround you can use the below mentioned codes to explicitly save and load the Model.
%To save model with name "demoModel", assuming your network is in "net"
save('demoModel','net')
%To load model to variable net1
net1=load('demoModel.mat','net');
net1.net.Layers(n).TrainedMean %where n is the batch normalization layer
  4 件のコメント
ramin nateghi
ramin nateghi 2020 年 11 月 5 日
編集済み: ramin nateghi 2020 年 11 月 5 日
Hello,
I also faced this problem. When a model is saved by "save" function, it is ok and the model contains all information (TrainedMean and TrainedVariance) of the trained batch normalization layers. But, when the model is saved by the"checkpoint" during training, both of the TrainedMean and TrainedVariance params became empty. This is a bug for "checkpoint".
Yi Wei
Yi Wei 2020 年 11 月 30 日
Does it mean the saving process will cost too much time if a network contains normalization layers and the training data volume is large(e.g.8T)?

サインインしてコメントする。

その他の回答 (1 件)

Sam Leeney
Sam Leeney 2022 年 12 月 15 日
For anyone else stuck, there is a fix here; https://uk.mathworks.com/matlabcentral/answers/423588-how-to-classify-with-dag-network-from-checkpoint

カテゴリ

Help Center および File ExchangeImage Data Workflows についてさらに検索

製品


リリース

R2018b

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by