Skip to main content

A framework to help navigate buffers through a graph. The buffers must flow.

Project description

SGN

ci ci documentation pypi version

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

  • sgn-ts: TimeSeries utilities for SGN
  • sgn-ligo: LSC specific utilities for SGN

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


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.8.0.tar.gz (1.8 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

sgn-0.8.0-py3-none-any.whl (108.9 kB view details)

Uploaded Python 3

File details

Details for the file sgn-0.8.0.tar.gz.

File metadata

  • Download URL: sgn-0.8.0.tar.gz
  • Upload date:
  • Size: 1.8 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: Hatch/1.16.4 cpython/3.13.12 HTTPX/0.28.1

File hashes

Hashes for sgn-0.8.0.tar.gz
Algorithm Hash digest
SHA256 5a2c35d5e88eb011805f2a74703d7319440d4b9c9ecd5712fd77e203f9b1f2d0
MD5 75ad89f02ec9b0da085deb2a4bbaccce
BLAKE2b-256 c95b6c58010d2f97f244cc73e545d8f0285e0194c5e15c972392c7b63c65391b

See more details on using hashes here.

File details

Details for the file sgn-0.8.0-py3-none-any.whl.

File metadata

  • Download URL: sgn-0.8.0-py3-none-any.whl
  • Upload date:
  • Size: 108.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: Hatch/1.16.4 cpython/3.13.12 HTTPX/0.28.1

File hashes

Hashes for sgn-0.8.0-py3-none-any.whl
Algorithm Hash digest
SHA256 e2cf25b5a1fd78df2d558633e36b9edc0b1f6a418e3c842c28789d0067f857be
MD5 8a7285db6bd888e079a3c2c56ac50c03
BLAKE2b-256 38406d430cefab63420931791e9e594e0d847f66f08545c9a262164ae7ffaf7b

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page