Towards High-Performance Code Generation for Multi-GPU Clusters Based on a Domain-Specific Language for Algorithmic Skeletons

被引:0
|
作者
Wrede, Fabian [1 ]
Kuchen, Herbert [1 ]
机构
[1] Univ Munster, European Res Ctr Informat Syst ERCIS, Dept Informat Syst, Leonardo Campus 3, D-48149 Munster, Germany
关键词
Algorithmic skeletons; Parallel programming; High-performance computing; Model-driven development; Domain-specific language;
D O I
10.1007/s10766-020-00659-x
中图分类号
TP301 [理论、方法];
学科分类号
081202 ;
摘要
In earlier work, we defined a domain-specific language (DSL) with the aim to provide an easy-to-use approach for programming multi-core and multi-GPU clusters. The DSL incorporates the idea of utilizing algorithmic skeletons, which are well-known patterns for parallel programming, such as map and reduce. Based on the chosen skeleton, a user-defined function can be applied to a data structure in parallel with the main advantage that the user does not have to worry about implementation details. So far, we had only implemented a generator for multi-core clusters and in this paper we present and evaluate two prototypes of generators for multi-GPU clusters, which are based on OpenACC and CUDA. We have evaluated the approach with four benchmark applications. The results show that the generation approach leads to execution times, which are on par with an alternative library implementation.
引用
收藏
页码:713 / 728
页数:16
相关论文
共 50 条
  • [1] Towards High-Performance Code Generation for Multi-GPU Clusters Based on a Domain-Specific Language for Algorithmic Skeletons
    Fabian Wrede
    Herbert Kuchen
    [J]. International Journal of Parallel Programming, 2020, 48 : 713 - 728
  • [2] Generation of high-performance code based on a domain-specific language for algorithmic skeletons
    Wrede, Fabian
    Rieger, Christoph
    Kuchen, Herbert
    [J]. JOURNAL OF SUPERCOMPUTING, 2020, 76 (07): : 5098 - 5116
  • [3] Generation of high-performance code based on a domain-specific language for algorithmic skeletons
    Fabian Wrede
    Christoph Rieger
    Herbert Kuchen
    [J]. The Journal of Supercomputing, 2020, 76 : 5098 - 5116
  • [4] Domain-Specific Optimization and Generation of High-Performance GPU Code for Stencil Computations
    Rawat, Prashant Singh
    Vaidya, Miheer
    Sukumaran-Rajam, Aravind
    Ravishankar, Mahesh
    Grover, Vinod
    Rountev, Atanas
    Pouchet, Louis-Noel
    Sadayappan, P.
    [J]. PROCEEDINGS OF THE IEEE, 2018, 106 (11) : 1902 - 1920
  • [5] Algorithmic skeletons for multi-core, multi-GPU systems and clusters
    Ernsting, Steffen
    Kuchen, Herbert
    [J]. International Journal of High Performance Computing and Networking, 2012, 7 (02) : 129 - 138
  • [6] Musket: A Domain-Specific Language for High-Level Parallel Programming with Algorithmic Skeletons
    Rieger, Christoph
    Wrede, Fabian
    Kuchen, Herbert
    [J]. SAC '19: PROCEEDINGS OF THE 34TH ACM/SIGAPP SYMPOSIUM ON APPLIED COMPUTING, 2019, : 1534 - 1543
  • [7] An Evaluation of Domain-Specific Language Technologies for Code Generation
    Schmittt, Christian
    Kuckuk, Sebastian
    Kostlert, Harald
    Hannig, Frank
    Teich, Jurgen
    [J]. 2014 14TH INTERNATIONAL CONFERENCE ON COMPUTATIONAL SCIENCE AND ITS APPLICATIONS (ICCSA), 2014, : 18 - 26
  • [8] Multinode Multi-GPU Two-Electron Integrals: Code Generation Using the Regent Language
    Johnson, K. Grace
    Mirchandaney, Seema
    Hoag, Ellis
    Heirich, Alan
    Aiken, Alex
    Martinez, Todd J.
    [J]. JOURNAL OF CHEMICAL THEORY AND COMPUTATION, 2022, 18 (11) : 6522 - 6536
  • [9] Automatic Task-Based Code Generation for High Performance Domain Specific Embedded Language
    Tan, Antoine Tran
    Falcou, Joel
    Etiemble, Daniel
    Kaiser, Hartmut
    [J]. INTERNATIONAL JOURNAL OF PARALLEL PROGRAMMING, 2016, 44 (03) : 449 - 465
  • [10] Automatic Task-Based Code Generation for High Performance Domain Specific Embedded Language
    Antoine Tran Tan
    Joel Falcou
    Daniel Etiemble
    Hartmut Kaiser
    [J]. International Journal of Parallel Programming, 2016, 44 : 449 - 465