Skip to main content

Delta Cycle

Project description

Delta Cycle

DeltaCycle is a Python library for discrete event simulation (DES).

A simulation has two components: a collection of variables, and a collection of processes. Variables represent the instantaneous state of the simulation. They may be organized into arbitrary data structures. Processes define how that state evolves. They may appear concurrent, but are scheduled sequentially.

Process execution is subdivided into a sequence of slots. Slots are assigned a monotonically increasing integer value, called time. Multiple processes may execute in the same slot, and therefore at the same time. The term "delta cycle" refers to a zero-delay subdivision of a time slot. It is the clockwork mechanism behind the illusion of concurrency.

Read the docs! (WIP)

Documentation Status

Features

  • Loop: task scheduler
  • Tasks: coroutine wrapper
  • Synchronization Primitives:
    • Events
    • Locks
    • Semaphores
    • Queues
  • Structured concurrency:
    • Task groups
    • Task cancellation
    • Task dependencies
    • Exception handling
  • Variables:
    • Singular
    • Aggregate
    • Variable dependencies

Example

The following code simulates two clocks running concurrently. The fast clock prints the current time every time step. The slow clock prints the current time every two time steps.

>>> from deltacycle import create_task, now, run, sleep

>>> async def clock(name: str, period: int):
...     while True:
...         print(f"{now()}: {name}")
...         await sleep(period)

>>> async def main():
...     create_task(clock("fast", 1))
...     create_task(clock("slow", 2))

>>> run(main(), until=7)
0: fast
0: slow
1: fast
2: slow
2: fast
3: fast
4: slow
4: fast
5: fast
6: slow
6: fast

Installing

DeltaCycle is available on PyPI:

$ pip install deltacycle

It supports Python 3.12+

Developing

DeltaCycle's repository is on GitHub:

$ git clone https://github.com/cjdrake/deltacycle.git

It is 100% Python, and has no runtime dependencies. Development dependencies are listed in requirements-dev.txt.

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

deltacycle-0.13.1.tar.gz (22.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

deltacycle-0.13.1-py3-none-any.whl (15.7 kB view details)

Uploaded Python 3

File details

Details for the file deltacycle-0.13.1.tar.gz.

File metadata

  • Download URL: deltacycle-0.13.1.tar.gz
  • Upload date:
  • Size: 22.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.7.13

File hashes

Hashes for deltacycle-0.13.1.tar.gz
Algorithm Hash digest
SHA256 f1ec6119f288973ac1dd934f4b6c270493e3eac20f1435f65763bd6606d4fb22
MD5 dee615f6aa8aef893f11eef06f107f1e
BLAKE2b-256 e0335da5d91f5355a79555b16c7821d89c0d4499d5486c98aa08fc728a15dd4b

See more details on using hashes here.

File details

Details for the file deltacycle-0.13.1-py3-none-any.whl.

File metadata

File hashes

Hashes for deltacycle-0.13.1-py3-none-any.whl
Algorithm Hash digest
SHA256 ec00e90263f5bb3085d9e08d9bf82d22f445ee4533ec41e22ef8546094383ab2
MD5 91aae44ecba90a560fb0ce5e450e7fe2
BLAKE2b-256 f854e1bbf5a4863833d7d7b9e18deb0f0537cbf5936a1f79acd38a24c8d49505

See more details on using hashes here.

Supported by

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