Network flow based tracker with guided error correction
Project description
tracktour
tracktour is a simple object tracker based on a network flow linear model. tracktour takes a dataframe of detected objects and solves a linear program (currently using Gurobi, but we will soon add an open source solver interface) to produce tracking results.
tracktour is rapidly changing and its API will change without deprecation warnings.
Usage
The Tracker
object is the interface for producing tracking solutions. Below is a toy example with explicitly defined detections.
coords = [
(0, 50.0, 50.0),
(0, 40, 50),
(0, 30, 57),
(1, 50, 52),
(1, 38, 51),
(1, 29, 60),
(2, 52, 53),
(2, 37, 53),
(2, 28, 64),
]
coords = pd.DataFrame(coords, columns=["t", "y", "x"])
# initialize Tracker object
tracker = Tracker(
im_shape=(100, 100), # size of the image detections come from. Affects cost of detections appearing/disappearing
k_neighbours=2 # number of neighbours to consider for assignment in the next frame (default=10)
)
# solve
tracked = tracker.solve(coords)
The Tracked
object contains a copy of the detections, potentially reindexed, and a dataframe of edges that make up the solution.
Columns u
and v
in tracked_edges
are direct indices into tracked_detections
.
print(tracked.tracked_detections)
print(tracked.tracked_edges)
You may want to convert the solution into a networkx graph for easier manipulation.
solution_graph = tracked.as_nx_digraph()
Extracting Detections
If you're starting from an image segmentation, you can use the get_im_centers
or extract_im_centers
functions.
If your segmentation is already loaded into a numpy array, use extract_im_centers
. The returned detections
DataFrame is ready for use with the Tracker
.
detections, min_t, max_t, corners = extract_im_centers(segmentation)
If your segmentation is in Cell Tracking Challenge format and lives in single tiffs per frame in a directory, use get_im_centers
. This will also return
the segmentation as a numpy array.
seg, detections, min_t, max_t, corners = get_im_centers('path/to/01_RES/')
CLI Tool - Cell Tracking Challenge
If you're working with Cell Tracking Challenge formatted datasets, you can use the CLI to extract detections, run tracktour, and save output in CTC format.
$ tracktour ctc /path/to/seg/ /path/to/save/ -k 8
Support
Please feel free to open issues with feature requests, bug reports, questions on usage, etc.
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 tracktour-0.0.4.tar.gz
.
File metadata
- Download URL: tracktour-0.0.4.tar.gz
- Upload date:
- Size: 25.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.0.0 CPython/3.12.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 36a11a87db0a7f049524836b87f54d35176bd638dd9c11cba602964f4e3b6a76 |
|
MD5 | cbbd49919e9602f14381e928c154d268 |
|
BLAKE2b-256 | 44adbcdb0fb33518e37f516cf0d93e1b2a022dc3a358182dd86536b464c05d4b |
File details
Details for the file tracktour-0.0.4-py3-none-any.whl
.
File metadata
- Download URL: tracktour-0.0.4-py3-none-any.whl
- Upload date:
- Size: 25.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.0.0 CPython/3.12.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 7ee5db3e7bf354fa959bb4d9ba0fbfb6b79b81ced73ac868f468a8894a871c4e |
|
MD5 | 4714869ab75f1fefd2268115050010a2 |
|
BLAKE2b-256 | 51efcf4d4f9f7561deefc2033924df52455cf5b1ed342c7d45843538ba3cac52 |