使用TensorFlow從頭開始實現(xiàn)這個架構
在此之前,我已經討論了MobileNet的體系結構
接下來,我們將看到如何使用TensorFlow從頭開始實現(xiàn)這個架構。
實現(xiàn):
MobileNet架構:
圖顯示了我們將在代碼中實現(xiàn)的MobileNet體系結構。網絡從Conv、BatchNorm、ReLU塊開始,并從其上跟隨多個MobileNet塊。它最終以一個平均池和一個完全連接的層結束,并激活Softmax。
我們看到該體系結構有一個模式——Conv-dw/s1,后跟Conv/s1,依此類推。這里dw是深度層和步幅數(shù),然后是Conv層和步幅數(shù)。這兩條線是MobileNet區(qū)塊。
“Filter Shape”列給出了核大小和要使用的濾波器數(shù)量的詳細信息。列的最后一個數(shù)字表示濾波器的數(shù)量。我們看到濾波器數(shù)量從32逐漸增加到64,從64逐漸增加到128,從128逐漸增加到256,以此類推。
最后一列顯示了隨著我們深入網絡,圖像的大小是如何變化的。輸入大小選擇為224*224像素,有3個通道,輸出層分類為1000類。
正常CNN架構塊之間的差異(左),與MobileNet架構(右):
構建網絡時需要記住的幾件事:
所有層之后都是批量標準化和ReLU非線性。
與具有Conv2D層的普通CNN模型不同,MobileNet具有Depthwise Conv層,如圖所示。
工作流
從TensorFlow庫導入所有必要的層
為MobileNet塊編寫輔助函數(shù)
構建模型的主干
使用helper函數(shù)構建模型的主要部分
導入圖層
import tensorflow as tf
# 導入所有必要的層
from tensorflow.keras.layers import Input, DepthwiseConv2D
from tensorflow.keras.layers import Conv2D, BatchNormalization
from tensorflow.keras.layers import ReLU, AvgPool2D, Flatten, Dense
from tensorflow.keras import Model
Keras已經內置了一個DepthwiseConv層,所以我們不需要從頭開始創(chuàng)建它。
MobileNet塊
MobileNet塊的表示
要為MobileNet塊創(chuàng)建函數(shù),我們需要以下步驟:
函數(shù)的輸入:
a.張量(x)
b.卷積層的濾波器數(shù)量(濾波器)
c.卷積層的步長(步長)
運行:
a.應用3x3分步卷積層,然后是批量標準化層和ReLU激活
b.應用帶有1x1卷積層的濾波器,然后是批量標準化層和ReLU激活
返回張量(輸出)
這3個步驟在下面的代碼塊中實現(xiàn)。
# MobileNet block
def mobilnet_block (x, filters, strides):
x = DepthwiseConv2D(kernel_size = 3, strides = strides, padding = 'same')(x)
x = BatchNormalization()(x)
x = ReLU()(x)
x = Conv2D(filters = filters, kernel_size = 1, strides = 1)(x)
x = BatchNormalization()(x)
x = ReLU()(x)
return x
構建模型的主干
如圖2所示,第一層為Conv/s2,濾波器形狀為3x32。
模型的主干
# 模型的主干
input = Input(shape = (224,224,3))
x = Conv2D(filters = 32, kernel_size = 3, strides = 2, padding = 'same')(input)
x = BatchNormalization()(x)
x = ReLU()(x)
模型的主要部分:
# 模型的主要部分
x = mobilnet_block(x, filters = 64, strides = 1)
x = mobilnet_block(x, filters = 128, strides = 2)
x = mobilnet_block(x, filters = 128, strides = 1)
x = mobilnet_block(x, filters = 256, strides = 2)
x = mobilnet_block(x, filters = 256, strides = 1)
x = mobilnet_block(x, filters = 512, strides = 2)
for _ in range (5):
x = mobilnet_block(x, filters = 512, strides = 1)
x = mobilnet_block(x, filters = 1024, strides = 2)
x = mobilnet_block(x, filters = 1024, strides = 1)
x = AvgPool2D (pool_size = 7, strides = 1, data_format='channels_first')(x)
output = Dense (units = 1000, activation = 'softmax')(x)
model = Model(inputs=input, outputs=output)
model.summary()
模型摘要的一個片段

最新活動更多
-
10月23日火熱報名中>> 2025是德科技創(chuàng)新技術峰會
-
10月23日立即報名>> Works With 開發(fā)者大會深圳站
-
10月24日立即參評>> 【評選】維科杯·OFweek 2025(第十屆)物聯(lián)網行業(yè)年度評選
-
即日-11.25立即下載>>> 費斯托白皮書《柔性:汽車生產未來的關鍵》
-
11月27日立即報名>> 【工程師系列】汽車電子技術在線大會
-
12月18日立即報名>> 【線下會議】OFweek 2025(第十屆)物聯(lián)網產業(yè)大會
-
10 大模型的盡頭是開源
- 1 特斯拉工人被故障機器人打成重傷,索賠3.6億
- 2 【行業(yè)深度研究】退居幕后四年后,張一鳴終于把算法公司變成AI公司?
- 3 人形機器人廠商,正在批量復刻宇樹G1
- 4 AI 時代,阿里云想當“安卓” ,那誰是“蘋果”?
- 5 華為公布昇騰芯片三年計劃,自研HBM曝光
- 6 硬剛英偉達!華為發(fā)布全球最強算力超節(jié)點和集群
- 7 機器人9月大事件|3家國產機器人沖刺IPO,行業(yè)交付與融資再創(chuàng)新高!
- 8 谷歌“香蕉”爆火啟示:國產垂類AI的危機還是轉機?
- 9 00后華裔女生靠兩部AI電影狂賺7.8億人民幣,AI正式進軍好萊塢
- 10 美光:AI Capex瘋投不止,終于要拉起存儲超級周期了?