Migration of a generic multi-physics framework to HPC environments
Rights accessOpen Access
Creating a highly parallelizable code is a challenge specially for distributed memory machines (DMMs). Moreover, algorithms and data structures suitable for these platforms can be very different from the ones used in serial code. For this reason, many programmers in the field prefer to start their own code from scratch. However, for an already existing framework supported by a long-time expertise the idea of transformation becomes attractive in order to reuse the effort done during years of development. In this presentation we explain how a relatively complex framework but with modular structure can be prepared for high performance computing with minimum modification. Kratos Multi-Physics  is an open source generic multi-disciplinary platform for solution of coupled problems consist of fluid, structure, thermal and electromagnetic fields. The parallelization of this framework is performed with objective of enforcing the less possible changes to its different solver modules and encapsulate the changes as much as possible in its common kernel. This objective is achieved thanks to the Kratos design and also innovative way of dealing with data transfers for a multi-disciplinary code. This work is completed by the migration of the framework from the x86 architecture to the Marenostrum Supercomputing platform. The migration has been verified by a set of benchmarks which show high scalability, from which we present the Telescope problem in this paper.
CitationDadvand, P. [et al.]. Migration of a generic multi-physics framework to HPC environments. "Computers and fluids", Juliol 2013, vol. 80, p. 301-309.
- (MC)2 - Grup de Mecànica Computacional en Medis Continus - Articles de revista 
- CAP - Grup de Computació d´Altes Prestacions - Articles de revista 
- Departament de Resistència dels Materials i Estructures en Enginyeria (fins octubre 2015) - Articles de revista 
- Departament d'Arquitectura de Computadors - Articles de revista