Time series synchronization and resample library.
Project description
What is syncing?
syncing is an useful library to synchronise and re-sample time series.
Synchronization is based on the fourier transform and the re-sampling is performed with a specific interpolation method.
Installation
To install it use (with root privileges):
$ pip install syncing
Or download the last git version and use (with root privileges):
$ python setup.py install
Install extras
Some additional functionality is enabled installing the following extras:
cli: enables the command line interface.
plot: enables to plot the model process and its workflow.
dev: installs all libraries plus the development libraries.
To install syncing and all extras (except development libraries), do:
$ pip install syncing[all]
Synchronising Laboratory Data
This example shows how to synchronise two data-sets obd and dyno (respectively they are the On-Board Diagnostics of a vehicle and Chassis dynamometer) with a reference signal ref. To achieve this we use the model syncing model to visualize the model:
>>> from syncing.model import dsp >>> model = dsp.register() >>> model.plot(view=False) SiteMap(...)[graph]
Tip: You can explore the diagram by clicking on it.
First of all, we generate synthetically the data-sets to feed the model:
>>> import numpy as np >>> data_sets = {} >>> time = np.arange(0, 150, .1) >>> velocity = (1 + np.sin(time / 10)) * 60 >>> data_sets['ref'] = dict( ... time=time, # [10 Hz] ... velocity=velocity / 3.6 # [m/s] ... ) >>> data_sets['obd'] = dict( ... time=time[::10] + 12, # 1 Hz ... velocity=velocity[::10] + np.random.normal(0, 5, 150), # [km/h] ... engine_rpm=np.maximum( ... np.random.normal(velocity[::10] * 3 + 600, 5), 800 ... ) # [RPM] ... ) >>> data_sets['dyno'] = dict( ... time=time + 6.66, # 10 Hz ... velocity=velocity + np.random.normal(0, 1, 1500) # [km/h] ... )
To synchronize the data-sets and plot the workflow:
>>> from syncing.model import dsp >>> sol = dsp(dict( ... data=data_sets, x_label='time', y_label='velocity', ... reference_name='ref', interpolation_method='cubic' ... )) >>> sol.plot(view=False) SiteMap(...)[graph]
Finally, we can analyze the time shifts and the synchronized and re-sampled data-sets:
>>> import pandas as pd >>> import schedula as sh >>> pd.DataFrame(sol['shifts'], index=[0]) # doctest: +SKIP obd dyno ... >>> df = pd.DataFrame(dict(sh.stack_nested_keys(sol['resampled']))) >>> df.columns = df.columns.map('/'.join) >>> df['ref/velocity'] *= 3.6 >>> ax = df.set_index('ref/time').plot(secondary_y='obd/engine_rpm') >>> ax.set_ylabel('[km/h]'); ax.right_ax.set_ylabel('[RPM]') Text(...)
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 syncing-1.0.3.tar.gz
.
File metadata
- Download URL: syncing-1.0.3.tar.gz
- Upload date:
- Size: 14.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.19.1 setuptools/40.2.0 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/3.7.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | af94e23afc92fedacffa8207cb9ba3340988ea0e0ab02957f5f5bb5aac2fa948 |
|
MD5 | 0777c17820ea5abc7502fd657bef9904 |
|
BLAKE2b-256 | f73dd7e4a860159872e0bbe403be457a61548e731a8db7d4439799441a5e3840 |
File details
Details for the file syncing-1.0.3-py2.py3-none-any.whl
.
File metadata
- Download URL: syncing-1.0.3-py2.py3-none-any.whl
- Upload date:
- Size: 13.6 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.19.1 setuptools/40.2.0 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/3.7.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | ceeec69af49eb748c7908e9703bc450858b3f7ecfd34361ac4333826a6ee9080 |
|
MD5 | 0795f0885213db62f4c1caba25e3dac3 |
|
BLAKE2b-256 | cee39b9d16142d208a2a99842030c37f8159fea69103063fb6a6e196ea46869d |