Skip to main content

Python Battery Mathematical Modelling.

Project description

PyBaMM

Build readthedocs codecov Open In Colab black_code_style

PyBaMM (Python Battery Mathematical Modelling) solves physics-based electrochemical DAE models by using state-of-the-art automatic differentiation and numerical solvers. The Doyle-Fuller-Newman model can be solved in under 0.1 seconds, while the reduced-order Single Particle Model and Single Particle Model with electrolyte can be solved in just a few milliseconds. Additional physics can easily be included such as thermal effects, fast particle diffusion, 3D effects, and more. All models are implemented in a flexible manner, and a wide range of models and parameter sets (NCA, NMC, LiCoO2, ...) are available. There is also functionality to simulate any set of experimental instructions, such as CCCV or GITT, or specify drive cycles.

How do I use PyBaMM?

The easiest way to use PyBaMM is to run a 1C constant-current discharge with a model of your choice with all the default settings:

import pybamm
model = pybamm.lithium_ion.DFN()  # Doyle-Fuller-Newman model
sim = pybamm.Simulation(model)
sim.solve([0, 3600])  # solve for 1 hour
sim.plot()

or simulate an experiment such as CCCV:

import pybamm
experiment = pybamm.Experiment(
    [
        "Discharge at C/10 for 10 hours or until 3.3 V",
        "Rest for 1 hour",
        "Charge at 1 A until 4.1 V",
        "Hold at 4.1 V until 50 mA",
        "Rest for 1 hour",
    ]
    * 3,
)
model = pybamm.lithium_ion.DFN()
sim = pybamm.Simulation(model, experiment=experiment, solver=pybamm.CasadiSolver())
sim.solve()
sim.plot()

However, much greater customisation is available. It is possible to change the physics, parameter values, geometry, submesh type, number of submesh points, methods for spatial discretisation and solver for integration (see DFN script or notebook).

For new users we recommend the Getting Started guides. These are intended to be very simple step-by-step guides to show the basic functionality of PyBaMM, and can either be downloaded and used locally, or used online through Google Colab.

Further details can be found in a number of detailed examples, hosted here on github. In addition, there is a full API documentation, hosted on Read The Docs. Additional supporting material can be found here.

For further examples, see the list of repositories that use PyBaMM here

How can I install PyBaMM?

PyBaMM is available on GNU/Linux, MacOS and Windows. We strongly recommend to install PyBaMM within a python virtual environment, in order not to alter any distribution python files. For instructions on how to create a virtual environment for PyBaMM, see the documentation.

Using pip

pip install pybamm

Using conda

PyBaMM is available as a conda package through the conda-forge channel.

conda install -c conda-forge pybamm

Optional solvers

On GNU/Linux and MacOS, an optional scikits.odes-based solver is available, see the documentation.

Citing PyBaMM

If you use PyBaMM in your work, please cite our paper

Sulzer, V., Marquis, S. G., Timms, R., Robinson, M., & Chapman, S. J. (2020). Python Battery Mathematical Modelling (PyBaMM). ECSarXiv. February, 7.

You can use the bibtex

@article{sulzer2020python,
  title={Python Battery Mathematical Modelling (PyBaMM)},
  author={Sulzer, Valentin and Marquis, Scott G and Timms, Robert and Robinson, Martin and Chapman, S Jon},
  journal={ECSarXiv. February},
  volume={7},
  year={2020}
}

We would be grateful if you could also cite the relevant papers. These will change depending on what models and solvers you use. To find out which papers you should cite, add the line

pybamm.print_citations()

to the end of your script. This will print bibtex information to the terminal; passing a filename to print_citations will print the bibtex information to the specified file instead. A list of all citations can also be found in the citations file. In particular, PyBaMM relies heavily on CasADi. See CONTRIBUTING.md for information on how to add your own citations when you contribute.

How can I contribute to PyBaMM?

If you'd like to help us develop PyBaMM by adding new methods, writing documentation, or fixing embarrassing bugs, please have a look at these guidelines first.

Licensing

PyBaMM is fully open source. For more information about its license, see LICENSE.

Project details


Release history Release notifications | RSS feed

This version

0.2.4

Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

pybamm-0.2.4-py3-none-any.whl (520.7 kB view details)

Uploaded Python 3

pybamm-0.2.4-cp38-cp38-macosx_10_15_x86_64.whl (694.7 kB view details)

Uploaded CPython 3.8macOS 10.15+ x86-64

pybamm-0.2.4-cp37-cp37m-manylinux2010_x86_64.whl (1.0 MB view details)

Uploaded CPython 3.7mmanylinux: glibc 2.12+ x86-64

pybamm-0.2.4-cp37-cp37m-macosx_10_15_x86_64.whl (694.3 kB view details)

Uploaded CPython 3.7mmacOS 10.15+ x86-64

pybamm-0.2.4-cp36-cp36m-manylinux2010_x86_64.whl (1.0 MB view details)

Uploaded CPython 3.6mmanylinux: glibc 2.12+ x86-64

pybamm-0.2.4-cp36-cp36m-macosx_10_15_x86_64.whl (694.1 kB view details)

