Cuvis-AI Core Framework
Project description
Cuvis-AI Core Framework
Overview
cuvis-ai-core is the foundational framework that powers the cuvis-ai machine learning pipeline for hyperspectral image analysis. This repository provides the core infrastructure and building blocks that enable flexible, extensible AI workflows for hyperspectral measurements.
While the cuvis-ai repository contains domain-specific nodes and pre-built models for tasks like anomaly detection and classification, cuvis-ai-core provides the essential framework components:
- Node System: Base classes for creating processing nodes with typed input/output ports
- Pipeline Infrastructure: Graph-based pipeline orchestration, execution, and visualization
- Plugin System: Dynamic node loading from Git repositories or local filesystem paths
- Serialization & Restoration: Save and restore complete pipeline states and configurations
- Type Safety: Strongly-typed port system with runtime validation
- gRPC Services: Remote pipeline management, training, and inference APIs
- Training Framework: Integration with PyTorch Lightning for model training workflows
This separation allows the core framework to evolve independently while the catalog of domain-specific nodes grows through a plugin architecture.
Installation
Prerequisites
If you want to directly work with cubert session files (.cu3s), you need to install cuvis C SDK from here.
Local development now relies on uv for Python and dependency management.
If uv is not already available on your system you can install it following their installation instructions.
Install from PyPI (Recommended)
# Install cuvis-ai-core from PyPI
uv add cuvis-ai-core
PyTorch will be installed automatically with CUDA support if available on your system.
Local development with uv
Create or refresh a development environment at the repository root with:
uv sync --all-extras --dev
This installs the runtime dependencies declared in pyproject.toml. uv automatically provisions the Python version declared in the project metadata, so no manual interpreter management is required.
Enable Git Hooks (Required)
After cloning the repository, enable the git hooks for code quality enforcement:
git config core.hooksPath .githooks
This configures Git to use the version-controlled hooks in .githooks/ which automatically enforce code formatting, linting, and testing standards before commits and pushes. See docs/development/git-hooks.md for details.
Advanced environment setup
When you need the reproducible development toolchain (JupyterLab, TensorBoard, etc.) from the lock file, run:
uv sync --locked --extra dev
Use uv run to execute project tooling without manually activating virtual environments, for example:
uv run pytest
Collect coverage details (the dev extra installs pytest-cov) with:
uv run pytest --cov=cuvis_ai --cov-report=term-missing
Ruff handles both formatting and linting. Format sources and check style with:
uv run ruff format .
uv run ruff check .
The configuration enforces import ordering, newline hygiene, modern string formatting, safe exception chaining, and practical return type annotations while avoiding noisy Any policing.
Validate packaging metadata and build artifacts before publishing:
uv build
To build the documentation, add the docs extra:
uv sync --locked --extra docs
Combine extras as needed (e.g. uv sync --locked --extra dev --extra docs). Whenever the pyproject.toml or uv.lock changes, rerun uv sync --locked with the extras you need to stay up to date.
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
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
File details
Details for the file cuvis_ai_core-0.2.0.tar.gz.
File metadata
- Download URL: cuvis_ai_core-0.2.0.tar.gz
- Upload date:
- Size: 407.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b464f55a8047c3a95c09e2060f26c492bbbbf26689b07fa4b0b417db77a155d9
|
|
| MD5 |
93e981c5c75fe4765798be16fc922b89
|
|
| BLAKE2b-256 |
07fd93eb6cd5b15474905e15b5b921b9e9e203275aa9cafb7cbe60bf196029c5
|
Provenance
The following attestation bundles were made for cuvis_ai_core-0.2.0.tar.gz:
Publisher:
pypi-release.yml on cubert-hyperspectral/cuvis-ai-core
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
cuvis_ai_core-0.2.0.tar.gz -
Subject digest:
b464f55a8047c3a95c09e2060f26c492bbbbf26689b07fa4b0b417db77a155d9 - Sigstore transparency entry: 1003699262
- Sigstore integration time:
-
Permalink:
cubert-hyperspectral/cuvis-ai-core@517d0d707e132ccdfd24a789c263d764ace47d18 -
Branch / Tag:
refs/tags/v0.2.0 - Owner: https://github.com/cubert-hyperspectral
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
pypi-release.yml@517d0d707e132ccdfd24a789c263d764ace47d18 -
Trigger Event:
push
-
Statement type:
File details
Details for the file cuvis_ai_core-0.2.0-py3-none-any.whl.
File metadata
- Download URL: cuvis_ai_core-0.2.0-py3-none-any.whl
- Upload date:
- Size: 124.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f9e1c543f2c43b4256ee76bbbdb1dcf5a2449f1f835f8f768db9bb3be1198f7c
|
|
| MD5 |
da51aec98e87eaa1da1e10fef69ee792
|
|
| BLAKE2b-256 |
64310540e641e9d83c9df33acc4774c75e1cd1f400ee2917091f581ae0efba50
|
Provenance
The following attestation bundles were made for cuvis_ai_core-0.2.0-py3-none-any.whl:
Publisher:
pypi-release.yml on cubert-hyperspectral/cuvis-ai-core
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
cuvis_ai_core-0.2.0-py3-none-any.whl -
Subject digest:
f9e1c543f2c43b4256ee76bbbdb1dcf5a2449f1f835f8f768db9bb3be1198f7c - Sigstore transparency entry: 1003699266
- Sigstore integration time:
-
Permalink:
cubert-hyperspectral/cuvis-ai-core@517d0d707e132ccdfd24a789c263d764ace47d18 -
Branch / Tag:
refs/tags/v0.2.0 - Owner: https://github.com/cubert-hyperspectral
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
pypi-release.yml@517d0d707e132ccdfd24a789c263d764ace47d18 -
Trigger Event:
push
-
Statement type: