Skip to main content

System Dynamics Modeling in Python

Project description

PySD

Coverage Status Anaconda-Server Badge PyPI version PyPI status Py version DOI Docs

Simulating System Dynamics Models in Python

This project is a simple library for running System Dynamics models in python, with the purpose of improving integration of Big Data and Machine Learning into the SD workflow.

The current version needs to run at least Python 3.7.

Resources

See the project documentation for information about:

For standard methods for data analysis with SD models, see the PySD Cookbook, containing (for example):

If you use PySD in any published work, consider citing the PySD Introductory Paper:

Houghton, James; Siegel, Michael. "Advanced data analytics for system dynamics models using PySD." Proceedings of the 33rd International Conference of the System Dynamics Society. 2015.

You can also cite the library using the DOI provided by Zenodo. It is recomendable to specify the used PySD version and its correspondent DOI. If you want to cite all versions you can use the generic DOI for PySD instead:

DOI

Why create a new SD simulation engine?

There are a number of great SD programs out there (Vensim, iThink, AnyLogic, Insight Maker, and others). In order not to waste our effort, or fall victim to the Not-Invented-Here fallacy, we should have a very good reason for starting a new project.

That reason is this: There is a whole world of computational tools being developed in the larger data science community. System dynamicists should directly use the tools that other people are building, instead of replicating their functionality in SD specific software. The best way to do this is to bring specific SD functionality to the domain where those other tools are being developed.

This approach allows SD modelers to take advantage of the most recent developments in data science, and focus our efforts on improving the part of the stack that is unique to System Dynamics modeling.

Cloning this repository

If you'd like to work with this repository directly, you'll need to use a recursive git checkout in order to properly load the test suite (sorry..)

The command should be something like:

git clone --recursive https://github.com/JamesPHoughton/pysd.git

Extensions

You can use PySD in R via the PySD2R package, also available on cran.

Contributors

Many people have contributed to developing this project - by submitting code, bug reports, and advice.

Special thanks to the sdCloud.io development team, who have made great contributions to XMILE support, and for integrating PySD into their cloud-based model simulation environment.

Extra special thanks to @enekomartinmartinez for dramatically pushing forward subscript capabilities (and many other attributes).

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

pysd-3.0.1.tar.gz (103.1 kB view details)

Uploaded Source

Built Distribution

pysd-3.0.1-py3-none-any.whl (120.8 kB view details)

Uploaded Python 3

File details

Details for the file pysd-3.0.1.tar.gz.

File metadata

  • Download URL: pysd-3.0.1.tar.gz
  • Upload date:
  • Size: 103.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.7.13

File hashes

Hashes for pysd-3.0.1.tar.gz
Algorithm Hash digest
SHA256 bc1c0d79c76bc08a54bbcf017a6fb89b00d63f4158d94294abff43054112615b
MD5 0819beab5920857e47fbe75dc4804db9
BLAKE2b-256 33594d2506ab6454a5a5d1e38199f187077ca49fb9245279518f44bd6b66a9db

See more details on using hashes here.

File details

Details for the file pysd-3.0.1-py3-none-any.whl.

File metadata

  • Download URL: pysd-3.0.1-py3-none-any.whl
  • Upload date:
  • Size: 120.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.7.13

File hashes

Hashes for pysd-3.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 7c23eb45c1a5c9c59e2cc5c416551b5d9f786e3081aab8dc8e4529fdc373145c
MD5 2115ff5ea4abc4c237bcd1c7c767c591
BLAKE2b-256 09584cd380cfa57bed3794cce624b6b01c38ec4851ec348dfcbe60139d3b7945

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