Skip to main content

This package provides a Python implementation of a metadata scheme for time-series with measurement uncertainties.

Project description

time-series-metadata

CircleCI Documentation Status DOI

A metrologically enabled time-series metadata scheme

time-series-metadata is a Python implementation of a metadata scheme for time-series with measurement uncertainties. It is developed jointly by software developers and researchers from Physikalisch-Technische Bundesanstalt (Germany) and Institute for Manufacturing (UK) as part of the joint European Research Project EMPIR 17IND12 Met4FoF and the German research project FAMOUS.

time-series-metadata is written in Python 3 and strives to run with all Python versions with upstream support. Currently it is tested to work with Python 3.5 to 3.8.

Scheme

The following image illustrates an abstract representation of a time series:

time-series metadata scheme illustration

The scheme contains all metadata to interpret the actual time and quantity values.

It is comprised of a dictionary containing the following keys with (default) values of the specified type:

metadata = {
    "device_id": string (default: ""),
    "time_name": string (default: "time"),
    "time_unit": string (default: "om:second"),
    "quantity_names": string or list of strings (default: ""),
    "quantity_units": string or list of strings (default: ""),
    "misc": optional, any other data you want to provide (default: None),
}

Example use

We illustrate the use of the scheme assuming you already have a project set up.

Installation

First you need to install the scheme with the usual command into your project's Python virtual environment:

pip install time-series-metadata

Import scheme

Inside your project's code import the scheme at the top of your module.

from time_series_metadata.scheme import MetaData

Assign initial values

After importing the package you can make use of it and assign initial values.

vs_description = MetaData(
    device_id="my_virtual_sensor",
    time_name="time",
    time_unit="s",
    quantity_names=("pressure_1", "pressure_2"),
    quantity_units=("Pa","mPa"),
    misc="additional information"
)

Read out metadata

You can access the metadata as a whole or time and quantity metadata separately. Quantity metadata can be either accessed for all quantities at once or individually via index or name. If you do not specify name or index, the first's quantity metadata is returned. This might be especially convenient, if there is only one quantity.

>>> vs_description.metadata
{"device_id": "my_virtual_sensor", "time_name": "time", "time_unit": "s", "quantity_names": ["pressure_1", "pressure_2"], "quantity_units": ["Pa", "mPa"], "misc": None}
>>> vs_description.time
{'time_name': 'time', 'time_unit': 's'}
>>> vs_description.quantities
{'quantity_names': ('pressure_1', 'pressure_2'), 'quantity_units': ('Pa', 'mPa')}
>>> vs_description.get_quantity(1)
{'quantity_names': 'pressure_2', 'quantity_units': 'mPa'}
>>> vs_description.get_quantity(name="pressure_1")
{'quantity_names': 'pressure_1', 'quantity_units': 'Pa'}
>>> vs_description.get_quantity()
{'quantity_names': 'pressure_1', 'quantity_units': 'Pa'}

Maintainers

The package is developed and maintained at the "Physikalisch-Technische Bundesanstalt" by Maximilian Gruber and Björn Ludwig.

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

time_series_metadata-0.1.1.tar.gz (18.9 kB view details)

Uploaded Source

Built Distribution

time_series_metadata-0.1.1-py3-none-any.whl (8.0 kB view details)

Uploaded Python 3

File details

Details for the file time_series_metadata-0.1.1.tar.gz.

File metadata

  • Download URL: time_series_metadata-0.1.1.tar.gz
  • Upload date:
  • Size: 18.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.0.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.8.9

File hashes

Hashes for time_series_metadata-0.1.1.tar.gz
Algorithm Hash digest
SHA256 c5045195a9f2f21406c37b6e2b6c6992b22831bfeed24e58da648ee12ad5f689
MD5 f1a3970ca76ced5b184d8033dc834d3e
BLAKE2b-256 a845661588c538312806df23ea433aa7f8f33eb61a56e28cfc7e309f1b32432d

See more details on using hashes here.

File details

Details for the file time_series_metadata-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: time_series_metadata-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 8.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.0.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.8.9

File hashes

Hashes for time_series_metadata-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 fcd4e9e389d1dfe893a8e8244285c55dee8e641fd321e122a84b3d9f60c18b07
MD5 bf725df204a3c62d9a173ee2a7ef9353
BLAKE2b-256 b86e62e3c483bb3958f805b972c00b1f1af5ca77a2ce8baa5626c00927cd7a80

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page