首页 | 官方网站   微博 | 高级检索  
     


A Python extension for the massively parallel multiphysics simulation framework waLBerla
Authors:Martin Bauer  Florian Schornbaum  Christian Godenschwager  Matthias Markl  Daniela Anderl  Harald Köstler
Affiliation:1. Department of Computer Science 10 System Simulation, Friedrich-Alexander-Universit?t Erlangen-Nürnberg, Erlangen, Germany.martin.bauer@fau.de;3. Department of Computer Science 10 System Simulation, Friedrich-Alexander-Universit?t Erlangen-Nürnberg, Erlangen, Germany.
Abstract:We present a Python extension to the massively parallel HPC simulation toolkit waLBerla. waLBerla is a framework for stencil based algorithms operating on block-structured grids, with the main application field being fluid simulations in complex geometries using the lattice Boltzmann method. Careful performance engineering results in excellent node performance and good scalability to over 400,000 cores. To increase the usability and flexibility of the framework, a Python interface was developed. Python extensions are used at all stages of the simulation pipeline: they simplify and automate scenario setup, evaluation, and plotting. We show how our Python interface outperforms the existing text-file-based configuration mechanism, providing features like automatic nondimensionalization of physical quantities and handling of complex parameter dependencies. Furthermore, Python is used to process and evaluate results while the simulation is running, leading to smaller output files and the possibility to adjust parameters dependent on the current simulation state. C++ data structures are exported such that a seamless interfacing to other numerical Python libraries is possible. The expressive power of Python and the performance of C++ make development of efficient code with low time effort possible.
Keywords:High performance computing  Python  software design  CFD
设为首页 | 免责声明 | 关于勤云 | 加入收藏

Copyright©北京勤云科技发展有限公司    京ICP备09084417号-23

京公网安备 11010802026262号