Project Details
Projekt Print View

Enabling Performance Engineering in Hesse and Rhineland-Palatinate - A Cooperation of the Rhine-Main-Universities and the Technische Universität Kaiserslautern

Subject Area Data Management, Data-Intensive Systems, Computer Science Methods in Business Informatics
Term from 2016 to 2020
Project identifier Deutsche Forschungsgemeinschaft (DFG) - Project number 320898076
 
Final Report Year 2020

Final Report Abstract

The goal of the project was to enable a larger group of scientific users to bring performance engineering techniques to bear on their codes, and to harmonize the educational HPC structures between the states of Hesse and Rhineland-Palatine. The goal was both to provide more depth and breadth with respect to HPC skills deemed crucial for effective use of HPC resources. With respect to usability of tools, significant progress was made regarding the Extra-P performance modeling tool, the Vc vectorization library, and the CoDiPack Software for algorithmic differentiation. Extra-P: A streamlined process was developed that greatly simplifies the generation of performance models for inexperienced users, thereby providing a service for performance model generation. In addition, Extra-P was used in various in-depth explorations of codes, including one in C#. Lastly, Extra-P’s underlying algorithmic base was enhanced to provide better results while needing less information from the user. Vc: The Vc library explicitly states data-parallel operations, expressing parallelism via the type system. It is already used in production systems, but in order to ensure the long-term viability of this approach, support for SIMD templates was introduced into C++ standardization efforts, implemented in the libc++ standard library, and will soon be included in the GCC compiler. This philosophy was also successfully applied in the porting codes to GPUs and the GPU implementation of tensor operations. CoDiPack: The CoDiPack package implements algorithmic differntiation in an effective fashion, enabling, in particular, the identification of code passages that are the most sensitive to small changes arising from numerical roundoff or changes of parametrization. In collaboration with TRR 165, cloud microphysical schemes were investigated. In collaboration with DLR, the sensitivity of hand-coded Fourier transformation libraries was assessed and it was established that an exchange with external libraries was safe. In addition, for all tools, workshops and tutorials were held at various occasions. While successful in the sense of educating potential users about tool capabilities, we found it to be difficult to engage users to the point where they would really dedicate their effort beyond the initial contact with our teams, despite tools being open-source. By and large, the expectation was that our staff, who is knowledgeable in the matters, does the work for the user. This approach does, of course, work, but it does not scale. Hence, the performance modeling service for Extra-P and the standardization efforts for Vc directly aimed at lowering the bar for initial use of the technology. Overall, HPC users in Hesse and Rhineland-Palatine profited greatly from the tool-knowledgeable staff funded through this project. But this project also succeeded in closing a gap in basic HPC education for AHRP users, allowing the development and regular delivery of an introductory HPC course and of shellscripting using bash. Researchers from Rhineland-Palatine also profited from the variety of topics offered in the HiPerCH workshop series. Researchers from this project also participated in activities such as workshops at the International Supercomputing Conference (ISC) on the DFG performance engineering programme, performance monitoring harmonization efforts, or the HPC certification forum. The envisioned overall alignment of HPC activities in Hesse and Rhineland-Palatine has been sidelined by the competition for National High-Performance Computing (NHR) centers. TU Darmstadt partnered with RWTH Aachen in "NHR for Computational Engineering Science" (NHR4CES), while the universities in Frankfurt, Kaiserslautern and Mainz teamed up with the University of Saarland in a "Verbund Süd-West" in a topically complementary fashion. However, it is clear that beyond HPC support activities for high-end systems, such as provided in NHR, there is a need for basic HPC education as provided by HKHLR and the AHRP. This is also demonstrated by the fact that the state of Northrhine-Westphalia established with HPC.NRW an HPC-network that draws, in particular, on experiences of HKHLR.

Publications

 
 

Additional Information

Textvergrößerung und Kontrastanpassung