Uploaded CPython 3.6mmacOS 10.15+ x86-64

File details

Details for the file pybamm-0.2.4-py3-none-any.whl.

File metadata

  • Download URL: pybamm-0.2.4-py3-none-any.whl
  • Upload date:
  • Size: 520.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/49.3.1 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.8.5

File hashes

Hashes for pybamm-0.2.4-py3-none-any.whl
Algorithm Hash digest
SHA256 ba85cc88a01cbf66fa6ebda0b275dadeb9a1d74caa686c5a34578ce243bc4269
MD5 fafdf9ae83163a4b0b53ab9393d9fd7e
BLAKE2b-256 fd339a091d0b2076f1e929fdadd83e6e14b6e6638722d62350deb7585ebd9033

See more details on using hashes here.

File details

Details for the file pybamm-0.2.4-cp38-cp38-macosx_10_15_x86_64.whl.

File metadata

  • Download URL: pybamm-0.2.4-cp38-cp38-macosx_10_15_x86_64.whl
  • Upload date:
  • Size: 694.7 kB
  • Tags: CPython 3.8, macOS 10.15+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/49.3.1 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.8.5

File hashes

Hashes for pybamm-0.2.4-cp38-cp38-macosx_10_15_x86_64.whl
Algorithm Hash digest
SHA256 66fa1d3a2fd0fe4f842b5bcf0eaf41cde29a27cc1ade08cfc871ac09b42142db
MD5 ecae414cc53a8d72e3c77cfdbe77564a
BLAKE2b-256 bcd31ff3ecf7c2efa7e94426f2b6345591761bfd26c5e8fb12c0f5c09d7061f2

See more details on using hashes here.

File details

Details for the file pybamm-0.2.4-cp37-cp37m-manylinux2010_x86_64.whl.

File metadata

  • Download URL: pybamm-0.2.4-cp37-cp37m-manylinux2010_x86_64.whl
  • Upload date:
  • Size: 1.0 MB
  • Tags: CPython 3.7m, manylinux: glibc 2.12+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/49.3.1 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.8.5

File hashes

Hashes for pybamm-0.2.4-cp37-cp37m-manylinux2010_x86_64.whl
Algorithm Hash digest
SHA256 da320010bed2eb3e7128494b47554530f98456696ba4c66e391873f3cd8c3aab
MD5 0aa8634356cd42876d27a115c49f1148
BLAKE2b-256 a2de49fd213ab3993915ee4eb0609dbff568325730fd63d34d69bcbabdc716ba

See more details on using hashes here.

File details

Details for the file pybamm-0.2.4-cp37-cp37m-macosx_10_15_x86_64.whl.

File metadata

  • Download URL: pybamm-0.2.4-cp37-cp37m-macosx_10_15_x86_64.whl
  • Upload date:
  • Size: 694.3 kB
  • Tags: CPython 3.7m, macOS 10.15+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/49.3.1 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.8.5

File hashes

Hashes for pybamm-0.2.4-cp37-cp37m-macosx_10_15_x86_64.whl
Algorithm Hash digest
SHA256 d881f4a4604b6f5d1adac0b1ff2f10d954e3094af90c8894fec6a488f6a3ffc7
MD5 46f978561f9085be74e3c339bc46acea
BLAKE2b-256 3c7f84dd0cc54ec72f46c56c32f9e70e811a4b3fbe1016b2f46bec30b012f8e7

See more details on using hashes here.

File details

Details for the file pybamm-0.2.4-cp36-cp36m-manylinux2010_x86_64.whl.

File metadata

  • Download URL: pybamm-0.2.4-cp36-cp36m-manylinux2010_x86_64.whl
  • Upload date:
  • Size: 1.0 MB
  • Tags: CPython 3.6m, manylinux: glibc 2.12+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/49.3.1 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.8.5

File hashes

Hashes for pybamm-0.2.4-cp36-cp36m-manylinux2010_x86_64.whl
Algorithm Hash digest
SHA256 66b341ca7cbb5dbb8ae01f7c31b257908720ab850c7a36ce3d006357c5e91f54
MD5 1c863d52f9d82f23c3c8f00bff3a1674
BLAKE2b-256 2b7b379f8ae9a397eb72237cdb4551d72951dc513e5291ab6e3497d02f71ffde

See more details on using hashes here.

File details

Details for the file pybamm-0.2.4-cp36-cp36m-macosx_10_15_x86_64.whl.

File metadata

  • Download URL: pybamm-0.2.4-cp36-cp36m-macosx_10_15_x86_64.whl
  • Upload date:
  • Size: 694.1 kB
  • Tags: CPython 3.6m, macOS 10.15+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/49.3.1 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.8.5

File hashes

Hashes for pybamm-0.2.4-cp36-cp36m-macosx_10_15_x86_64.whl
Algorithm Hash digest
SHA256 71f72521ebd8aa846c1e4b5ff638629a106e533abd5c618a68e9ec5d0f2cda78
MD5 9e9c610958e76ced83b9c93781bc13d1
BLAKE2b-256 e93744d08b0ec5b281c0d127da67ec917b4284e59a483a438b07a231e5fd6c86

See more details on using hashes here.

Supported by

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