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 tasks. Variables represent the instantaneous state of the simulation. They may be organized into arbitrary data structures. Tasks define how that state evolves. They may appear concurrent, but are scheduled sequentially.
Task execution is subdivided into a sequence of slots. Slots are assigned a monotonically increasing integer value, called time. Multiple tasks 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)
Features
- Kernel: task scheduler
- Task: coroutine wrapper
- Synchronization Primitives:
- Events
- Semaphores
- Credit Pools
- Queues
- Containers
- Structured Concurrency:
- Task Groups (parent/child hierarchy)
- Interrupts
- Exceptions
- Model Variables:
- Singular
- Aggregate
Example
The following code simulates singing in the round.
Four singers perform "Row, Row, Row Your Boat" in staggered fashion.
Each singer is represented by a coroutine.
A separator coroutine draws lines for readability.
The coroutines are wrapped by tasks,
and tasks are assigned a priority for precise ordering of concurrent events.
>>> from deltacycle import *
>>> song = [
... "Row, row, row your boat",
... "Gently down the stream",
... "Merrily, merrily, merrily, merrily",
... "Life is but a dream",
... ]
>>> async def singer(name: str, delay: int = 0):
... await sleep(delay)
... for line in song:
... print(f"{now()} ♫ {name}: {line:34} ♫")
... await sleep(1)
>>> async def separator():
... while True:
... print(f"{now()} ♫---------------------------------------♫")
... await sleep(1)
>>> async def main():
... t = create_task(separator(), priority=-1)
...
... async with TaskGroup() as tg:
... tg.create_task(singer("A", delay=0), priority=1)
... tg.create_task(singer("B", delay=1), priority=2)
... tg.create_task(singer("C", delay=2), priority=3)
... tg.create_task(singer("D", delay=3), priority=4)
...
... t.interrupt() # Interrupt separator task
...
... return "Bow / Curtsy"
>>> r = run(main())
0 ♫---------------------------------------♫
0 ♫ A: Row, row, row your boat ♫
1 ♫---------------------------------------♫
1 ♫ A: Gently down the stream ♫
1 ♫ B: Row, row, row your boat ♫
2 ♫---------------------------------------♫
2 ♫ A: Merrily, merrily, merrily, merrily ♫
2 ♫ B: Gently down the stream ♫
2 ♫ C: Row, row, row your boat ♫
3 ♫---------------------------------------♫
3 ♫ A: Life is but a dream ♫
3 ♫ B: Merrily, merrily, merrily, merrily ♫
3 ♫ C: Gently down the stream ♫
3 ♫ D: Row, row, row your boat ♫
4 ♫---------------------------------------♫
4 ♫ B: Life is but a dream ♫
4 ♫ C: Merrily, merrily, merrily, merrily ♫
4 ♫ D: Gently down the stream ♫
5 ♫---------------------------------------♫
5 ♫ C: Life is but a dream ♫
5 ♫ D: Merrily, merrily, merrily, merrily ♫
6 ♫---------------------------------------♫
6 ♫ D: Life is but a dream ♫
7 ♫---------------------------------------♫
>>> print(r)
Bow / Curtsy
Installing
DeltaCycle is available on PyPI:
$ pip install deltacycle
It requires 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
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file deltacycle-0.30.0.tar.gz.
File metadata
- Download URL: deltacycle-0.30.0.tar.gz
- Upload date:
- Size: 30.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.4 {"installer":{"name":"uv","version":"0.10.4","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":null,"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6197cbfcb31af4ea12b3551ea4380887fb5464aa0d4608d1292a2d8b19bcef04
|
|
| MD5 |
682edc99e2e2d8ef102678ea3cbffd46
|
|
| BLAKE2b-256 |
2a0287857b347ebff5c699b9b73372672223b56d90e7e9a52e4c0b4063cd3ba9
|
File details
Details for the file deltacycle-0.30.0-py3-none-any.whl.
File metadata
- Download URL: deltacycle-0.30.0-py3-none-any.whl
- Upload date:
- Size: 21.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.4 {"installer":{"name":"uv","version":"0.10.4","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":null,"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
72831ec920a1b545bc0d5735882a75e3fef3691e22e62e233cab49401518e97b
|
|
| MD5 |
6aa9a51210ca5e24989a4fd2932afe05
|
|
| BLAKE2b-256 |
0c2f850a91f443d77aff16f110d224ee3b948378a2bd7f1234bba604a971b24b
|