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

Uploaded Source

Built Distribution

reactivedataflow-0.1.15-py3-none-any.whl (31.4 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: reactivedataflow-0.1.15.tar.gz
  • Upload date:
  • Size: 19.9 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.15.tar.gz
Algorithm Hash digest
SHA256 3cecef57351c904b933a6cee853fa73faf26645e8381ef3caa24a7f26c8da5e6
MD5 b75da83213e90784afd5407c8d50ef42
BLAKE2b-256 df0192b30c124af2d629b0f2985fa60da33c7daa2024cdd586fcd7a51f0e1dac

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for reactivedataflow-0.1.15-py3-none-any.whl
Algorithm Hash digest
SHA256 45738d4330a36456f735bdbc3df1c3dc51b4a755fba759a6997a4e630094c9b9
MD5 e3d2e2295b142abf388f3eedfd2a5992
BLAKE2b-256 e6e5028c352d54e78d5e0e02c36edc59db442b0769b3e6333b1621de65b55cb7

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