LGDCPFOct 1, 2019

NGEMM: Optimizing GEMM for Deep Learning via Compiler-based Techniques

arXiv:1910.00178v29 citations
Originality Incremental advance
AI Analysis

This work addresses performance bottlenecks in quantized DNN training and inference for production services, representing an incremental improvement over existing methods.

The paper tackles the problem of inefficient integer GEMM operations in quantized deep neural networks by developing NGEMM, a compiler-based implementation that avoids unnecessary vector computation, resulting in average speedups of 1.86x and 1.16x over state-of-the-art BLAS libraries.

Quantization has emerged to be an effective way to significantly boost the performance of deep neural networks (DNNs) by utilizing low-bit computations. Despite having lower numerical precision, quantized DNNs are able to reduce both memory bandwidth and computation cycles with little losses of accuracy. Integer GEMM (General Matrix Multiplication) is critical to running quantized DNN models efficiently, as GEMM operations often dominate the computations in these models. Various approaches have been developed by leveraging techniques such as vectorization and memory layout to improve the performance of integer GEMM. However, these existing approaches are not fast enough in certain scenarios. We developed NGEMM, a compiler-based GEMM implementation for accelerating lower-precision training and inference. NGEMM has better use of the vector units by avoiding unnecessary vector computation that is introduced during tree reduction. We compared NGEMM's performance with the state-of-art BLAS libraries such as MKL. Our experimental results showed that NGEMM outperformed MKL non-pack and pack version by an average of 1.86x and 1.16x, respectively. We have applied NGEMM to a number of production services in Microsoft.

Foundations

The foundational work for this paper's niche, ranked by how specifically the neighbourhood builds on it — not by global fame.

Your Notes