This package provides a Python implementation of a metadata scheme for time-series with measurement uncertainties.
Project description
time-series-metadata
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:
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
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
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
Algorithm | Hash digest | |
---|---|---|
SHA256 | c5045195a9f2f21406c37b6e2b6c6992b22831bfeed24e58da648ee12ad5f689 |
|
MD5 | f1a3970ca76ced5b184d8033dc834d3e |
|
BLAKE2b-256 | a845661588c538312806df23ea433aa7f8f33eb61a56e28cfc7e309f1b32432d |
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
Algorithm | Hash digest | |
---|---|---|
SHA256 | fcd4e9e389d1dfe893a8e8244285c55dee8e641fd321e122a84b3d9f60c18b07 |
|
MD5 | bf725df204a3c62d9a173ee2a7ef9353 |
|
BLAKE2b-256 | b86e62e3c483bb3958f805b972c00b1f1af5ca77a2ce8baa5626c00927cd7a80 |