https://github.com/boutproject/hermes-3

Multifluid drift reduced fluid model

https://github.com/boutproject/hermes-3

Science Score: 49.0%

This score indicates how likely this project is to be science-related based on various indicators:

  • CITATION.cff file
  • codemeta.json file
    Found codemeta.json file
  • .zenodo.json file
    Found .zenodo.json file
  • DOI references
    Found 22 DOI reference(s) in README
  • Academic publication links
    Links to: arxiv.org
  • Academic email domains
  • Institutional organization owner
  • JOSS paper metadata
  • Scientific vocabulary similarity
    Low similarity (16.5%) to scientific vocabulary
Last synced: 6 months ago · JSON representation

Repository

Multifluid drift reduced fluid model

Basic Info
  • Host: GitHub
  • Owner: boutproject
  • License: gpl-3.0
  • Language: C++
  • Default Branch: master
  • Size: 12 MB
Statistics
  • Stars: 47
  • Watchers: 18
  • Forks: 20
  • Open Issues: 94
  • Releases: 6
Created almost 6 years ago · Last pushed 6 months ago
Metadata Files
Readme License

README.md

Hermes-3

License Build status

Hermes-3 is a multifluid plasma simulation model for transport and turbulence in the edge of magnetically confined plasmas, such as tokamaks. It is built on the BOUT++ framework, and uses a system of reusable components to build models at runtime based on input configuration, in 1D, 2D or 3D curvlinear coordinates. The manual is here on Readthedocs.

Post-processing Hermes-3 is made easy by using the xHermes Python library. xHermes is built on top of xBOUT and Xarray and automatically accounts for the normalisation of Hermes-3 parameters, as well as providing access to many useful xBOUT post-processing functions. Many of these are showcased in the xBOUT examples.

Note Under development, research code, may change without notice.

License

Hermes-3 is released under the GPL-3 license. See LICENSE and NOTICE for details. If you are using Hermes-3, please cite the relevant papers.

All new contributions must be made under the GPLv3 license.

LLNL-CODE-845139

Copyright Hermes-3 contributors 2017-2025
          email: dudson2@llnl.gov

This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.

This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.

You should have received a copy of the GNU General Public License
along with this program.  If not, see <http://www.gnu.org/licenses/>.

Installing and testing

Only CMake is supported for building Hermes-3 and running the tests. During configuration BOUT++ will be automatically downloaded as a submodule, together with some dependencies. NetCDF and FFTW are assumed to be installed already; optional dependencies include SUNDIALS and PETSc. The recommended way to build Hermes-3 links to the SUNDIALS library.

1) Configure with cmake, downloading and linking to SUNDIALS:

$ cmake . -B build -DBOUT_DOWNLOAD_SUNDIALS=ON

2) Build, compiling Hermes-3 and all dependencies:

$ cmake --build build

3) Run the unit and integrated tests to check that everything is working:

$ cd build
$ ctest

Note that the integrated tests require MPI, and so may not run on the head nodes of many computing clusters.

The CMake configuration can be customised: See the BOUT++ documentation for examples of using cmake arguments, or edit the compile options interactively before building:

$ ccmake . -B build

If you have already installed BOUT++ and want to use that rather than configure and build BOUT++ again, set HERMES_BUILD_BOUT to OFF and pass CMake the path to the BOUT++ build directory e.g.

$ cmake . -B build -DHERMES_BUILD_BOUT=OFF -DCMAKE_PREFIX_PATH=$HOME/BOUT-dev/build

Note that Hermes-3 currently requires a specific version of BOUT++: https://github.com/boutproject/BOUT-dev/commit/7152948fbde505f6708d5ca4a9c21e5828d1e0a1

Examples

There are example inputs under the examples/ subdirectory. A simple example is a 2D (drift plane) simulation of a plasma blob/filament, similar to the BOUT++ blob2d example:

./hermes-3 -d examples/blob2d

See the examples for more complicated cases.

Publications

Owner

  • Name: boutproject
  • Login: boutproject
  • Kind: organization

GitHub Events

Total
  • Create event: 39
  • Commit comment event: 2
  • Issues event: 44
  • Watch event: 5
  • Delete event: 33
  • Issue comment event: 88
  • Push event: 194
  • Pull request review event: 43
  • Pull request event: 83
  • Pull request review comment event: 15
Last Year
  • Create event: 39
  • Commit comment event: 2
  • Issues event: 44
  • Watch event: 5
  • Delete event: 33
  • Issue comment event: 88
  • Push event: 194
  • Pull request review event: 43
  • Pull request event: 83
  • Pull request review comment event: 15

Issues and Pull Requests

Last synced: 6 months ago

All Time
  • Total issues: 32
  • Total pull requests: 55
  • Average time to close issues: 5 months
  • Average time to close pull requests: 3 months
  • Total issue authors: 9
  • Total pull request authors: 9
  • Average comments per issue: 0.78
  • Average comments per pull request: 0.58
  • Merged pull requests: 29
  • Bot issues: 0
  • Bot pull requests: 0
Past Year
  • Issues: 29
  • Pull requests: 51
  • Average time to close issues: about 2 months
  • Average time to close pull requests: 18 days
  • Issue authors: 9
  • Pull request authors: 9
  • Average comments per issue: 0.55
  • Average comments per pull request: 0.27
  • Merged pull requests: 25
  • Bot issues: 0
  • Bot pull requests: 0
Top Authors
Issue Authors
  • mikekryjak (17)
  • cmacmackin (3)
  • PoloidalLloyd (2)
  • tbody-cfs (2)
  • mrhardman (2)
  • oparry-ukaea (1)
  • Vandoo (1)
  • ZedThree (1)
Pull Request Authors
  • mikekryjak (15)
  • bendudson (12)
  • tbody-cfs (11)
  • oparry-ukaea (4)
  • mrhardman (2)
  • dschwoerer (2)
  • ZedThree (2)
  • tashtonkey (1)
  • bshanahan (1)
Top Labels
Issue Labels
documentation (9) enhancement (5) bug (4) refactor (2) compilation (2) post-processing (2) tests (1) confusing (1)
Pull Request Labels
documentation (4) enhancement (2) bug (1) post-processing (1) boundary conditions (1)

Dependencies

docs/requirements.txt pypi
  • breathe *
.github/workflows/tests.yml actions
  • actions/checkout v2 composite