MobileNet is a family of convolutional neural network (CNN) architectures designed for image classification, object detection, and other computer vision tasks. They are designed for small size, low latency, and low power consumption, making them suitable for on-device inference and edge computing on resource-constrained devices like mobile phones and embedded systems. They were originally designed to be run efficiently on mobile devices with TensorFlow Lite.
Developer(s) | |
---|---|
Initial release | April 2017 |
Stable release | v4
/ September 2024 |
Repository | github |
Written in | Python |
License | Apache License 2.0 |
The need for efficient deep learning models on mobile devices led researchers at Google to develop MobileNet. As of October 2024[update], the family has four versions, each improving upon the previous one in terms of performance and efficiency.
Features
editV1
editMobileNetV1 was published in April 2017.[1][2] Its main architectural innovation was incorporation of depthwise separable convolutions. It was first developed by Laurent Sifre during an internship at Google Brain in 2013 as an architectural variation on AlexNet to improve convergence speed and model size.[3]
The depthwise separable convolution decomposes a single standard convolution into two convolutions: a depthwise convolution that filters each input channel independently and a pointwise convolution ( convolution) that combines the outputs of the depthwise convolution. This factorization significantly reduces computational cost.
The MobileNetV1 has two hyperparameters: a width multiplier that controls the number of channels in each layer. Smaller values of lead to smaller and faster models, but at the cost of reduced accuracy, and a resolution multiplier , which controls the input resolution of the images. Lower resolutions result in faster processing but potentially lower accuracy.
V2
editMobileNetV2 was published in March 2019.[4][5] It uses inverted residual layers and linear bottlenecks.
Inverted residuals modify the traditional residual block structure. Instead of compressing the input channels before the depthwise convolution, they expand them. This expansion is followed by a depthwise convolution and then a projection layer that reduces the number of channels back down. This inverted structure helps to maintain representational capacity by allowing the depthwise convolution to operate on a higher-dimensional feature space, thus preserving more information flow during the convolutional process.
Linear bottlenecks removes the typical ReLU activation function in the projection layers. This was rationalized by arguing that that nonlinear activation loses information in lower-dimensional spaces, which is problematic when the number of channels is already small.
V3
editMobileNetV3 was published in 2019.[6][7] The publication included MobileNetV3-Small, MobileNetV3-Large, and MobileNetEdgeTPU (optimized for Pixel 4). They were found by a form of neural architecture search (NAS) that takes mobile latency into account, to achieve good trade-off between accuracy and latency.[8][9] It used piecewise-linear approximations of swish and sigmoid activation functions (which they called "h-swish" and "h-sigmoid"), squeeze-and-excitation modules,[10] and the inverted bottlenecks of MobileNetV2.
V4
editMobileNetV4 was published in September 2024.[11][12] The publication included a large number of architectures found by NAS. Compared to the architectural modules used in V3, the V4 series included the "universal inverted bottleneck", which includes both inverted residual and inverted bottleneck as special cases, and attention modules with multi-query attention.[13]
See also
editExternal links
edit- "models/research/slim/nets/mobilenet at master · tensorflow/models". GitHub. Retrieved 2024-10-18.
- "Keras documentation: MobileNet, MobileNetV2, and MobileNetV3". Keras. Retrieved October 18, 2024.
References
edit- ^ Howard, Andrew G.; Zhu, Menglong; Chen, Bo; Kalenichenko, Dmitry; Wang, Weijun; Weyand, Tobias; Andreetto, Marco; Adam, Hartwig (2017-04-16), MobileNets: Efficient Convolutional Neural Networks for Mobile Vision Applications, arXiv:1704.04861
- ^ "MobileNets: Open-Source Models for Efficient On-Device Vision". research.google. June 14, 2017. Retrieved 2024-10-18.
- ^ Chollet, François (2017). "Xception: Deep Learning with Depthwise Separable Convolutions". 2017 IEEE Conference on Computer Vision and Pattern Recognition (CVPR). pp. 1800–1807. arXiv:1610.02357. doi:10.1109/CVPR.2017.195. ISBN 978-1-5386-0457-1.1800-1807&rft.date=2017&rft_id=info:arxiv/1610.02357&rft_id=info:doi/10.1109/CVPR.2017.195&rft.isbn=978-1-5386-0457-1&rft.aulast=Chollet&rft.aufirst=François&rft_id=https://openaccess.thecvf.com/content_cvpr_2017/html/Chollet_Xception_Deep_Learning_CVPR_2017_paper.html&rfr_id=info:sid/en.wikipedia.org:MobileNet" class="Z3988">
- ^ Sandler, Mark; Howard, Andrew; Zhu, Menglong; Zhmoginov, Andrey; Chen, Liang-Chieh (2019-03-21), MobileNetV2: Inverted Residuals and Linear Bottlenecks, arXiv:1801.04381
- ^ "MobileNetV2: The Next Generation of On-Device Computer Vision Networks". research.google. April 3, 2018. Retrieved 2024-10-18.
- ^ "Introducing the Next Generation of On-Device Vision Models: MobileNetV3 and Mobi". research.google. November 13, 2019. Retrieved 2024-10-18.
- ^ Howard, Andrew; Sandler, Mark; Chu, Grace; Chen, Liang-Chieh; Chen, Bo; Tan, Mingxing; Wang, Weijun; Zhu, Yukun; Pang, Ruoming; Vasudevan, Vijay; Le, Quoc V.; Adam, Hartwig (2019). "Searching for MobileNetV3": 1314–1324. arXiv:1905.02244.1314-1324&rft.date=2019&rft_id=info:arxiv/1905.02244&rft.aulast=Howard&rft.aufirst=Andrew&rft.au=Sandler, Mark&rft.au=Chu, Grace&rft.au=Chen, Liang-Chieh&rft.au=Chen, Bo&rft.au=Tan, Mingxing&rft.au=Wang, Weijun&rft.au=Zhu, Yukun&rft.au=Pang, Ruoming&rft.au=Vasudevan, Vijay&rft.au=Le, Quoc V.&rft.au=Adam, Hartwig&rft_id=https://openaccess.thecvf.com/content_ICCV_2019/html/Howard_Searching_for_MobileNetV3_ICCV_2019_paper.html&rfr_id=info:sid/en.wikipedia.org:MobileNet" class="Z3988">
{{cite journal}}
: Cite journal requires|journal=
(help) - ^ Tan, Mingxing; Chen, Bo; Pang, Ruoming; Vasudevan, Vijay; Sandler, Mark; Howard, Andrew; Le, Quoc V. (June 2019). "MnasNet: Platform-Aware Neural Architecture Search for Mobile". 2019 IEEE/CVF Conference on Computer Vision and Pattern Recognition (CVPR). IEEE. pp. 2815–2823. arXiv:1807.11626. doi:10.1109/CVPR.2019.00293. ISBN 978-1-7281-3293-8.2815-2823&rft.pub=IEEE&rft.date=2019-06&rft_id=info:arxiv/1807.11626&rft_id=info:doi/10.1109/CVPR.2019.00293&rft.isbn=978-1-7281-3293-8&rft.aulast=Tan&rft.aufirst=Mingxing&rft.au=Chen, Bo&rft.au=Pang, Ruoming&rft.au=Vasudevan, Vijay&rft.au=Sandler, Mark&rft.au=Howard, Andrew&rft.au=Le, Quoc V.&rft_id=https://ieeexplore.ieee.org/document/8954198&rfr_id=info:sid/en.wikipedia.org:MobileNet" class="Z3988">
- ^ Yang, Tien-Ju; Howard, Andrew; Chen, Bo; Zhang, Xiao; Go, Alec; Sandler, Mark; Sze, Vivienne; Adam, Hartwig (2018). "NetAdapt: Platform-Aware Neural Network Adaptation for Mobile Applications": 285–300. arXiv:1804.03230.285-300&rft.date=2018&rft_id=info:arxiv/1804.03230&rft.aulast=Yang&rft.aufirst=Tien-Ju&rft.au=Howard, Andrew&rft.au=Chen, Bo&rft.au=Zhang, Xiao&rft.au=Go, Alec&rft.au=Sandler, Mark&rft.au=Sze, Vivienne&rft.au=Adam, Hartwig&rft_id=https://openaccess.thecvf.com/content_ECCV_2018/html/Tien-Ju_Yang_NetAdapt_Platform-Aware_Neural_ECCV_2018_paper.html&rfr_id=info:sid/en.wikipedia.org:MobileNet" class="Z3988">
{{cite journal}}
: Cite journal requires|journal=
(help) - ^ Hu, Jie; Shen, Li; Sun, Gang (2018). "Squeeze-and-Excitation Networks": 7132–7141.7132-7141&rft.date=2018&rft.aulast=Hu&rft.aufirst=Jie&rft.au=Shen, Li&rft.au=Sun, Gang&rft_id=https://openaccess.thecvf.com/content_cvpr_2018/html/Hu_Squeeze-and-Excitation_Networks_CVPR_2018_paper.html&rfr_id=info:sid/en.wikipedia.org:MobileNet" class="Z3988">
{{cite journal}}
: Cite journal requires|journal=
(help) - ^ Qin, Danfeng; Leichner, Chas; Delakis, Manolis; Fornoni, Marco; Luo, Shixin; Yang, Fan; Wang, Weijun; Banbury, Colby; Ye, Chengxi (2024-09-29), MobileNetV4 -- Universal Models for the Mobile Ecosystem, arXiv:2404.10518
- ^ Wightman, Ross. "MobileNet-V4 (now in timm)". huggingface.co. Retrieved 2024-10-18.
- ^ Shazeer, Noam (2019-11-05), Fast Transformer Decoding: One Write-Head is All You Need, arXiv:1911.02150