Compressing deep neural networks on FPGAs to binary and ternary precision with hls4ml

Jennifer Ngadiuba,Vladimir Loncar,Maurizio Pierini,Sioni Summers,Giuseppe Di Guglielmo,Javier Duarte,Philip Harris,Dylan Rankin,Sergo Jindariani,Mia Liu,Kevin Pedro,Nhan Tran,Edward Kreinar,Sheila Sagear,Zhenbin Wu,Duc Hoang
DOI: https://doi.org/10.1088/2632-2153/aba042
2020-12-04
Machine Learning: Science and Technology
Abstract:We present the implementation of binary and ternary neural networks in the <span>hls4ml</span> library, designed to automatically convert deep neural network models to digital circuits with field-programmable gate arrays (FPGA) firmware. Starting from benchmark models trained with floating point precision, we investigate different strategies to reduce the network's resource consumption by reducing the numerical precision of the network parameters to binary or ternary. We discuss the trade-off between model accuracy and resource consumption. In addition, we show how to balance between latency and accuracy by retaining full precision on a selected subset of network components. As an example, we consider two multiclass classification tasks: handwritten digit recognition with the MNIST data set and jet identification with simulated proton-proton collisions at the CERN Large Hadron Collider. The binary and ternary implementation has similar performance to the higher precision implementation while using drastically fewer FPGA resources.
What problem does this paper attempt to address?