Applied Sciences (Dec 2022)

Flexible Convolver for Convolutional Neural Networks Deployment onto Hardware-Oriented Applications

  • Moisés Arredondo-Velázquez,
  • Paulo Aaron Aguirre-Álvarez,
  • Alfredo Padilla-Medina,
  • Alejandro Espinosa-Calderon,
  • Juan Prado-Olivarez,
  • Javier Diaz-Carmona

DOI
https://doi.org/10.3390/app13010093
Journal volume & issue
Vol. 13, no. 1
p. 93

Abstract

Read online

This paper introduces a flexible convolver capable of adapting to the different convolution layer configurations of state-of-the-art Convolution Neural Networks (CNNs). The use of two proposed programmable components achieves this adaptability. A Programmable Line Buffer (PLB) based on Programmable Shift Registers (PSRs) allows the generation of the required convolution masks required for each processed CNN layer. The convolution layer computing is performed through a proposed programmable systolic array configured according to the target device resources. In order to maximize the device resource usage and to achieve a shortened processing time, the filter, data, and loop parallelisms are leveraged. These characteristics allow the described architecture to be scalable and implemented on any FPGA device targeting different applications. The convolver description was written in VHDL using the Intel Cyclone V 5CSXFC6D6F31C6N device as a reference. The experimental results show that the proposed computing method allows the processing of any CNN without requiring special adaptation for a specific application since the standard convolution algorithm is used. The proposed flexible convolver achieves competitive performance compared with those reported in related works.

Keywords