Skip to main content

Core SDK for OWI-Lab metadatabase: geometry and location data

Project description

OWI-metadatabase SDK

version python versions license pytest lint issues DOI Coverage Documentation

Core SDK for OWI-Lab metadatabase geometry and location workflows, with optional extras for soil, results, and SHM.

A modern Python namespace package providing tools for working with offshore wind turbine geometry and location data from the OWI-metadatabase. The core package stays focused on shared APIs and data access, while optional extras install the soil, results, and structural health monitoring extensions into the same owi.metadatabase namespace.

📚 Read the Documentation

Features

Installation

Quick Install

Using pip:

pip install owi-metadatabase

Using uv (recommended for development):

uv pip install owi-metadatabase

Install optional extras

Using pip:

pip install "owi-metadatabase[soil]"
pip install "owi-metadatabase[results]"
pip install "owi-metadatabase[shm]"

Using uv:

uv pip install "owi-metadatabase[soil]"
uv pip install "owi-metadatabase[results]"
uv pip install "owi-metadatabase[shm]"

Install multiple extras together when you need more than one extension:

pip install "owi-metadatabase[soil,results,shm]"

In zsh, keep extras in quotes because [ and ] are treated as glob characters.

Development Installation

For contributing to the package:

# Clone the repository
git clone https://github.com/OWI-Lab/owi-metadatabase-sdk.git
cd owi-metadatabase-sdk

# Install with uv (recommended)
uv sync --dev

# Or with pip
pip install -e ".[dev]"

Quick Start

from owi.metadatabase.geometry.io import GeometryAPI
from owi.metadatabase.locations.io import LocationsAPI

# Initialize API clients
geometry_api = GeometryAPI(API_key='your-api-key')
locations_api = LocationsAPI(API_key='your-api-key')

# Fetch turbine geometry
turbine = geometry_api.get_geometry_turbine(turbine_id=123)

# Get location data
location = locations_api.get_location(location_id=456)

See the How To Guide for more examples.

🔄 Migration from v0.10.x

If you're migrating from pwimetadatabase-preprocessor v0.10.x, see our Migration Guide.

Key Changes:

  • Package name: owi-metadatabase-sdkowi-metadatabase
  • Import path: owimetadatabase_preprocessor.*owi.metadatabase.*
  • Removed modules: fatigue, soil, and results (available as package extensions)
  • Extension extras now available from the core package: soil, results, and shm

Development

This project uses modern Python tooling:

  • uv: Fast Python package manager
  • invoke: Task automation
  • ruff: Linting and formatting
  • pytest: Testing with extensive doctest coverage
  • Zensical: Documentation

Common Tasks

# Run tests and serve coverage report
uv run inv test

# Build documentation
uv run inv docs.build

# Serve documentation locally
uv run inv docs.serve

# Run code quality checks
uv run inv quality

Project Structure

src/owi/metadatabase/
├── __init__.py          # Main package entry point
├── geometry/            # Geometry data processing
│   ├── io.py           # GeometryAPI
│   ├── processing.py   # OWT, OWTs classes
│   └── structures.py   # Data structures
├── locations/           # Location data handling
│   └── io.py           # LocationsAPI
└── _utils/             # Internal utilities
    ├── exceptions.py   # Custom exceptions
    └── utils.py        # Helper functions

Extensibility

This package uses PEP 420 namespace packages, allowing modular extensions. Installed packages can extend the owi.metadatabase namespace side by side:

  • owi-metadatabase-soil: Soil data processing
  • owi-metadatabase-results: Results querying, typed models, and plotting helpers
  • owi-metadatabase-shm: Structural health monitoring queries, typed records, and upload workflows
  • owi-metadatabase-fatigue (planned): Fatigue analysis tools
  • Your extension: Create custom extensions using the namespace

All extensions work seamlessly together:

from owi.metadatabase.geometry.io import GeometryAPI
from owi.metadatabase.results import ResultsAPI
from owi.metadatabase.shm import ShmAPI
from owi.metadatabase.soil import SoilAPI

Documentation

Contributing

We welcome contributions! Please see our Contributing Guide for details.

Quick Contribution Workflow

  1. Fork the repository
  2. Create a feature branch: git checkout -b feature/amazing-feature
  3. Make your changes with tests and documentation
  4. Run quality checks: uv run invoke quality.all
  5. Run tests: uv run invoke test.all
  6. Commit your changes: git commit -m 'feat: add amazing feature'
  7. Push to the branch: git push origin feature/amazing-feature
  8. Open a Pull Request

License

This package is licensed under the GNU General Public License v3.0.

👥 Authors

owi-metadatabase is developed and maintained by the team at OWI-Lab.

Core Contributors:

Acknowledgements

This package was developed as part of:

  • ETF Smartlife (FOD165) project
  • WILLOW (EUAR157) project

Project Status

Aspect Status
Version PyPI Version
Python Python Versions
Tests Test Status
Coverage Coverage
Documentation Docs
License License

Related Projects

Support


Built with ❤️ and 🧠 by OWI-Lab

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

owi_metadatabase-0.1.6.tar.gz (1.3 MB view details)

Uploaded Source

Built Distribution

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

owi_metadatabase-0.1.6-py3-none-any.whl (64.2 kB view details)

Uploaded Python 3

File details

Details for the file owi_metadatabase-0.1.6.tar.gz.

File metadata

  • Download URL: owi_metadatabase-0.1.6.tar.gz
  • Upload date:
  • Size: 1.3 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for owi_metadatabase-0.1.6.tar.gz
Algorithm Hash digest
SHA256 442adf5fec83334ecdf4e3e3701ce7882a22af7b0ff76f772c680523fd2e0d1d
MD5 20e8b40d6e0d4d0d282d9e97e75ef357
BLAKE2b-256 6bbc92733e0056d1ddf9206a486e6e2fbcd5dd0de332c8dd9f89db8c816a2b94

See more details on using hashes here.

Provenance

The following attestation bundles were made for owi_metadatabase-0.1.6.tar.gz:

Publisher: publish.yml on OWI-Lab/owi-metadatabase-sdk

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

File details

Details for the file owi_metadatabase-0.1.6-py3-none-any.whl.

File metadata

File hashes

Hashes for owi_metadatabase-0.1.6-py3-none-any.whl
Algorithm Hash digest
SHA256 e6563d6f4910915c39bb180de85ad0713bb82b646989c055ff215c8d6542fee2
MD5 2d9063dfab3c6950841442e97a09487a
BLAKE2b-256 b6eb150e492e32306ab5d8685d5cee71a1a084cdc56205793db2f67103f4fa66

See more details on using hashes here.

Provenance

The following attestation bundles were made for owi_metadatabase-0.1.6-py3-none-any.whl:

Publisher: publish.yml on OWI-Lab/owi-metadatabase-sdk

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