freeqdsk


Namefreeqdsk JSON
Version 0.5.1 PyPI version JSON
download
home_pageNone
SummaryGEQDSK and AEQDSK tokamak equilibrium file reader/writer
upload_time2025-01-02 09:40:33
maintainerNone
docs_urlNone
authorBen Dudson, Peter Hill, Liam Pattinson
requires_python>=3.9
licenseCopyright 2016 Ben Dudson Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
keywords geqdsk aeqdsk plasma equilibrium
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # FreeQDSK

[![License](https://img.shields.io/badge/license-MIT-blue.svg)](https://img.shields.io/badge/license-MIT-blue.svg)
[![py3comp](https://img.shields.io/badge/py3-compatible-brightgreen.svg)](https://img.shields.io/badge/py3-compatible-brightgreen.svg)

Read and write G-EQDSK, A-EQDSK, and P-EQDSK file formats, which are used to describe
the tokamak fusion devices.

It has more features than other implementations, including aeqdsk and peqdsk formats,
support for COCOS numbers != 1, some customisation of the header format.

It aims to be a well maintained community package, allowing to replace custom 
implementations by a feature complete, freely available implementation.

## Installation

To install, you may need to update `pip` to the latest version:

```bash
$ python3 -m pip install --upgrade pip
```

You can then install using:

```bash
$ python3 -m pip install .
```

To run tests:

```bash
$ python3 -m install .[tests]
$ pytest -v
```

To build the docs:

```bash
$ python3 -m install .[docs]
$ cd docs
$ make html
```

## Usage

A G-EQDSK file may be read using the `geqdsk.read` function:

```python
from freeqdsk import geqdsk

with open(filename, "r") as f:
    data = geqdsk.read(f)
```

The result is a dict containing data from the G-EQDSK file. To write a file:

```python
with open(filename, "w") as f:
    geqdsk.write(data, f)
```

Similarly, for A-EQDSK files:

```python
from freeqdsk import aeqdsk

with open(filename, "r") as f:
    data = aeqdsk.read(f)

with open(filename, "w") as f:
    aeqdsk.write(data, f)
```

And again for P-EQDSK files:

```python
from freeqdsk import peqdsk

with open(filename, "r") as f:
    data = peqdsk.read(f)

with open(filename, "w") as f:
    peqdsk.write(data, f)
```

            

Raw data

            {
    "_id": null,
    "home_page": null,
    "name": "freeqdsk",
    "maintainer": null,
    "docs_url": null,
    "requires_python": ">=3.9",
    "maintainer_email": null,
    "keywords": "GEQDSK, AEQDSK, plasma, equilibrium",
    "author": "Ben Dudson, Peter Hill, Liam Pattinson",
    "author_email": null,
    "download_url": "https://files.pythonhosted.org/packages/21/5e/8d9f7ba386b81580fe7d76b57001db4919666ef76cac50758e3b2a6bd643/freeqdsk-0.5.1.tar.gz",
    "platform": null,
    "description": "# FreeQDSK\n\n[![License](https://img.shields.io/badge/license-MIT-blue.svg)](https://img.shields.io/badge/license-MIT-blue.svg)\n[![py3comp](https://img.shields.io/badge/py3-compatible-brightgreen.svg)](https://img.shields.io/badge/py3-compatible-brightgreen.svg)\n\nRead and write G-EQDSK, A-EQDSK, and P-EQDSK file formats, which are used to describe\nthe tokamak fusion devices.\n\nIt has more features than other implementations, including aeqdsk and peqdsk formats,\nsupport for COCOS numbers != 1, some customisation of the header format.\n\nIt aims to be a well maintained community package, allowing to replace custom \nimplementations by a feature complete, freely available implementation.\n\n## Installation\n\nTo install, you may need to update `pip` to the latest version:\n\n```bash\n$ python3 -m pip install --upgrade pip\n```\n\nYou can then install using:\n\n```bash\n$ python3 -m pip install .\n```\n\nTo run tests:\n\n```bash\n$ python3 -m install .[tests]\n$ pytest -v\n```\n\nTo build the docs:\n\n```bash\n$ python3 -m install .[docs]\n$ cd docs\n$ make html\n```\n\n## Usage\n\nA G-EQDSK file may be read using the `geqdsk.read` function:\n\n```python\nfrom freeqdsk import geqdsk\n\nwith open(filename, \"r\") as f:\n    data = geqdsk.read(f)\n```\n\nThe result is a dict containing data from the G-EQDSK file. To write a file:\n\n```python\nwith open(filename, \"w\") as f:\n    geqdsk.write(data, f)\n```\n\nSimilarly, for A-EQDSK files:\n\n```python\nfrom freeqdsk import aeqdsk\n\nwith open(filename, \"r\") as f:\n    data = aeqdsk.read(f)\n\nwith open(filename, \"w\") as f:\n    aeqdsk.write(data, f)\n```\n\nAnd again for P-EQDSK files:\n\n```python\nfrom freeqdsk import peqdsk\n\nwith open(filename, \"r\") as f:\n    data = peqdsk.read(f)\n\nwith open(filename, \"w\") as f:\n    peqdsk.write(data, f)\n```\n",
    "bugtrack_url": null,
    "license": "Copyright 2016 Ben Dudson  Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the \"Software\"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:  The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.  THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. ",
    "summary": "GEQDSK and AEQDSK tokamak equilibrium file reader/writer",
    "version": "0.5.1",
    "project_urls": {
        "Source": "https://github.com/freegs-plasma/FreeQDSK",
        "Tracker": "https://github.com/freegs-plasma/FreeQDSK/issues"
    },
    "split_keywords": [
        "geqdsk",
        " aeqdsk",
        " plasma",
        " equilibrium"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "1f091f1a876d1a611818cfb814556f2dd1563a08a0f50dabadd0f57038233a47",
                "md5": "ece0c494eb6be3b86cd2cb1545b47933",
                "sha256": "41d3375b106ecf343f8e61f433dcb8050272ec639b2d047ec8343580de7518e1"
            },
            "downloads": -1,
            "filename": "freeqdsk-0.5.1-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "ece0c494eb6be3b86cd2cb1545b47933",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.9",
            "size": 25718,
            "upload_time": "2025-01-02T09:40:31",
            "upload_time_iso_8601": "2025-01-02T09:40:31.380243Z",
            "url": "https://files.pythonhosted.org/packages/1f/09/1f1a876d1a611818cfb814556f2dd1563a08a0f50dabadd0f57038233a47/freeqdsk-0.5.1-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "215e8d9f7ba386b81580fe7d76b57001db4919666ef76cac50758e3b2a6bd643",
                "md5": "695220b2377fe0b5830c1a472463738a",
                "sha256": "58192ebbd5115b38185b3b23d7c50525d63bf6cdd4531ab967cc05b67d2ed13e"
            },
            "downloads": -1,
            "filename": "freeqdsk-0.5.1.tar.gz",
            "has_sig": false,
            "md5_digest": "695220b2377fe0b5830c1a472463738a",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.9",
            "size": 201517,
            "upload_time": "2025-01-02T09:40:33",
            "upload_time_iso_8601": "2025-01-02T09:40:33.480108Z",
            "url": "https://files.pythonhosted.org/packages/21/5e/8d9f7ba386b81580fe7d76b57001db4919666ef76cac50758e3b2a6bd643/freeqdsk-0.5.1.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2025-01-02 09:40:33",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "freegs-plasma",
    "github_project": "FreeQDSK",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "lcname": "freeqdsk"
}
        
Elapsed time: 0.88342s