Optimizing N-dimensional, winograd-based convolution for manycore CPUs

Zhen Jia, Aleksandar Zlateski, Fredo Durand, Kai Li

Research output: Chapter in Book/Report/Conference proceedingConference contribution

36 Scopus citations

Abstract

Recent work on Winograd-based convolution allows for a great reduction of computational complexity, but existing implementations are limited to 2D data and a single kernel size of 3 by 3. They can achieve only slightly better, and often worse performance than better optimized, direct convolution implementations. We propose and implement an algorithm for N-dimensional Winogradśbased convolution that allows arbitrary kernel sizes and is optimized for manycore CPUs. Our algorithm achieves high hardware utilization through a series of optimizations. Our experiments show that on modern ConvNets, our optimized implementation, is on average more than 3, and sometimes 8 faster than other state-ofthe-art CPU implementations on an Intel Xeon Phi manycore processors. Moreover, our implementation on the Xeon Phi achieves competitive performance for 2D ConvNets and superior performance for 3D ConvNets, compared with the best GPU implementations.

Original languageEnglish (US)
Title of host publicationPPoPP 2018 - Proceedings of the 23rd Principles and Practice of Parallel Programming
PublisherAssociation for Computing Machinery
Pages109-123
Number of pages15
ISBN (Electronic)9781450349826
DOIs
StatePublished - Feb 10 2018
Event23rd ACM SIGPLAN Symposium on Principles and Practice of Parallel Programming, PPoPP 2018 - Vienna, Austria
Duration: Feb 24 2018Feb 28 2018

Publication series

NameProceedings of the ACM SIGPLAN Symposium on Principles and Practice of Parallel Programming, PPOPP

Other

Other23rd ACM SIGPLAN Symposium on Principles and Practice of Parallel Programming, PPoPP 2018
Country/TerritoryAustria
CityVienna
Period2/24/182/28/18

All Science Journal Classification (ASJC) codes

  • Software

Keywords

  • Convolution
  • Parallelization
  • Vectorization
  • Winograd

Fingerprint

Dive into the research topics of 'Optimizing N-dimensional, winograd-based convolution for manycore CPUs'. Together they form a unique fingerprint.

Cite this