Python for development of OpenMP and CUDA kernels for multidimensional data

Bogdan Vacaliuc, Dilip R. Patlolla, Ed D'Azevedo, Greg G. Davidson, John K. Munro, Thomas M. Evans, Wayne Joubert, Zane W. Bell

Research output: Chapter in Book/Report/Conference proceedingConference contributionpeer-review

Abstract

Design of data structures for high performance computing (HPC) is one of the principal challenges facing researchers looking to utilize heterogeneous computing machinery. Heterogeneous systems derive cost, power, and speed efficiency by being composed of the appropriate hardware for the task. Yet, each type of processor requires a specific organization of the application state in order to achieve peak performance. Discovering this and refactoring the code can be a challenging and time-consuming task for the researcher, as the data structures and the computational model must be co-designed. We present a methodology that uses Python as the environment for which to explore tradeoffs in both the data structure design as well as the code executing on the computation accelerator. Our method enables multidimensional arrays to be used effectively in any target environment. We have chosen to focus on OpenMP and CUDA environments, thus exploring the development of optimized kernels for the two most common classes of computing hardware available today: multi-core CPU and GPU. Python's large palette of file and network access routines, its associative indexing syntax and support for common HPC environments makes it relevant for diverse hardware ranging from laptops through computing clusters to the highest performance supercomputers. Our work enables researchers to accelerate the development of their codes on the computing hardware of their choice.

Original languageEnglish
Title of host publicationProceedings - 2011 Symposium on Application Accelerators in High-Performance Computing, SAAHPC 2011
Pages159-167
Number of pages9
DOIs
StatePublished - 2011
Event2011 Symposium on Application Accelerators in High-Performance Computing, SAAHPC 2011 - Knoxville, TN, United States
Duration: Jul 19 2011Jul 20 2011

Publication series

NameProceedings - 2011 Symposium on Application Accelerators in High-Performance Computing, SAAHPC 2011

Conference

Conference2011 Symposium on Application Accelerators in High-Performance Computing, SAAHPC 2011
Country/TerritoryUnited States
CityKnoxville, TN
Period07/19/1107/20/11

Fingerprint

Dive into the research topics of 'Python for development of OpenMP and CUDA kernels for multidimensional data'. Together they form a unique fingerprint.

Cite this