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.10.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.10.0-py3-none-any.whl (122.2 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: sgn-0.10.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

Hashes for sgn-0.10.0.tar.gz
Algorithm Hash digest
SHA256 0e423fd73f2ee08da72685a737611a9defb3866f94ad4e0046293af0a9e82dc1
MD5 aee2472b721750be864922f77a727bc2
BLAKE2b-256 20bb11e3be106df8abcf92bdeae265f03cc5f892ac81286203101dfe2a0ac44d

See more details on using hashes here.

File details

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

File metadata

  • Download URL: sgn-0.10.0-py3-none-any.whl
  • Upload date:
  • Size: 122.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.11

File hashes

Hashes for sgn-0.10.0-py3-none-any.whl
Algorithm Hash digest
SHA256 689f9bb75be3fc3a7cbcf1b308e9136f58fd835e0282383068da6adfe9fcdc10
MD5 22469d8fefea0c48abe826b5c7924391
BLAKE2b-256 0bd039e7a978c50cc2cd671b150d2b97ecad11446a5e9708c9a7fd24af5194b1

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