日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 人文社科 > 生活经验 >内容正文

生活经验

机器学习入门(18)— 卷积网络中的池化层实现

發(fā)布時(shí)間:2023/11/27 生活经验 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 机器学习入门(18)— 卷积网络中的池化层实现 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

1. 池化層實(shí)現(xiàn)

池化層的實(shí)現(xiàn)和卷積層相同,都使用 im2col 展開輸入數(shù)據(jù)。不過,池化的情況下,在通道方向上是獨(dú)立的,這一點(diǎn)和卷積層不同。具體地講,如圖 7-21 所示,池化的應(yīng)用區(qū)域按通道單獨(dú)展開。

像這樣展開之后,只需對(duì)展開的矩陣求各行的最大值,并轉(zhuǎn)換為合適的形狀即可(圖7-22)。

上面就是池化層的 forward 處理的實(shí)現(xiàn)流程。下面來看一下實(shí)現(xiàn)示例。

class Pooling:def __init__(self, pool_h, pool_w, stride=1, pad=0):self.pool_h = pool_hself.pool_w = pool_wself.stride = strideself.pad = padself.x = Noneself.arg_max = Nonedef forward(self, x):N, C, H, W = x.shapeout_h = int(1 + (H - self.pool_h) / self.stride)out_w = int(1 + (W - self.pool_w) / self.stride)# 展開col = im2col(x, self.pool_h, self.pool_w, self.stride, self.pad)col = col.reshape(-1, self.pool_h*self.pool_w)# 最大值arg_max = np.argmax(col, axis=1)out = np.max(col, axis=1)# 轉(zhuǎn)換out = out.reshape(N, out_h, out_w, C).transpose(0, 3, 1, 2)self.x = xself.arg_max = arg_maxreturn outdef backward(self, dout):dout = dout.transpose(0, 2, 3, 1)pool_size = self.pool_h * self.pool_wdmax = np.zeros((dout.size, pool_size))dmax[np.arange(self.arg_max.size), self.arg_max.flatten()] = dout.flatten()dmax = dmax.reshape(dout.shape + (pool_size,)) dcol = dmax.reshape(dmax.shape[0] * dmax.shape[1] * dmax.shape[2], -1)dx = col2im(dcol, self.x.shape, self.pool_h, self.pool_w, self.stride, self.pad)return dx

最大值的計(jì)算可以使用 NumPynp.max 方法。np.max 可以指定 axis 參數(shù),并在這個(gè)參數(shù)指定的各個(gè)軸方向上求最大值。比如,如果寫成 np.max(x, axis=1),就可以在輸入 x 的第 1 維的各個(gè)軸方向上求最大值。

總結(jié)

以上是生活随笔為你收集整理的机器学习入门(18)— 卷积网络中的池化层实现的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。