Skip to main content

Reactive Dataflow Graphs

Project description

Reactive-Dataflow

Reactive Processing Graphs for Python.

Getting Started

Installation

pip install reactivedataflow

The key dependencies for this project include rx and networkx. These are outlined in the pyproject.toml dependencies section.

Usage

import reactivex as rx
from reactivedataflow import (
	GraphAssembler, 
	GraphModel, 
	VerbNodeModel, 
	InputNodeModel, 
	InputModel,
	verb,
	InputPort,
	ConfigPort
)
#
# Define a processing verb
#
@verb(
	name="print",
	ports=[
		InputPort(name="values", required=True, parameter="val"),
		ConfigPort(name="prefix", required=False, parameter="prefix"),
	]
)
def print_verb(val, prefix=""):
	return f"{prefix}{val}"

#
# Define a simple graph
#
assembler = GraphAssembler()
assembler.load(
	GraphModel(
		inputs=[
			# This is an input stream of values we'll define on build
			InputNodeModel(id="input_values")
		],
		nodes=[
			# Here we define the processing nodes
			VerbNodeModel(
				id="verb1",
				verb="print",
				config={"prefix": "emitted: "},
				input={
					"values": InputModel(node="input_values")
				}
			),
		],
	),
)

#
# Build the graph and bind input streams
#
graph = assembler.build(
	inputs={
		"input_values": rx.of([1, 2, 3])
	}
)
#
# Watch graph outputs
#
graph.output("verb1").subscribe(print)
# Output:
# emitted: 1
# emitted: 2
# emitted: 3

Developing

This project uses poetry for dependency management. You should have a recent Python version (e.g. 3.10+) and Poetry 1.8+ installed on your system.

# Install dependencies
poetry install

# Run tests
poetry run poe test

# Run static checks
poetry run poe check

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

reactivedataflow-0.1.14.tar.gz (19.8 kB view details)

Uploaded Source

Built Distribution

reactivedataflow-0.1.14-py3-none-any.whl (31.2 kB view details)

Uploaded Python 3

File details

Details for the file reactivedataflow-0.1.14.tar.gz.

File metadata

  • Download URL: reactivedataflow-0.1.14.tar.gz
  • Upload date:
  • Size: 19.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.0 CPython/3.12.5

File hashes

Hashes for reactivedataflow-0.1.14.tar.gz
Algorithm Hash digest
SHA256 218f8112d5fa2bfaacb5edd1bc224008eebfe3538b318fa37b4fb1657b670ef9
MD5 20a31ff5b7c3db790558988987baf846
BLAKE2b-256 528fa0f37bf4abef5dcd13b60d04791c8e90b7a5b17588f2b80990ac17363a4e

See more details on using hashes here.

File details

Details for the file reactivedataflow-0.1.14-py3-none-any.whl.

File metadata

File hashes

Hashes for reactivedataflow-0.1.14-py3-none-any.whl
Algorithm Hash digest
SHA256 b83b6dc4a6c18588646dbae9a193469ce030e14b4e3cf16d943408ce47e143c1
MD5 4439f0c12cd29ec78844e36d7ceedf17
BLAKE2b-256 f5fea8957585239ca66a0686b82301459908c51777f3ef0962fe489fd8482cf6

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