A framework to help navigate buffers through a graph. The buffers must flow.
Project description
SGN
SGN is a lightweight Python library for building streaming data pipelines. Connect sources, transforms, and sinks into clear workflows while SGN handles asynchronous execution under the hood. Zero external dependencies.
Installation
pip install sgn
Example
import functools
from sgn import Pipeline, IterSource, CallableTransform, CollectSink
def scale(frame, factor: float):
return None if frame.data is None else frame.data * factor
src = IterSource(name="src", source_pad_names=["H1"], iters={"H1": [1, 2, 3]})
transform = CallableTransform.from_callable(
name="t1",
sink_pad_names=["H1"],
callable=functools.partial(scale, factor=10),
output_pad_name="H1",
)
sink = CollectSink(name="snk", sink_pad_names=["H1"])
p = Pipeline()
p.connect(src, transform)
p.connect(transform, sink)
p.run()
assert list(sink.collects["H1"]) == [10, 20, 30]
Documentation
- Tutorial — New to SGN? Build your first pipeline step by step.
- User Guide — Solve specific problems: connecting elements, grouping, parallelism, and more.
- Background — Understand how SGN works: execution model, core concepts, and design decisions.
- Reference — Elements and auto-generated API documentation.
Related Libraries
Instructions for reviewers
- We will use glreview for this project. Please familiarize yourself with it.
Unreviewed modules
- A librarian or designated person will generate issues using glreview for all modules
- The issue will contain an AI review with Claude
- An AI generated merge request will be made to address issues. The librarian/designee may take liberties to guide that process so that it is high quality
- The librarian/designee will seek out a human to be assigned to each issue at this point
- The assigned human will:
- Verify the pre-review checklist in the git issue (and check boxes if appropriate)
- Post independent findings as well as notes on the AI review in findings
- Fill out the overall summary table
- update the MR (if required) and work with the code authors to approve and merge the MR
- The issue will be closed when the MR is merged
- run glreview signoff after the issue is closed
Reviewed modules - updating when code changes
- FIXME. More to say on this later
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
sgn-0.11.0.tar.gz
(1.8 MB
view details)
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
sgn-0.11.0-py3-none-any.whl
(125.0 kB
view details)
File details
Details for the file sgn-0.11.0.tar.gz.
File metadata
- Download URL: sgn-0.11.0.tar.gz
- Upload date:
- Size: 1.8 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.11
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7235fc2cfc5cd2e80c29b3e7f071523fee19ab31419fb6b5a6e9db51e275a099
|
|
| MD5 |
e965fb0e20afc360fb52e814f07a5848
|
|
| BLAKE2b-256 |
79d56bc703c3a76f2fb631562f2a82412ea910c748cbb0a5668daad2ac306318
|
File details
Details for the file sgn-0.11.0-py3-none-any.whl.
File metadata
- Download URL: sgn-0.11.0-py3-none-any.whl
- Upload date:
- Size: 125.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.11
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
52703d04053d805e2e39faed4e15440873310f097c306904164db1db74e1ad0a
|
|
| MD5 |
17fe80f1a6dd465578c31bb89ac6af8d
|
|
| BLAKE2b-256 |
3a7d84562eb61b78473f7ee1e470804629df698e220a07cdfa07dde7b011f693
|