trixi-framework / paper-2021-EC_performance

Reproducibility repository for "Efficient implementation of modern entropy stable and kinetic energy preserving discontinuous Galerkin methods for conservation laws"

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Efficient implementation of modern entropy stable and kinetic energy preserving discontinuous Galerkin methods for conservation laws

License: MIT DOI

This repository contains information and code to reproduce the results presented in the article

@article{ranocha2023efficient,
  title={Efficient implementation of modern entropy stable and kinetic energy
         preserving discontinuous {G}alerkin methods for conservation laws},
  author={Ranocha, Hendrik and Schlottke-Lakemper, Michael and Chan, Jesse and
          Rueda-Ram\'{i}rez, Andr{\'e}s M and Winters, Andrew R and
          Hindenlang, Florian and Gassner, Gregor J},
  journal={ACM Transactions on Mathematical Software},
  year={2023},
  month={09},
  doi={10.1145/3625559},
  eprint={2112.10517},
  eprinttype={arxiv},
  eprintclass={cs.MS}
}

If you find these results useful, please cite the article mentioned above. If you use the implementations provided here, please also cite this repository as

@misc{ranocha2021efficientRepro,
  title={Reproducibility repository for
         {E}fficient implementation of modern entropy stable and kinetic energy
         preserving discontinuous {G}alerkin methods for conservation laws},
  author={Ranocha, Hendrik and Schlottke-Lakemper, Michael and Chan, Jesse and
          Rueda-Ram\'{i}rez, Andr{\'e}s M and Winters, Andrew R and
          Hindenlang, Florian and Gassner, Gregor J},
  year={2021},
  month={12},
  howpublished={\url{https://github.com/trixi-framework/paper-2021-EC\_performance}},
  doi={10.5281/zenodo.5792576}
}

Abstract

Many modern discontinuous Galerkin (DG) methods for conservation laws make use of summation by parts operators and flux differencing to achieve kinetic energy preservation or entropy stability. While these techniques increase the robustness of DG methods significantly, they are also computationally more demanding than standard weak form nodal DG methods. We present several implementation techniques to improve the efficiency of flux differencing DG methods that use tensor product quadrilateral or hexahedral elements, in 2D or 3D respectively. Focus is mostly given to CPUs and DG methods for the compressible Euler equations, although these techniques are generally also useful for GPU computing and other physical systems including the compressible Navier-Stokes and magnetohydrodynamics equations. We present results using two open source codes, Trixi.jl written in Julia and FLUXO written in Fortran, to demonstrate that our proposed implementation techniques are applicable to different code bases and programming languages.

Numerical experiments

The numerical experiments presented in the paper use Trixi.jl and FLUXO. To reproduce the numerical experiments using Trixi.jl, you need to install Julia.

The subfolders of this repository contain README.md files with instructions to reproduce the numerical experiments, including postprocessing.

The numerical experiments were carried out using Julia v1.7.0.

Authors

Disclaimer

Everything is provided as is and without warranty. Use at your own risk!

About

Reproducibility repository for "Efficient implementation of modern entropy stable and kinetic energy preserving discontinuous Galerkin methods for conservation laws"

License:MIT License


Languages

Language:Julia 80.0%Language:Shell 10.7%Language:Python 9.3%