Skip to Main content Skip to Navigation
Conference papers

Expressing and Applying C++ Code Transformations for the HDF5 API Through a DSL

Abstract : Hierarchical Data Format (HDF5) is a popular binary storage solution in high performance computing (HPC) and other scientific fields. It has bindings for many popular programming languages, including C++, which is widely used in the HPC field. Its C++ API requires mapping of the native C++ data types to types native to the HDF5 API. This task can be error prone, especially when working with complex data structures, which are usually stored using HDF5 compound data types. Due to the lack of a comprehensive reflection mechanism in C++, the mapping code for data manipulation has to be hand-written for each compound type separately. This approach is vulnerable to bugs and mistakes, which can be eliminated by using an automated code generation phase. In this paper we present an approach implemented in the LARA language and supported by the tool Clava, which allows us to automate the generation of the HDF5 data access code for complex data structures in C++.
Complete list of metadata

Cited literature [12 references]  Display  Hide  Download
Contributor : Hal Ifip <>
Submitted on : Tuesday, December 5, 2017 - 2:57:39 PM
Last modification on : Sunday, November 15, 2020 - 7:40:06 PM


Files produced by the author(s)


Distributed under a Creative Commons Attribution 4.0 International License



Martin Golasowski, João Bispo, Jan Martinovič, Kateřina Slaninová, João Cardoso. Expressing and Applying C++ Code Transformations for the HDF5 API Through a DSL. 16th IFIP International Conference on Computer Information Systems and Industrial Management (CISIM), Jun 2017, Bialystok, Poland. pp.303-314, ⟨10.1007/978-3-319-59105-6_26⟩. ⟨hal-01656228⟩



Record views


Files downloads