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

Uploaded Source

Built Distribution

reactivedataflow-0.1.17-py3-none-any.whl (32.3 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: reactivedataflow-0.1.17.tar.gz
  • Upload date:
  • Size: 20.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.6

File hashes

Hashes for reactivedataflow-0.1.17.tar.gz
Algorithm Hash digest
SHA256 5d7f024fbd64747ffa68d8cda709154ea6ad8cfd39e79181e959c4b71212d14e
MD5 3035fde01f13abbacc1d899b3990958e
BLAKE2b-256 847f271e57cfa0eb6815cc8ca04e4f61980984ab20dba2ab616e5f14ed03f0a4

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for reactivedataflow-0.1.17-py3-none-any.whl
Algorithm Hash digest
SHA256 0378200f1e7364ebf614c72e6960a9ca9b320baaf19ed974aa3755fff4ce227f
MD5 12d51bd0b58ac6af0876944af46b8887
BLAKE2b-256 d133cd817914b5e83f16d71b7537687b3ee38ca4377a3e4a52c0a7c81514de99

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