Skip to main content

V&V-grade specifications for engineered systems — AI, optimization, simulation, and physics.

Project description

vnvspec

V&V-grade specifications for engineered systems — AI, optimization, simulation, and physics.

CI Docs codecov V&Ved PyPI License Python

Overview

vnvspec lets you write machine-readable V&V specifications for any engineered system and automatically assess models against them. It produces traceable evidence reports that map to international standards (ISO/PAS 8800, ISO 21448, UL 4600, EU AI Act, and more).

Key features

  • Typed spec language — Pydantic-based Spec, Requirement, IOContract, ODD, Hazard, Evidence models
  • INCOSE GtWR quality checker — catch vague, ambiguous, or unverifiable requirements early, with configurable profiles (formal, web-app, embedded)
  • Traceability graphs — link requirements ↔ hazards ↔ evidence ↔ standards clauses, plus auto-trace scanning
  • Standards registries — built-in clause databases for ISO/PAS 8800, ISO 21448, UL 4600, EU AI Act, NIST AI RMF
  • Compliance matrix — auditor-grade XLSX/CSV/HTML exports with gap analysis against any standard
  • Best-practices catalogs — pre-written requirements for PyTorch, HuggingFace, FastAPI, SQLAlchemy, Pyomo; composable via Spec.extend()
  • Pluggable adapters — wrap any model (PyTorch, HuggingFace, scikit-learn, ONNX, Pyomo, FMI)
  • EvidenceCollector — ergonomic context manager for building evidence from assertions and JUnit XML
  • pytest pluginpytest-vnvspec captures evidence directly from test results
  • Multi-format specs — define specs in Python, YAML, or TOML; lossless round-trips
  • CI integrations — GitHub Actions composite action, V&V badge SVG, report diff for regression detection
  • Rich exports — HTML reports, Markdown, GSN assurance cases (Mermaid), EU AI Act Annex IV tech docs

Installation

pip install vnvspec

With PyTorch adapter:

pip install vnvspec[torch]

Quick start

from vnvspec import Requirement, Spec

req = Requirement(
    id="REQ-001",
    statement="The classifier shall produce probabilities in [0, 1].",
    rationale="Probability outputs must be valid for downstream calibration.",
    verification_method="test",
    acceptance_criteria=["All output probabilities are between 0.0 and 1.0 inclusive."],
)

spec = Spec(name="image-classifier-v1", requirements=[req])
violations = req.check_quality()
print(f"Quality issues: {len(violations)}")

Development

# Install all dev dependencies
just install

# Run all checks (lint, typecheck, test with coverage)
just check

License

Apache-2.0. See LICENSE.

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

vnvspec-0.3.2.tar.gz (453.0 kB view details)

Uploaded Source

Built Distribution

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

vnvspec-0.3.2-py3-none-any.whl (131.6 kB view details)

Uploaded Python 3

File details

Details for the file vnvspec-0.3.2.tar.gz.

File metadata

  • Download URL: vnvspec-0.3.2.tar.gz
  • Upload date:
  • Size: 453.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for vnvspec-0.3.2.tar.gz
Algorithm Hash digest
SHA256 8d936106966138c2f08e1da784f66dc193d26799d6f6f7c5b81e4c39837cdb39
MD5 55e80fc063f31f13aff4f38c3eebdeac
BLAKE2b-256 82bab6aadb38b53588675fc78ae75131475adf5d01196cfb83d4eed2aedd18b6

See more details on using hashes here.

Provenance

The following attestation bundles were made for vnvspec-0.3.2.tar.gz:

Publisher: workflow.yml on ai-vnv/vnvspec

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file vnvspec-0.3.2-py3-none-any.whl.

File metadata

  • Download URL: vnvspec-0.3.2-py3-none-any.whl
  • Upload date:
  • Size: 131.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for vnvspec-0.3.2-py3-none-any.whl
Algorithm Hash digest
SHA256 375787f8cd8866d59bf6912a360cab7b98e1b1cc2a45c1dc94c26f0a28064a1e
MD5 636747a49a33c7f49aa428a519f4d5f3
BLAKE2b-256 fe3076944f6b5756926a12b298879903b3c62e70993791ec3940475e1e36df8a

See more details on using hashes here.

Provenance

The following attestation bundles were made for vnvspec-0.3.2-py3-none-any.whl:

Publisher: workflow.yml on ai-vnv/vnvspec

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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