Conv2DTranspose
類別tf_keras.layers.Conv2DTranspose(
filters,
kernel_size,
strides=(1, 1),
padding="valid",
output_padding=None,
data_format=None,
dilation_rate=(1, 1),
activation=None,
use_bias=True,
kernel_initializer="glorot_uniform",
bias_initializer="zeros",
kernel_regularizer=None,
bias_regularizer=None,
activity_regularizer=None,
kernel_constraint=None,
bias_constraint=None,
**kwargs
)
轉置卷積層(有時稱為反卷積)。
對轉置卷積的需求通常源於希望使用與一般卷積相反方向的轉換,也就是說,從具有某些卷積輸出的形狀轉換為具有其輸入形狀的同時,保持與該卷積相容的連接模式。
當使用此層作為模型中的第一層時,請提供關鍵字參數 input_shape
(整數或 None
的元組,不包括樣本軸),例如,針對 data_format="channels_last"
中 128x128 RGB 圖片,input_shape=(128, 128, 3)
。
參數
dilation_rate
值 != 1 不相容。"valid"
或 "same"
其中之一(不區分大小寫)。"valid"
表示不填充。"same"
會將零均勻地填充到輸入的左/右或上/下,以便輸出具有與輸入相同的高度/寬度維度。None
(預設值),則會推斷輸出形狀。channels_last
(預設值)或 channels_first
其中之一。輸入中維度的順序。channels_last
對應於形狀為 (batch_size, height, width, channels)
的輸入,而 channels_first
對應於形狀為 (batch_size, channels, height, width)
的輸入。如果未指定,則會使用在您的 Keras 設定檔 ~/.keras/keras.json
中找到的 image_data_format
值(如果存在),否則使用 'channels_last'。預設值為 "channels_last"。dilation_rate
值 != 1 與指定任何步幅值 != 1 不相容。keras.activations
)。kernel
權重矩陣的初始化器(請參閱 keras.initializers
)。預設值為 'glorot_uniform'。keras.initializers
)。預設值為 'zeros'。kernel
權重矩陣的正規化函數(請參閱 keras.regularizers
)。keras.regularizers
)。keras.regularizers
)。keras.constraints
)。keras.constraints
)。輸入形狀
如果 data_format='channels_first',則為形狀為 (batch_size, channels, rows, cols)
的 4D 張量;如果 data_format='channels_last',則為形狀為 (batch_size, rows, cols, channels)
的 4D 張量。
輸出形狀
如果 data_format='channels_first',則為形狀為 (batch_size, filters, new_rows, new_cols)
的 4D 張量;如果 data_format='channels_last',則為形狀為 (batch_size, new_rows, new_cols, filters)
的 4D 張量。rows
和 cols
的值可能會因為填充而改變。如果指定了 output_padding
new_rows = ((rows - 1) * strides[0] + kernel_size[0] - 2 * padding[0] +
output_padding[0])
new_cols = ((cols - 1) * strides[1] + kernel_size[1] - 2 * padding[1] +
output_padding[1])
傳回
代表 activation(conv2dtranspose(inputs, kernel) + bias)
的 4 階張量。
觸發
padding
為 "causal"。strides
> 1 且 dilation_rate
> 1 時。參考資料