A collection of simple NumPy-based filters and trackers optimized for real-time performance
Project description
Simple Filters and Tracking for Time-Series using NumPy
pip install simple-filters
This is a collection of simple filters and trackers based on NumPy and SciPy, which are optimized for real-time performance. This is an example that applies tracking to non-recurrent methods like SMOKE with the DummyFilterStrategy:
Filter
A filter acts as a container for a time-series. The length of the time-series is kept constant after initial filling, according to the history_size
specified.
Currently, two filters are implemented:
- NumpyFilterStrategy: Applies a numpy function (e.g. numpy.mean) to the time-series.
- PolynomialFilterStrategy: Returns the filtered last item (and optionally predicts the next item) of a multi-dimensional time series using a polynomial regression. The strategy can be applied to sensor data to retain smoothness while ensuring low latency and avoiding offsets with outliers.
- DummyFilterStrategy: Simply returns the last item of the time-series.
Set up your filter:
from simple_filters import Filter, PolynomialFilterStrategy, NumpyFilterStrategy, DummyFilterStrategy
strategy_1 = PolynomialFilterStrategy(poly_degree=3, outlier_rejection_ratio=2.0)
strategy_2 = NumpyFilterStrategy(np.mean)
strategy_3 = DummyFilterStrategy()
filter = Filter(strategy_1, history_size=10)
Fill the history with a 1D array:
filter.update([1.0, 2.0])
filter.update([1.1, 2.1])
Get the last filtered item at the current_time, or by specifying a time step in the future (time=1
). Note that only PolynomialFilterStrategy allows for predicting the future.
result_current = filter.eval()
result_future = filter.eval(time=1)
Tracker
Oftentimes, multiple objects must be tracked that also require filtering. SimpleFilters implements a simple multi-object tracker for this purpose. The tracker associates objects by applying minimum weight matching to a distance graph.
The following properties can be defined:
- distance_threshold: Maximum distance to match objects - when the threshold is exceeded, a new object will be created
- max_time_to_live: If an object is not seen, it is still retained for the given number of state updates
- time_to_birth: The number of observations needed until an object is born
- filter_prototype: A filter that will be cloned for each new appearing object
- distance_function: A lambda (x1, x2) that returns a distance between the two arrays
The PolynomialFilterStrategy is especially suitable for tracking, as it can predict the future state of the object according to its reconstructed polynomial:
from simple_filters import Filter, PolynomialFilterStrategy, Tracker
strategy = PolynomialFilterStrategy(poly_degree=3, outlier_rejection_ratio=2.0)
filter_prototype = Filter(strategy, history_size=10)
tracker = Tracker(filter_prototype, distance_threshold=1.0, time_to_live=1)
Update your tracker with a 2D array:
tracker.update([[1.0, 1.0], [2.0, 2.1]])
tracker.update([[1.1, 1.1], [1.9, 2.0], [3.1, 3.0]])
Retrieve the results:
# Access the list of objects like any filter:
list_of_objects = tracker.get_tracked_objects()
list_of_objects[0].eval(0) # get the latest state ([1.1, 1.1])
list_of_objects[0].id # get the tracking ID
# Or convert to a NumPy array:
np_array = tracker.to_numpy_array()
Testing
Simply run pytest
in the project directory.
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
Built Distribution
File details
Details for the file simple-filters-0.1.6.tar.gz
.
File metadata
- Download URL: simple-filters-0.1.6.tar.gz
- Upload date:
- Size: 13.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.8.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 803faeb1429ee58797d73501b3df1b485b07592240ac3be007c5a7fdfe9c94db |
|
MD5 | 9232842d7a9104c6bb2a553355f16720 |
|
BLAKE2b-256 | fb8a095ded14197ed79bc6fff6c681a069adff3a0e0f204e67d7b02893a6d35d |
File details
Details for the file simple_filters-0.1.6-py3-none-any.whl
.
File metadata
- Download URL: simple_filters-0.1.6-py3-none-any.whl
- Upload date:
- Size: 15.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.8.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 224a59f4b1636f8a7d3d63944f728cc612f7a2106ec11cdeb6ca705b52d3a2ce |
|
MD5 | f6af9886be872066a7e8f68133d8f1e9 |
|
BLAKE2b-256 | 04bca3f20502085fc86d42887d66f7b00a1da2a7ff04254b844297303684574c |