Tracker using kinematic Kalman filters.
Project description
Kinematic Tracker
📖 Live docs: https://kovalp.github.io/kinematic-tracker-docs/
This tracker is based on kinematic Kalman filters. The system state can consist of multiple parts,
each defined by its kinematic order and dimensionality. For example, to track cuboids
aligned with Cartesian axes, we might decide for a constant-acceleration motion model
for Cartesian coordinates and a constant-position motion model for the sizes of the cuboids.
This choice encoded by orders = [3, 1]. The dimensionality of both parts (coordinates and sizes)
is 3. Therefore dimensions = [3, 3] in our example.
The state of the cuboids aligned with Cartesian axis will have 12 variables. Internally, a block-diagonal states are used, i.e.
state = p_x, v_x, a_x, p_y, v_y, a_y, p_z, v_z, a_z, s_x, s_y, s_z
To simplify the input/output processing, one might find attractive a derivative-sorted order
state = p_x, p_y, p_z, s_x, s_y, s_z, v_x, v_y, v_z, a_x, a_y, a_z
This package provides utility classes for such conversion (block-diagonal ↔ derivative sorted).
Process noise models
The tracker supports various process noise models, including a custom adaptive process noise model based on a white-noise assumption.
Association metrics
A number of association metrics are implemented. Some of the metrics are experimental.
- Mahalanobis with a process-measurement noise sum covariance (HPH + R) -- default.
- 3D axes-aligned GIoU (volumetric GIoU for cuboids).
- 3D yaw-only GIoU (volumetric GIoU for cuboids oriented by yaw).
- Mahalanobis with size-modulated covariance (experimental).
- IoU-like two-yaw (experimental): based on Mahalanobis distance with diagonal covariance.
Installation
If you plan to use OpenCV with HighGUI, then
pip install kinematic-tracker[gui]
If you do not plan to use OpenCV's GUI, then
pip install kinematic-tracker[headless]
In any case, you choose one extra: gui or headless.
Usage
Simple examples are available in the test/tutorials folder.
The test folder is available in the source package
pip download kinematic-tracker --no-binary :all: --no-deps
Use the kinematic-tracker as dependency
uv add kinematic-tracker --extra headless
If you happen to need GUI-enabled version of OpenCV, then
uv add kinematic-tracker --extra gui
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file kinematic_tracker-20.10.0.tar.gz.
File metadata
- Download URL: kinematic_tracker-20.10.0.tar.gz
- Upload date:
- Size: 266.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.10 {"installer":{"name":"uv","version":"0.10.10","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"13","id":"trixie","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4b5ffcc7fa0be5910bf032fa8a37bd362232066b8154f3edd582479576432bd1
|
|
| MD5 |
66e187e95db32ac096754a3b82383a64
|
|
| BLAKE2b-256 |
707a585454415b3b288abd5a815a933bf35c40d47097cd716a50e5e57c9358d8
|
File details
Details for the file kinematic_tracker-20.10.0-py3-none-any.whl.
File metadata
- Download URL: kinematic_tracker-20.10.0-py3-none-any.whl
- Upload date:
- Size: 58.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.10 {"installer":{"name":"uv","version":"0.10.10","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"13","id":"trixie","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d819bb60dcb64f49c2920446556c96025f2a3bd96a4cdd51e7b6575199fbdf24
|
|
| MD5 |
d3da024fcc19aaa18bb2596c2fa7c217
|
|
| BLAKE2b-256 |
b2f06851d45637d896911e16457d6db87650d980a60424590208ddb1801f752a
|