TY - JOUR
T1 - Xevolver
T2 - A code transformation framework for separation of system-awareness from application codes
AU - Komatsu, Kazuhiko
AU - Gomi, Ayumu
AU - Egawa, Ryusuke
AU - Takahashi, Daisuke
AU - Suda, Reiji
AU - Takizawa, Hiroyuki
N1 - Funding Information:
This research was partially supported by Core Research of Evolutional Science and Technology, Japan Science and Technology Agency (CREST, JST) “An Evolutionary Approach to Construction of a Software Development Environment for Massively Parallel Heterogeneous Systems.” This research uses the SX‐ACE and LX systems in Cyberscience Center of Tohoku University.
Funding Information:
This research was partially supported by Core Research of Evolutional Science and Technology, Japan Science and Technology Agency (CREST, JST) ?An Evolutionary Approach to Construction of a Software Development Environment for Massively Parallel Heterogeneous Systems.? This research uses the SX-ACE and LX systems in Cyberscience Center of Tohoku University.
Publisher Copyright:
© 2019 John Wiley & Sons, Ltd.
PY - 2020/4/10
Y1 - 2020/4/10
N2 - This paper introduces the Xevolver code transformation framework to separate system-aware code optimizations from HPC application codes. System-aware code optimizations often make it difficult for programmers to maintain HPC application codes. On the other side, system-aware code optimizations are mandatory to exploit the performance of target HPC systems. To achieve both high maintainability and high performance, the Xevolver framework provides an easy way to express system-aware code optimizations as user-defined code transformation rules. Those rules can be defined separately from HPC application codes. As a result, an HPC application code is converted into its optimized version for a particular target system just before the compilation, and standard HPC programmers do not usually need to maintain the optimized version that could be complicated and difficult-to-maintain. In this paper, three important components of the Xevolver framework are described, and then their practicality and benefits are demonstrated through six case studies. Accordingly, the user-defined code transformation approach behind the Xevolver framework is promising to express system-awareness for extracting the performance of an HPC system, and also for sharing expert knowledge and experiences about code optimizations. As the complexity and diversity of HPC system architectures are increasing in an extreme-scale computing era, system-aware code optimization without overcomplicating the code as discussed in this paper will become more and more important in the future.
AB - This paper introduces the Xevolver code transformation framework to separate system-aware code optimizations from HPC application codes. System-aware code optimizations often make it difficult for programmers to maintain HPC application codes. On the other side, system-aware code optimizations are mandatory to exploit the performance of target HPC systems. To achieve both high maintainability and high performance, the Xevolver framework provides an easy way to express system-aware code optimizations as user-defined code transformation rules. Those rules can be defined separately from HPC application codes. As a result, an HPC application code is converted into its optimized version for a particular target system just before the compilation, and standard HPC programmers do not usually need to maintain the optimized version that could be complicated and difficult-to-maintain. In this paper, three important components of the Xevolver framework are described, and then their practicality and benefits are demonstrated through six case studies. Accordingly, the user-defined code transformation approach behind the Xevolver framework is promising to express system-awareness for extracting the performance of an HPC system, and also for sharing expert knowledge and experiences about code optimizations. As the complexity and diversity of HPC system architectures are increasing in an extreme-scale computing era, system-aware code optimization without overcomplicating the code as discussed in this paper will become more and more important in the future.
KW - high-performance computing
KW - performance optimization
KW - separation of concern
KW - system-awareness
KW - user-defined code transformation
UR - http://www.scopus.com/inward/record.url?scp=85076108600&partnerID=8YFLogxK
UR - http://www.scopus.com/inward/citedby.url?scp=85076108600&partnerID=8YFLogxK
U2 - 10.1002/cpe.5577
DO - 10.1002/cpe.5577
M3 - Article
AN - SCOPUS:85076108600
SN - 1532-0626
VL - 32
JO - Concurrency Computation Practice and Experience
JF - Concurrency Computation Practice and Experience
IS - 7
M1 - e5577
ER -