Skip to main content

Free boundary tokamak plasma equilibrium Grad-Shafranov solver for time evolution

Project description

FreeGS4E: Free boundary Grad-Shafranov solver for time evolution

FreeGS4E is a package based on FreeGS, which calculates plasma equilibria for tokamak fusion experiments by solving the free boundary Grad-Shafranov equation. FreeGS4E is forked from FreeGS 0.6.1 and includes some performance optimisations that may also limit the use cases.

The primary use case for FreeGS4E is to provide a fast equilibrium solver for the FreeGSNKE code. This has resulted in some changes to the FreeGS codebase that mean FreeGS4E is no longer a drop-in replacement for FreeGS. FreeGS4E is also not intended to be a standalone equilibrium solver, and some features have been removed to improve performance. Users looking for a static equilibrium solver should use FreeGS.

Installing

FreeGS4E is available on PyPI and can be installed with pip:

pip install freegs4e

To build from source:

  1. Download this repository
    git clone https://github.com/freegs4e/freegs4e
    
  2. Install with pip
    cd freegs4e
    pip install .
    

Documentation

The FreeGS manual is in the docs subdirectory.

Examples

The Jupyter notebooks contain examples with additional notes

  • MAST-example.ipynb

There are also some Python scripts to run short tests and examples

$ python 01-freeboundary.py

This solves a free boundary problem, specifying the desired location of two X-points. Writes the equilibrium to a G-EQDSK file "lsn.geqdsk"

$ python 02-read-geqdsk.py

Reads in the file "lsn.geqdsk", inferring the coil currents from the plasma boundary and profiles in the G-EQDSK file.

$ python 03-mast.py

Calculates a double-null (CDND) equilibrium for MAST from scratch. Writes solution to G-EQDSK file "mast.geqdsk"

$ python 04-read-mast-geqdsk.py

Reads the file "mast.geqdsk", inferring the coil currents.

$ python 05-fixed-boundary.py 

This example solves a fixed boundary problem, in which the square edges of the domain are fixed. The plasma pressure on axis and plasma current are fixed.

$ python 06-xpoints.py

This demonstrates the coil current control code, finding X-points, and marking core region These routines are used inside the free boundary solver

Contributing

To install FreeGS4E for development, clone the repository and install the package in editable mode with the development dependencies:

git clone https://github.com/freegs4e/freegs4e
cd freegs4e
pip install -e ".[dev]"

Changes to the main branch must be made through pull requests.

If you don't have write access to the repository, pull requests through GitHub forks are welcome.

Pre-commit hooks are used to ensure code quality. To install the pre-commit hooks, run:

pre-commit install

License

Copyright 2024 Nicola C. Amorisco, George K. Holt, Adriano Agnello, and other contributors.

FreeGS4E is licensed under the GNU Lesser General Public License version 3. The license text is included in the file LICENSE.

The license text for FreeGS is reproduced below:

Copyright 2016-2021 Ben Dudson, University of York, and other contributors.
Email: benjamin.dudson@york.ac.uk

This program is free software: you can redistribute it and/or modify
it under the terms of the GNU Lesser 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 Lesser General Public License for more details.

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

References

Versions

0.1.0

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

freegs4e-0.1.1a1.tar.gz (87.5 kB view details)

Uploaded Source

Built Distribution

freegs4e-0.1.1a1-py3-none-any.whl (115.2 kB view details)

Uploaded Python 3

File details

Details for the file freegs4e-0.1.1a1.tar.gz.

File metadata

  • Download URL: freegs4e-0.1.1a1.tar.gz
  • Upload date:
  • Size: 87.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.4

File hashes

Hashes for freegs4e-0.1.1a1.tar.gz
Algorithm Hash digest
SHA256 aae3d43e80821cd10f5ee26c57d8592363400f1c0a5e2a6ad25ac5fdd593dfc4
MD5 387dfadbf6733ff3d58e47b3fcfa9275
BLAKE2b-256 962d9356479247302e5ac6bfd4698d68a9580eeaecd6fc5e36ad36900a2aedce

See more details on using hashes here.

File details

Details for the file freegs4e-0.1.1a1-py3-none-any.whl.

File metadata

  • Download URL: freegs4e-0.1.1a1-py3-none-any.whl
  • Upload date:
  • Size: 115.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.4

File hashes

Hashes for freegs4e-0.1.1a1-py3-none-any.whl
Algorithm Hash digest
SHA256 560e56be65021edc7022c7c695115a48b4ea18355be1147ac557a208e2b9de28
MD5 de1117a53c7225814a31dc2fc72b149a
BLAKE2b-256 438e474b1953678529ba700deb368bc976e6c05633c9759c7f7ced89a65924ab

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page