Help regarding the transposed convolution layer

6 Ansichten (letzte 30 Tage)
Radians
Radians am 6 Mär. 2020
Beantwortet: Srivardhan Gadila am 17 Mär. 2020
Hi,
Please provide help regarding how the transposedConv2dLayer works.
I am struggling to understand the following helper function
function out = createUpsampleTransponseConvLayer(factor,numFilters)
filterSize = 2*factor - mod(factor,2);
cropping = (factor-mod(factor,2))/2;
numChannels = 1;
out = transposedConv2dLayer(filterSize,numFilters, ...
'NumChannels',numChannels,'Stride',factor,'Cropping',cropping);
end
How does the filtersize and stride affect the output of this layer?
What's the difference between this layer and a simple upsampling layer?
whether the weights are somehow transposed or learned from scratch?

Akzeptierte Antwort

Srivardhan Gadila
Srivardhan Gadila am 17 Mär. 2020
An upsampling layer uses a defined/pre-defined interpolation method to upsample the input but a transposed convolution layer learns weights from the scratch. Starting in R2019a, the software, by default, initializes the layer weights of this layer using the Glorot initializer. This behavior helps stabilize training and usually reduces the training time of deep networks.
Check for the references of the transposedConv2dLayer for more information.
Refer to Input Arguments section of transposedConv2dLayer for explanation of each input parameter.

Weitere Antworten (0)

Tags

Community Treasure Hunt

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

Start Hunting!

Translated by