Hermes plasma edge simulation model. Uses BOUT++ framework, adds finite volume operators and neutral gas models.
This is Hermes-3, a hot ion multifluid drift-reduced model. The manual is here on Readthedocs.
Note Currently under development, not yet fully working, and may change without notice.
Author: Ben Dudson, University of York [email protected]
Released under the GPL license
Full text of the license is in the file LICENSE. If you are using Hermes-3, please cite the relevant papers.
Copyright B.Dudson, J.Leddy, University of York, September 2017-2020
email: [email protected]
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/>.
This version of Hermes-3 works with the latest next
branch of
BOUT++. Only CMake is currently supported for building Hermes-3
and running the tests.
First configure BOUT++ and Hermes-3. To use the default options and minimal dependencies just run:
$ cmake . -B build
Alternatively the CMake build can be customised: See the BOUT++
documentation
for examples of using cmake
arguments, or edit the compile options
interactively before building:
$ ccmake . -B build
During configuration BOUT++ will be automatically downloaded as a submodule, together with some dependencies (NetCDF and FFTW are assumed to be installed already, along with optional dependencies like SUNDIALS and PETSc if they are requested).
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
Once configured, run build to compile BOUT++ and then Hermes-3:
$ cmake --build build
Then run the unit and integrated tests to check that everything is working:
$ cd build
$ ctest
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.