Skip to main content

Add your description here

Project description

regelum

docs tests python uv

regelum

regelum is a framework for modeling Phased Reactive Systems: systems that execute one tick at a time, activate different groups of nodes in different phases, and move between phases with explicit transitions.

Overview

  • Nodes declare typed inputs and outputs.
  • Phases decide which node instances are active together.
  • Transitions describe how one phase hands control to the next.
  • Compilation resolves links, schedules nodes, and catches structural mistakes before runtime.

The best entry point is the concepts overview:

Quick Example

import regelum as rg


class TemperatureSensor(rg.Node):
    class Outputs(rg.NodeOutputs):
        temperature: float = rg.Output(initial=19.0)

    def run(self) -> Outputs:
        return self.Outputs(temperature=21.5)


class HeaterController(rg.Node):
    class Inputs(rg.NodeInputs):
        temperature: float = rg.Input(
            source=TemperatureSensor.Outputs.temperature,
        )

    class Outputs(rg.NodeOutputs):
        heater_on: bool

    def run(self, inputs: Inputs) -> Outputs:
        return self.Outputs(heater_on=inputs.temperature < 22.0)


sensor = TemperatureSensor(name="room_sensor")
controller = HeaterController(name="heater_controller")

system = rg.PhasedReactiveSystem(
    phases=[
        rg.Phase(
            "control",
            nodes=(sensor, controller),
            transitions=(rg.Goto(rg.terminate),),
            is_initial=True,
        ),
    ],
)

snapshot = system.step()
print(snapshot["heater_controller.heater_on"])

Installation

Recommended: use uv.

uv add regelum

For local development from this repository:

uv sync --all-groups
uv run pytest tests
uv run ty check src tests
uv run mkdocs serve

Examples

uv run regelum-pendulum
uv run regelum-video-player
uv run regelum-instance-connect

Release Process

Create a GitHub Release with a tag such as v0.2.0.

The publish workflow will:

  1. build the package with uv build
  2. derive version 0.2.0 from the git tag via hatch-vcs
  3. publish the artifacts to PyPI with uv publish

After installation, users can verify the packaged version:

import regelum

print(regelum.__version__)

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

regelum-0.2.0.tar.gz (2.4 MB view details)

Uploaded Source

Built Distribution

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

regelum-0.2.0-py3-none-any.whl (57.6 kB view details)

Uploaded Python 3

File details

Details for the file regelum-0.2.0.tar.gz.

File metadata

  • Download URL: regelum-0.2.0.tar.gz
  • Upload date:
  • Size: 2.4 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.8 {"installer":{"name":"uv","version":"0.11.8","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for regelum-0.2.0.tar.gz
Algorithm Hash digest
SHA256 ffbd1521c747bc0ada0a7b623dfade16bd4511d8578406afaf014e3e42699a32
MD5 c2b7a6e57697afd732f6cc3ec42617b4
BLAKE2b-256 e8a02862e12f0baf6df231e679caf46fdeb2c7b0c4020b7a349e46ff8a572371

See more details on using hashes here.

File details

Details for the file regelum-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: regelum-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 57.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.8 {"installer":{"name":"uv","version":"0.11.8","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for regelum-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 f8f915e6fdaeb2d78f6cf45f9baabb3ecb20658ec71d591be1161d4f36d03325
MD5 b9eabec34e7e18c9b1602286007a0067
BLAKE2b-256 6cee1e48ac7e13f34808be639f027ce7b3f29a8167606a12d39ffe34d33092d9

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