Skip to main content

Ryn SDK: data, model, and trainer interfaces

Project description

Ryn SDK

A unified Python SDK for data, model, and trainer workflows.
This repository mirrors the automatic release workflow used in model-registry (auto-publish to PyPI via GitHub Actions).

Default install pulls everything. Subsets are available via extras (ryn[model], ryn[data], ryn[trainer]).


Table of Contents


Installation

Default (everything): installs the union of data + model + trainer requirements.

# Everything
pip install ryn

# Only the model stack
pip install "ryn[model]"

# Only the data stack
pip install "ryn[data]"

# Only the trainer stack
pip install "ryn[trainer]"

Notes

  • Some dependencies (e.g., torch) may require platform-specific wheels. If you're on a GPU machine, consult the official PyTorch install guide for your CUDA/ROCm toolkit.
  • If you need a slim install instead, use a virtual environment and install only the extras you need.

Quick Start

import ryn
from ryn import data, model, trainer

print("Ryn version:", ryn.__version__)

# Example scaffolding (replace with your actual API calls):
# Dataset operations
# ds = data.load_dataset("your-dataset-id")
# df = data.to_pandas(ds)

# Model registry / storage operations
# model_id = model.register_model(name="my-model", version="1.0.0", metadata={"task": "classification"})
# meta = model.get_model(name="my-model", version="1.0.0")

# Training utilities
# run = trainer.train(config={"epochs": 10, "lr": 1e-3})
# metrics = trainer.evaluate(run)

The snippet above shows typical entry points. Replace with your actual functions/classes provided by ryn.data, ryn.model, and ryn.trainer in this repo.


Project Structure

ryn/
  data/       # Data utilities & loaders
  model/      # Model registry / storage / inference helpers
  trainer/    # Training loops, trackers, and helpers
  __init__.py # Exposes public API and package metadata

Requirements Layout

Dependencies are split into three groups under requirements/ and combined for the default install:

requirements/
  model.txt    # e.g., boto3, huggingface-hub, transformers, einops, ...
  data.txt     # e.g., numpy, pandas, scikit-learn, datasets, openml, ...
  trainer.txt  # e.g., torch, torchvision, timm, albumentations, ...
  • Default install (pip install ryn) = union(model + data + trainer).
  • Extras for explicit subsets:
    • ryn[model]
    • ryn[data]
    • ryn[trainer]

These groups are wired in setup.py so that PyPI metadata carries the dependency info.


Versioning & Auto-Publish to PyPI

The repository uses a CI workflow (GitHub Actions) that auto-bumps and publishes to PyPI on push to main when the following conditions are met:

  1. Repository variable PUBLISH_TO_PYPI is set to true.
  2. The commit message contains the phrase pipy commit -push.

Bump level is controlled via the commit message:

  • pipy commit -push major → bump MAJOR
  • pipy commit -push minor → bump MINOR
  • pipy commit -push (no keyword) → bump PATCH (default)

Workflow outline

  1. Read current version from PyPI.
  2. Compute next version (patch/minor/major).
  3. Update ryn/__init__.py and setup.py.
  4. Build distributions (sdist + wheel).
  5. Upload to PyPI using Twine.

Required repo settings

  • Settings → Secrets and variables → Actions → Secrets
    • PYPI_API_TOKEN (PyPI token)
  • Settings → Secrets and variables → Actions → Variables
    • PUBLISH_TO_PYPI = true

Local Development

# Clone
git clone https://github.com/AIP-MLOPS/rayen.git
cd rayen

# (Optional) Create a virtual environment
python -m venv .venv && source .venv/bin/activate  # or .venv\Scripts\activate on Windows

# Install in editable mode with a subset of extras, e.g., model
pip install -e ".[model]"

# Build locally
python -m pip install --upgrade pip build twine
python -m build
twine check dist/*

If you prefer a full dev install, use pip install -e ".[all]" (identical to default deps).


Update Checker (Optional)

The package may include a lightweight update checker that prints a hint if a newer version is available on PyPI. This check is best-effort and should never fail your import due to network issues.


Supported Python Versions

  • Python 3.11+

Contributing

  1. Fork the repository and create a feature branch.
  2. Keep commits focused and meaningful.
  3. Open a Pull Request with a clear description and, if applicable, tests or examples.

Consider running your linter/formatter locally (e.g., ruff) before opening a PR.


License

MIT

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

ryn-0.2.12.tar.gz (140.8 kB view details)

Uploaded Source

Built Distribution

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

ryn-0.2.12-py3-none-any.whl (194.7 kB view details)

Uploaded Python 3

File details

Details for the file ryn-0.2.12.tar.gz.

File metadata

  • Download URL: ryn-0.2.12.tar.gz
  • Upload date:
  • Size: 140.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.13

File hashes

Hashes for ryn-0.2.12.tar.gz
Algorithm Hash digest
SHA256 83dfea9cea7634b5f1fb9a87c71fca96aa484c4d4f61cbde3d4f27521394717d
MD5 b9400914a7e3d8acf870477d73a9dca7
BLAKE2b-256 519c4dd32b5cd346032015f903b69fc23c91c750a26702675c77d139c9ecce32

See more details on using hashes here.

File details

Details for the file ryn-0.2.12-py3-none-any.whl.

File metadata

  • Download URL: ryn-0.2.12-py3-none-any.whl
  • Upload date:
  • Size: 194.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.13

File hashes

Hashes for ryn-0.2.12-py3-none-any.whl
Algorithm Hash digest
SHA256 65b2a697f4f629ec0538dc5908eb4471bb02e3d982733eac34d09e36a5ded382
MD5 7b2f6fdb1dcbaf0449edff44c9414045
BLAKE2b-256 8b621dd75306af03dd4429402092f092bcdd27b22082256e8f82824b289ac780

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