Streaming Overlay Architecture for Lightweight LSTM Computation on FPGA SoCs

Lenos Ioannou, Suhaib A. Fahmy

Research output: Contribution to journalArticlepeer-review

Abstract

Long-Short Term Memory (LSTM) networks, and Recurrent Neural Networks (RNNs) in general, have demonstrated their suitability in many time series data applications, especially in Natural Language Processing (NLP). Computationally, LSTMs introduce dependencies on previous outputs in each layer that complicate their computation and the design of custom computing architectures, compared to traditional feed-forward networks. Most neural network acceleration work has focused on optimising the core matrix-vector operations on highly capable FPGAs in server environments. Research that considers the embedded domain has often been unsuitable for streaming inference, relying heavily on batch processing to achieve high throughput. Moreover, many existing accelerator architectures have not focused on fully exploiting the underlying FPGA architecture, resulting in designs that achieve lower operating frequencies than the theoretical maximum. This paper presents a flexible overlay architecture for LSTMs on FPGA SoCs that is built around a streaming dataflow arrangement, uses DSP block capabilities directly, and is tailored to keep parameters within the architecture while moving input data serially to mitigate external memory access overheads. The architecture is designed as an overlay that can be configured to implement alternative models or update model parameters at runtime. It achieves higher operating frequency and demonstrates higher performance than other lightweight LSTM accelerators, as demonstrated in an FPGA SoC implementation.
Original languageEnglish (US)
JournalACM Transactions on Reconfigurable Technology and Systems
DOIs
StatePublished - Jun 21 2022

ASJC Scopus subject areas

  • Computer Science(all)

Fingerprint

Dive into the research topics of 'Streaming Overlay Architecture for Lightweight LSTM Computation on FPGA SoCs'. Together they form a unique fingerprint.

Cite this