Binary Neural Network (BNN) method is an extreme application of convolutional neural network (CNN) parameter quantization. As opposed to the original CNN methods which employed floating-point computation with full-precision weights and activations, BBN uses 1-bit activations and weights. With BBNs, a significant amount of storage, network complexity and energy consumption can be reduced, and neural networks can be implemented more efficiently in embedded applications. Unfortunately, binarization causes severe information loss. A gap still exists between full-precision CNN models and their binarized counterparts. The recent developments in BNN have led to a lot of algorithms and solutions that have helped address this issue. This article provides a full overview of recent developments in BNN. The present paper focuses exclusively on 1-bit activations and weights networks, as opposed to previous surveys in which low-bit works are mixed in. In this paper, we conduct a complete investigation of BNN's development from their predecessors to the latest BNN algorithms and techniques, presenting a broad design pipeline, and discussing each module's variants. Along the way, this paper examines BNN (a) purpose: their early successes and challenges; (b) BNN optimization: selected representative works that contain key optimization techniques; (c) deployment: open-source frameworks for BNN modeling and development; (d) terminal: efficient computing architectures and devices for BNN and (e) applications: diverse applications with BNN. Moreover, this paper discusses potential directions and future research opportunities for the latest BNN algorithms and techniques, presents a broad design pipeline, and discusses each module's variants.
翻译:BNN使用全精度权重和活化的浮动点计算法,BBN使用1位启动器和重量。BNB使用1位启动器和重量。BBN使用1位启动器和重量。BBN可以减少大量存储器、网络复杂性和能源消耗量,神经网络可以在嵌入的应用中更有效地实施。不幸的是,二进制造成了严重的信息损失。全精度CNN的模型和其二进制的对应方之间仍然存在着差距。BNN最近的发展导致许多计算法和解决办法,有助于解决这一问题。这篇文章全面概述了BNNN的近期发展动态。本文专门侧重于1位启动器和重量网络,而以前的调查则将低位工程混杂在一起。在本论文中,我们对BNNN的模型发展与最新的 BNNN的变式算法和技术,展示了广泛的设计管道,并讨论了每个模块的变式:NNNN的近期设计技术;B的早期设计法;B的近期设计框架;B的中期设计法;B的中期设计法;B的中期设计法;B的中期设计法;B的流程;B的流程;B级的流程;B的流程;B级的流程;B级的流程;B级的流程;B级的流程;B级的流程;B级研究;B级研究;B级的初的流程;B级的流程;B级的流程;B级的流程;B级的每个级的流程;B级的流程;和B级的初试。