OCC: An Automated End-to-End Machine Learning Optimizing Compiler for Computing-In-Memory
Adam Siemieniuk,Lorenzo Chelini,Asif Ali Khan,Jeronimo Castrillon,Andi Drebes,Henk Corporaal,Tobias Grosser,Martin Kong
DOI: https://doi.org/10.1109/tcad.2021.3101464
2021-01-01
Abstract:Memristive devices promise an alternative approach toward non-Von Neumann architectures, where specific computational tasks are performed within the memory devices. In the machine learning (ML) domain, crossbar arrays of resistive devices have shown great promise for ML inference, as they allow for hardware acceleration of matrix multiplications. But, to enable widespread adoption of these novel architectures, it is critical to have an automatic compilation flow as opposed to relying on a manual mapping of specific kernels on the crossbar arrays. We demonstrate the programmability of memristor-based accelerators using the new compiler design principle of multilevel rewriting, where a hierarchy of abstractions lowers programs level-by-level and perform code transformations at the most suitable abstraction. In particular, we develop a prototype compiler, which progressively lowers a mathematical notation for tensor operations arising in ML workloads, to fixed-function memristor-based hardware blocks.
engineering, electrical & electronic,computer science, interdisciplinary applications, hardware & architecture