Optimizing memory bandwidth efficiency with user-preferred kernel mergeJumah, N. and Kunkel, J. (2020) Optimizing memory bandwidth efficiency with user-preferred kernel merge. In: Euro-Par 2019: Parallel Processing Workshops, 26–30 Aug 2019, Göttingen, Germany, pp. 69-81, https://doi.org/10.1007/978-3-030-48340-1_6. Full text not archived in this repository. It is advisable to refer to the publisher's version if you intend to cite from this work. See Guidance on citing. To link to this item DOI: 10.1007/978-3-030-48340-1_6 Abstract/SummaryEarth system modeling computations use stencils extensively while running many kernels. Optimal coding of the stencils is essential to efficiently use memory bandwidth of an underlying hardware. This is important as stencil computations are memory bound. Even when the code within one kernel is written to optimally use the memory bandwidth, there are still opportunities for further optimization at the inter-kernel level. Stencils naturally exhibit data locality, and executing a sequence of stencils within separate kernels could waste caching capabilities. Interprocedural optimizations such as merging of kernels bears the potential to improve the use of the caches. However, due to semantic restrictions, it is difficult to achieve on general purpose languages. Some tools were developed to automatically fuse loops instead of the manual optimization. However, scientists still implement fusion in different levels of loop nests manually to find optimal performance. To allow scientists to still apply loop fusions equal to manual loop fusion, we develop a technique to automatically analyze the code and allow scientists to select their preferred fusions by providing automatic dependency analysis and code transformation; this also bears the potential for automatic tools that make smart choices on behalf of the user. Our work is done using GGDML language extensions which enables performance portability over different architectures using a single source code.
Altmetric Deposit Details University Staff: Request a correction | Centaur Editors: Update this record |