Skip to main content

COVID-19 agent-based simulator

Project description

Covasim is a stochastic agent-based simulator designed to be used for COVID-19 (novel coronavirus, SARS-CoV-2) epidemic analyses. These include projections of indicators such as numbers of infections and peak hospital demand. Covasim can also be used to explore the potential impact of different interventions, including social distancing, school closures, testing, contact tracing, and quarantine.

Questions or comments can be directed to covasim@idmod.org, or on this project’s GitHub page. Full information about Covasim is provided in the documentation.

Requirements

Python >=3.6 (64-bit). (Note: Python 2 is not supported.)

We also recommend, but do not require, using Python virtual environments. For more information, see documentation for venv or Anaconda.

Quick start guide

Install with pip install covasim. If everything is working, the following Python commands should bring up a plot:

import covasim as cv
sim = cv.Sim()
sim.run()
sim.plot()

Detailed installation instructions

  1. Clone a copy of the repository. If you intend to make changes to the code, we recommend that you fork it first.

  2. (Optional) Create and activate a virtual environment.

  3. Navigate to the root of the repository and install the Covasim Python package using one of the following options:

    • To install with web app support (recommended):

      python setup.py develop
    • To install as a standalone Python model without webapp support:

      python setup.py develop nowebapp
    • To install Covasim and optional dependencies (be aware this may fail since it relies on private packages), enter:

      python setup.py develop full

    The module should then be importable via import covasim.

Usage examples

There are several examples in the examples directory. These can be run as follows:

  • python examples/simple.py

    This example creates a figure using default parameter values.

  • python examples/run_sim.py

    This shows a slightly more detailed example, including creating an intervention and saving to disk.

  • python examples/run_scenarios.py

    This shows a more complex example, including running an intervention scenario, plotting uncertainty, and performing a health systems analysis.

Module structure

All core model code is located in the covasim subfolder; standard usage is import covasim as cv. The other subfolders, cruise_ship and webapp, are also described below.

The model consists of two core classes: the Person class (which contains information on health state), and the Sim class (which contains methods for running, calculating results, plotting, etc.).

The structure of the covasim folder is as follows:

  • base.py: The ParsObj class, plus basic methods of the BaseSim class, and associated functions.

  • defaults.py: The default colors, plots, etc. used by Covasim.

  • interventions.py: The Intervention class, for adding interventions and dynamically modifying parameters.

  • misc.py: Miscellaneous helper functions.

  • parameters.py: Functions for creating the parameters dictionary and loading the input data.

  • population.py: The People class, for handling updates of state for each person.

  • plotting.py: Plotly graphs to supplement the built-in Matplotlib graphs.

  • population.py: Functions for creating populations of people, including age, contacts, etc.

  • requirements.py: A simple module to check that imports succeeded, and turn off features if they didn’t.

  • run.py: Functions for running simulations (e.g. parallel runs and the Scenarios class).

  • sim.py: The Sim class, which performs most of the heavy lifting: initializing the model, running, and plotting.

  • utils.py: Functions for choosing random numbers, many based on Numba, plus other helper functions.

  • version.py: Version, date, and license information.

cruise_ship

A version of the Covasim model specifically adapted for modeling the Diamond Princess cruise ship. It uses its own parameters file (parameters.py) and has slight variations to the model (model.py).

webapp

For running the interactive web application. See the webapp README for more information.

Other folders

Please see the readme in each subfolder for more information.

bin

This folder contains a command-line interface (CLI) version of Covasim; example usage:

covasim --pars "{pop_size:20000, pop_infected:1, n_days:360, rand_seed:1}"

Note: the CLI is currently not compatible with Windows. You will need to add this folder to your path to run from other folders.

data

Scripts to automatically scrape data (including demographics and COVID epidemiology data), and the data files themselves (which are not part of the repository).

docker

This folder contains the Dockerfile and other files that allow Covasim to be run as a webapp via Docker.

examples

This folder contains demonstrations of simple Covasim usage.

licenses

Licensing information and legal notices.

tests

Integration, development, and unit tests.

sweep

Utilities for hyperparameter sweeps, using Weights and Biases. See the sweep README for more information.

Disclaimer

The code in this repository was developed by IDM to support our research in disease transmission and managing epidemics. We’ve made it publicly available under the Creative Commons Attribution-Noncommercial-ShareAlike 4.0 License to provide others with a better understanding of our research and an opportunity to build upon it for their own work. We make no representations that the code works as intended or that we will provide support, address issues that are found, or accept pull requests. You are welcome to create your own fork and modify the code to suit your own modeling needs as contemplated under the Creative Commons Attribution-Noncommercial-ShareAlike 4.0 License. See the contributing and code of conduct READMEs for more information.

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

covasim-0.29.8.tar.gz (750.5 kB view details)

Uploaded Source

Built Distribution

covasim-0.29.8-py3-none-any.whl (666.4 kB view details)

Uploaded Python 3

File details

Details for the file covasim-0.29.8.tar.gz.

File metadata

  • Download URL: covasim-0.29.8.tar.gz
  • Upload date:
  • Size: 750.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/45.2.0.post20200313 requests-toolbelt/0.9.1 tqdm/4.39.0 CPython/3.7.5

File hashes

Hashes for covasim-0.29.8.tar.gz
Algorithm Hash digest
SHA256 d6d067ac54e8be62101062a8af9b037f4f9f0e92979fa0dfaf4d90453b965b14
MD5 419fb6d4fdd3c62bd26695914fd90793
BLAKE2b-256 27fdee599b76abb932fd6519c83cc4f1cea515a398904c1ad513532c279f87eb

See more details on using hashes here.

File details

Details for the file covasim-0.29.8-py3-none-any.whl.

File metadata

  • Download URL: covasim-0.29.8-py3-none-any.whl
  • Upload date:
  • Size: 666.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/45.2.0.post20200313 requests-toolbelt/0.9.1 tqdm/4.39.0 CPython/3.7.5

File hashes

Hashes for covasim-0.29.8-py3-none-any.whl
Algorithm Hash digest
SHA256 bef4b6c61fb9d903152c811cfa1bdcb86ea5ebd17e8de8e9e4d37e08058c9c62
MD5 f516103cb7e5c05b8b4dc90d377bd402
BLAKE2b-256 cf27fef0939c29c62a18810217d20f185355370b0ff6d3b187965f9418699b6b

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