プールとサンプリング

アウトライン

  • プーリング

  • アップサンプル

  • 履歴書

点心を削減

36-プーリングとサンプリング - 次元削減の.jpg

サブサンプル

最大/平均プーリング

  • ストライド= 2

36-プーリングとサンプリング - プール.JPG

ストライド

  • ストライド= 1

36-プールし、サンプリングされた - ステップ1.JPGをプール

例えば

36-プーリングとサンプリング - プールall.jpg

import tensorflow as tf
from tensorflow.keras import layers
x = tf.random.normal([1, 14, 14, 4])
x.shape
TensorShape([1, 14, 14, 4])
pool = layers.MaxPool2D(2, strides=2)
out = pool(x)
out.shape
TensorShape([1, 7, 7, 4])
pool = layers.MaxPool2D(3, strides=2)
out = pool(x)
out.shape
TensorShape([1, 6, 6, 4])
out = tf.nn.max_pool2d(x, 2, strides=2, padding='VALID')
out.shape
TensorShape([1, 7, 7, 4])

アップサンプル

  • 最寄り

  • バイリニア

36-プーリングとサンプリング - サンプリング.JPG

UpSampling2D

x = tf.random.normal([1, 7, 7, 4])
x.shape
TensorShape([1, 7, 7, 4])
layer = layers.UpSampling2D(size=3)
out = layer(x)
out.shape
TensorShape([1, 21, 21, 4])
layer = layers.UpSampling2D(size=2)
out = layer(x)
out.shape
TensorShape([1, 14, 14, 4])

履歴書

36-プーリングとサンプリング-relu.jpg

x = tf.random.normal([2,3])
x
<tf.Tensor: id=76, shape=(2, 3), dtype=float32, numpy=
array([[-0.30181265,  0.39785287, -0.78380096],
       [ 0.6593401 , -0.40962896, -0.3656048 ]], dtype=float32)>
tf.nn.relu(x)
x
<tf.Tensor: id=76, shape=(2, 3), dtype=float32, numpy=
array([[-0.30181265,  0.39785287, -0.78380096],
       [ 0.6593401 , -0.40962896, -0.3656048 ]], dtype=float32)>
layers.ReLU()(x)
<tf.Tensor: id=80, shape=(2, 3), dtype=float32, numpy=
array([[0.        , 0.39785287, 0.        ],
       [0.6593401 , 0.        , 0.        ]], dtype=float32)>

おすすめ

転載: www.cnblogs.com/nickchen121/p/10930571.html