Skip to main content

A lightweight computational physics framework, which implements a "Simulation, PhysicsModule, ComputeTool" class hierarchy.

Project description

turboPy

DOI PyPI version Documentation Status Build Status codecov GitHub

A lightweight computational physics framework, based on the organization of turboWAVE. Implements a "Simulation, PhysicsModule, ComputeTool" class hierarchy.

Motivation

Computational physics problems often have a common set of aspects to them that any particular numerical code will have to address. Because these aspects are common to many problems, having a framework already designed and ready to use will not only speed the development of new codes, but also enhance compatibility between codes.

Some of the most common aspects of computational physics problems are: a grid, a clock which tracks the flow of the simulation, and a set of models describing the dynamics of various quantities on the grid. Having a framework that could deal with these basic aspects of the simulation in a common way could provide great value to computational scientists by solving various numerical and class design issues that routinely arise.

This paper describes the newly developed computational framework that we have built for rapidly prototyping new physics codes. This framework, called turboPy, is a lightweight physics modeling framework based on the design of the particle-in-cell code turboWAVE. It implements a class (called Simulation) which drives the simulation and manages communication between physics modules, a class (called PhysicsModule) which handles the details of the dynamics of the various parts of the problem, and some additional classes such as a Grid class and a Diagnostic class to handle various ancillary issues that commonly arise.

More Resources

Install turboPy

  • Install: pip install turbopy

turboPy development environment

  • Create a conda environment for turboPy: conda env create -f environment.yml
  • Activate: conda activate turbopy
  • Install turboPy in editable mode (i.e. setuptools "develop mode") if you are modifying turboPy itself: pip install -e .
  • Run tests: pytest

If using pylint (which you should!) add variable-rgx=[a-z0-9_]{1,30}$ to your .pylintrc file to allow single character variable names.

Merge requests are encouraged!

Attribution

If you use turboPy for a project, first, you're awesome, thanks! :tada:

Also, we would appreciate it if you would cite turboPy. There are a few ways you can cite this project.

Cite a specific version

If you used turboPy, please cite the specific version of the code that you used. We use Zenodo to create DOIs and archive our code. You can find the DOI for the version that you used on our Zenodo page

For example, a citation for version v2023.06.09 should look like this:

A. S. Richardson, P. E. Adamson, G. Tang, A. Ostenfeld, G. T. Morgan, C. G. Sun, D. J. Watkins, O. S. Grannis, K. L. Phlips, and S. B. Swanekamp. (2023, June 09). NRL-Plasma-Physics-Division/turbopy: v2023.06.09 (Version v2023.06.09). Zenodo. https://doi.org/10.5281/zenodo.4088189

While bibtex styles vary, the above output can be created by an entry something like this:

@software{turbopy_v2023.06.09,
	author = {A. S. Richardson and P. E. Adamson and G. Tang and A. Ostenfeld and G. T. Morgan and C. G. Sun and D. J. Watkins and O. S. Grannis and K. L. Phlips and S. B. Swanekamp},
	doi = {10.5281/zenodo.4088189},
	month = {June 08},
	publisher = {Zenodo},
	title = {{NRL-Plasma-Physics-Division/turbopy: v2023.06.09}},
	url = {https://doi.org/10.5281/zenodo.4088189},
	version = {v2023.06.09},
	year = 2023,
}

Note that the author names above have been lightly edited to put them in a standard format. The Zenodo page for a specific version of the code will try to infer author names from the GitHub accounts of contributers. That author list would be fine, too, espcially as additional GitHub users contribute to turboPy.

Cite the turboPy project

If you are refering to the turboPy project as a whole, rather than a specific version of the code, you also have the option of using the Zenodo concept DOI for turboPy. This DOI always resolves to the latest version of the code.

The concept DOI for turboPy is 10.5281/zenodo.3973692.

An example citation and bibtex entry for the concept DOI would look something like this:

The turboPy Development Team. NRL-Plasma-Physics-Division/turbopy. Zenodo. https://doi.org/10.5281/zenodo.3973692

@software{turbopy_project,
	author = {The turboPy Development Team},
	doi = {10.5281/zenodo.3973692},
	publisher = {Zenodo},
	title = {{NRL-Plasma-Physics-Division/turbopy}},
	url = {https://doi.org/10.5281/zenodo.3973692},
	year = 2023,
}

Cite the turboPy paper

If you are looking for a paper to cite, rather than source code, this is the reference to use. This citation is appropriate when you are discussing the functionality of turboPy.

A. S. Richardson, D. F. Gordon, S. B. Swanekamp, I. M. Rittersdorf, P. E. Adamson, O. S. Grannis, G. T. Morgan, A. Ostenfeld, K. L. Phlips, C. G. Sun, G. Tang, and D. J. Watkins. TurboPy: A lightweight python framework for computational physics. Computer Physics Communications, 258:107607, January 2021. https://doi.org/10.1016/j.cpc.2020.107607

@article{RICHARDSON2020107607,
	author = {A. S. Richardson and D. F. Gordon and S. B. Swanekamp and I. M. Rittersdorf and P. E. Adamson and O. S. Grannis and G. T. Morgan and A. Ostenfeld and K. L. Phlips and C. G. Sun and G. Tang and D. J. Watkins},
	doi = {10.1016/j.cpc.2020.107607},
	issn = {0010-4655},
	journal = {Computer Physics Communications},
	keywords = {Framework, Physics, Computational physics, Python, Dynamic factory pattern, Resource sharing},
	month = {January},
	pages = {107607},
	title = {{TurboPy}: A lightweight python framework for computational physics},
	url = {http://www.sciencedirect.com/science/article/pii/S0010465520302897},
	volume = {258},
	year = {2021},
}

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

turbopy-2023.6.9.tar.gz (37.2 kB view details)

Uploaded Source

Built Distribution

turbopy-2023.6.9-py3-none-any.whl (38.1 kB view details)

Uploaded Python 3

File details

Details for the file turbopy-2023.6.9.tar.gz.

File metadata

  • Download URL: turbopy-2023.6.9.tar.gz
  • Upload date:
  • Size: 37.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.3

File hashes

Hashes for turbopy-2023.6.9.tar.gz
Algorithm Hash digest
SHA256 b3db3d51d342059812f2cf61b6f46c24dc49c4709f6ef58b1e2d14af59c74f37
MD5 e2c0342e562452ae0e7111cfc995bf39
BLAKE2b-256 d1100d3f91c5c25012ea220d868c80f2531bf53de387502868f69d0451077764

See more details on using hashes here.

File details

Details for the file turbopy-2023.6.9-py3-none-any.whl.

File metadata

  • Download URL: turbopy-2023.6.9-py3-none-any.whl
  • Upload date:
  • Size: 38.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.3

File hashes

Hashes for turbopy-2023.6.9-py3-none-any.whl
Algorithm Hash digest
SHA256 0f8c8085f3e6615eb6af5e92c917a46fb2459489382daec1f470bdef79de8a88
MD5 7d2b732bfd7d32066607a2d7cff273c9
BLAKE2b-256 58761f609589f1ad2b8d9411ee5b11352dfade7170bb5e9c9dd059540b7ecc93

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