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.12.tar.gz (19.7 kB view details)

Uploaded Source

Built Distribution

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

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for reactivedataflow-0.1.12.tar.gz
Algorithm Hash digest
SHA256 f32ad9d360553495a3e3b7f0d152640d8dbf15f0429edcf512f5c010c83daf9a
MD5 f4bfd32d7af359a3ff20c7a18cfb60f1
BLAKE2b-256 9e97424dcae18d85d9892804e513eb31cf0640b8d4164c99fb88b61994521605

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for reactivedataflow-0.1.12-py3-none-any.whl
Algorithm Hash digest
SHA256 ca3adee42ebd4fc94564e4a5aea03b3789b93969892518338cac6dd55d94f459
MD5 11a2db64bf043abef36dc5424a806e41
BLAKE2b-256 f54f4ec5a4dc0874995229230302ece8ca090f409b3c93501c7df5a9880db285

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