Conference Papers Year : 2017

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++.
Fichier principal
Vignette du fichier
448933_1_En_26_Chapter.pdf (1.3 Mo) Télécharger le fichier
Origin Files produced by the author(s)
Loading...

Dates and versions

hal-01656228 , version 1 (05-12-2017)

Licence

Identifiers

Cite

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⟩
154 View
170 Download

Altmetric

Share

More