Skip to content

Latest commit

 

History

History
72 lines (44 loc) · 4.4 KB

README.md

File metadata and controls

72 lines (44 loc) · 4.4 KB

MEmilio Python Bindings

This package contains Python bindings for the MEmilio C++ library. It enables setting up and running simulations from Python code.

Installation

Use the provided setup.py script to build the bindings and install the package. The script requires CMake and the Scikit-Build packages. Both are installed by the script if not available on the system. The package uses the Pybind11 C++ library to create the bindings.

To install the package, use the command (from the directory containing setup.py)

pip install .

This builds the C++ library and C++ Python extension module and copies everything required to your site-packages.

For developement of code use

pip install -e .[dev]

This command allows you to work on the code without having to reinstall the package after a change. Note that this only works for changes to Python code. If C++ code is modified, the install command has to be repeated every time. The command also installs all additional dependencies required for development and maintenance.

For development, it may be easier to use the alternative command python setup.py <build|install|develop> which provides better configuration and observation of the C++ build process.

All the requirements of the C++ library must be met in order to build and use the python bindings. A virtual environment is recommended.

CMake is executed internally by the setup.py script. All the options provided by the CMake configuration of the C++ library are available when building the Python extension as well. Additionally, the CMake configuration for the bindings provide the following CMake options:

  • MEMILIO_USE_BUNDLED_PYBIND11: ON or OFF, default ON. If ON, downloads Pybind11 automatically from a repository during CMake configuration. If OFF, Pybind11 needs to be installed on the system.

When building the bindings, CMake options can be set by appending them to the install command, e.g.

python setup.py install -- -DCMAKE_BUILD_TYPE=Debug -DMEMILIO_USE_BUNDLED_PYBIND11=OFF

Alternatively, the CMakeCache.txt in the directory created by Scikit-Build can be edited to set the options.

Stubs

A stub file is a file containing a skeleton of the public interface of that Python module including classes, variables, functions and their types. They help by enabling autocompletes and type annotations. pybind11-stubgen is used to generate the stub files for the MEmilio Python Bindings and provide them as a separate stubs-only package.

For installing stubs you first need to install our package memilio.simulation and the external dependency pybind11-stubgen for your python interpreter. Then run generate_stubs.py to generate the stubs-only package and install it as memilio-stubs, e.g. from the current folder

python ./tools/generate_stubs.py

Usage

The package provides the following modules:

  • memilio.simulation: core simulation framework and utilities, corresponds to the framework in cpp/memilio.
  • memilio.simulation.osir: ODE SIR model and simulation with demographic resolution, corresponds to the model in cpp/models/ode_sir.
  • memilio.simulation.oseir: ODE SEIR model and simulation with demographic resolution, corresponds to the model in cpp/models/ode_seir.
  • memilio.simulation.osecir: ODE SECIHURD model and simulation with demographic and geographic resolution, corresponds to the model in cpp/models/ode_secir.
  • memilio.simulation.osecirvvs: Extended ODE SECIHURD model to include vaccinations and multi-layered immunity, among other enhancements, with the ability to integrate new disease variants. Simulation includes demographic and geographic resolution, corresponds to the model in cpp/models/ode_secirvvs. memilio.simulation.abm: Agent based model and simulation, corresponds to the model in cpp/models/abm (python model is incomplete and work in progress).

Detailed documentation under construction. See the scripts in the examples directory for more information.

Testing

The package provides a test suite in memilio/simulation_test. To run the tests, simply run the following command

python -m unittest

Note that these tests do not cover every case of the C++ library, they are only intended to test the binding code. To verify correctness of the C++ library itself, build and run the C++ unit tests.