Tracker¶
BoxMOT tracking utilities and unified tracker interface.
This module provides the Tracker class for BoxMOT tracking and post-processing utilities for infilling, clustering, and filtering tracks.
MOTModels ¶
Bases: StrEnum
Supported tracker backends exposed by BoxMOT.
Attributes:
| Name | Type | Description |
|---|---|---|
BOTSORT |
str
|
BoT-SORT tracker name used by BoxMOT. Good default when you want motion + appearance matching. |
BOOSTTRACK |
str
|
BoostTrack tracker name used by BoxMOT. Usually improves association under difficult motion/crowding. |
BYTE_TRACK |
str
|
ByteTrack tracker name used by BoxMOT. Faster and simpler; does not require ReID weights. |
OCSORT |
str
|
OCSORT tracker name used by BoxMOT. Motion-centric tracker; useful when appearance features are unreliable. |
STRONGSORT |
str
|
StrongSORT tracker name used by BoxMOT. Appearance-heavy tracker; typically more robust to long occlusions. |
DEEPOCSORT |
str
|
DeepOCSORT tracker name used by BoxMOT. OCSORT variant enhanced with appearance features. |
HYBRIDSORT |
str
|
HybridSORT tracker name used by BoxMOT. Hybrid strategy between motion and appearance matching. |
SFSORT |
str
|
SFSort tracker name used by BoxMOT. Lightweight motion-centric tracking for real-time pipelines. |
ReIDWeights ¶
Bases: StrEnum
Built-in BoxMOT ReID weight file names.
Use these enum values for reid_weights in tracker parameter dataclasses.
MOTBaseConfig
dataclass
¶
MOTBaseConfig(
model: MOTModels = MOTModels.BOTSORT,
per_class: bool = False,
extra_kwargs: dict[str, Any] = dict(),
)
Common configuration fields for BoxMOT tracker creation.
Attributes:
| Name | Type | Description |
|---|---|---|
model |
MOTModels
|
BoxMOT tracker backend for this parameter bundle
(default: |
per_class |
bool
|
Whether to run tracking independently per class (default: |
extra_kwargs |
dict[str, Any]
|
Additional kwargs merged into tracker construction arguments
(default: |
to_kwargs ¶
to_kwargs() -> dict[str, Any]
Convert dataclass fields to keyword arguments for BoxMOT tracker creation.
Source code in src/dnt/track/tracker.py
189 190 191 192 193 194 195 | |
to_dict ¶
to_dict() -> dict[str, Any]
Return dataclass values as a serializable dictionary.
Source code in src/dnt/track/tracker.py
197 198 199 | |
from_dict
classmethod
¶
from_dict(data: dict[str, Any]) -> MOTBaseConfig
Build a parameter object from a dictionary.
Unknown keys are stored in extra_kwargs.
Source code in src/dnt/track/tracker.py
214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 | |
export_yaml ¶
export_yaml(yaml_file: str) -> None
Export parameters to a YAML file.
Source code in src/dnt/track/tracker.py
232 233 234 235 236 237 | |
import_yaml
classmethod
¶
import_yaml(yaml_file: str) -> MOTBaseConfig
Import parameters from a YAML file.
Source code in src/dnt/track/tracker.py
239 240 241 242 243 244 245 246 247 | |
BoTSORTConfig
dataclass
¶
BoTSORTConfig(
model: MOTModels = MOTModels.BOTSORT,
per_class: bool = False,
extra_kwargs: dict[str, Any] = dict(),
reid_weights: ReIDWeights
| str
| None = ReIDWeights.OSNET_X1_0_MSMT17,
track_high_thresh: float = 0.5,
track_low_thresh: float = 0.1,
new_track_thresh: float = 0.6,
match_thresh: float = 0.8,
track_buffer: int = 30,
with_reid: bool = True,
proximity_thresh: float = 0.5,
appearance_thresh: float = 0.25,
)
Bases: MOTBaseConfig
BoTSORT-specific parameters.
Attributes:
| Name | Type | Description |
|---|---|---|
reid_weights |
ReIDWeights | str | None
|
Optional ReID weights path (default: |
track_high_thresh |
float
|
High score threshold for first association (default: |
track_low_thresh |
float
|
Lower score threshold for second association (default: |
new_track_thresh |
float
|
Threshold to initialize new tracks (default: |
match_thresh |
float
|
Matching threshold for association (default: |
track_buffer |
int
|
Number of frames to keep lost tracks (default: |
with_reid |
bool
|
Whether to enable ReID-assisted association (default: |
proximity_thresh |
float
|
Proximity threshold for ReID matching (default: |
appearance_thresh |
float
|
Appearance similarity threshold for ReID matching (default: |
to_kwargs ¶
to_kwargs() -> dict[str, Any]
Convert dataclass fields to keyword arguments for BoxMOT tracker creation.
Source code in src/dnt/track/tracker.py
189 190 191 192 193 194 195 | |
to_dict ¶
to_dict() -> dict[str, Any]
Return dataclass values as a serializable dictionary.
Source code in src/dnt/track/tracker.py
197 198 199 | |
from_dict
classmethod
¶
from_dict(data: dict[str, Any]) -> MOTBaseConfig
Build a parameter object from a dictionary.
Unknown keys are stored in extra_kwargs.
Source code in src/dnt/track/tracker.py
214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 | |
export_yaml ¶
export_yaml(yaml_file: str) -> None
Export parameters to a YAML file.
Source code in src/dnt/track/tracker.py
232 233 234 235 236 237 | |
import_yaml
classmethod
¶
import_yaml(yaml_file: str) -> MOTBaseConfig
Import parameters from a YAML file.
Source code in src/dnt/track/tracker.py
239 240 241 242 243 244 245 246 247 | |
BoostTrackConfig
dataclass
¶
BoostTrackConfig(
model: MOTModels = MOTModels.BOOSTTRACK,
per_class: bool = False,
extra_kwargs: dict[str, Any] = dict(),
reid_weights: ReIDWeights
| str
| None = ReIDWeights.OSNET_X1_0_MSMT17,
det_thresh: float = 0.3,
max_age: int = 30,
min_hits: int = 3,
iou_threshold: float = 0.3,
asso_func: str = "iou",
)
Bases: MOTBaseConfig
BoostTrack-specific parameters.
Attributes:
| Name | Type | Description |
|---|---|---|
reid_weights |
ReIDWeights | str | None
|
Optional ReID weights path (default: |
det_thresh |
float
|
Detection confidence threshold (default: |
max_age |
int
|
Maximum age of unmatched tracks (default: |
min_hits |
int
|
Minimum hits before track confirmation (default: |
iou_threshold |
float
|
IoU threshold for association (default: |
asso_func |
str
|
Association function name (default: |
to_kwargs ¶
to_kwargs() -> dict[str, Any]
Convert dataclass fields to keyword arguments for BoxMOT tracker creation.
Source code in src/dnt/track/tracker.py
189 190 191 192 193 194 195 | |
to_dict ¶
to_dict() -> dict[str, Any]
Return dataclass values as a serializable dictionary.
Source code in src/dnt/track/tracker.py
197 198 199 | |
from_dict
classmethod
¶
from_dict(data: dict[str, Any]) -> MOTBaseConfig
Build a parameter object from a dictionary.
Unknown keys are stored in extra_kwargs.
Source code in src/dnt/track/tracker.py
214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 | |
export_yaml ¶
export_yaml(yaml_file: str) -> None
Export parameters to a YAML file.
Source code in src/dnt/track/tracker.py
232 233 234 235 236 237 | |
import_yaml
classmethod
¶
import_yaml(yaml_file: str) -> MOTBaseConfig
Import parameters from a YAML file.
Source code in src/dnt/track/tracker.py
239 240 241 242 243 244 245 246 247 | |
ByteTrackConfig
dataclass
¶
ByteTrackConfig(
model: MOTModels = MOTModels.BYTE_TRACK,
per_class: bool = False,
extra_kwargs: dict[str, Any] = dict(),
track_thresh: float = 0.5,
match_thresh: float = 0.8,
track_buffer: int = 30,
frame_rate: int = 30,
)
Bases: MOTBaseConfig
ByteTrack-specific parameters.
Attributes:
| Name | Type | Description |
|---|---|---|
track_thresh |
float
|
Detection confidence threshold (default: |
match_thresh |
float
|
Threshold for matching detections to tracks (default: |
track_buffer |
int
|
Number of frames to keep lost tracks (default: |
frame_rate |
int
|
Source video frame rate used by the tracker (default: |
to_kwargs ¶
to_kwargs() -> dict[str, Any]
Convert dataclass fields to keyword arguments for BoxMOT tracker creation.
Source code in src/dnt/track/tracker.py
189 190 191 192 193 194 195 | |
to_dict ¶
to_dict() -> dict[str, Any]
Return dataclass values as a serializable dictionary.
Source code in src/dnt/track/tracker.py
197 198 199 | |
from_dict
classmethod
¶
from_dict(data: dict[str, Any]) -> MOTBaseConfig
Build a parameter object from a dictionary.
Unknown keys are stored in extra_kwargs.
Source code in src/dnt/track/tracker.py
214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 | |
export_yaml ¶
export_yaml(yaml_file: str) -> None
Export parameters to a YAML file.
Source code in src/dnt/track/tracker.py
232 233 234 235 236 237 | |
import_yaml
classmethod
¶
import_yaml(yaml_file: str) -> MOTBaseConfig
Import parameters from a YAML file.
Source code in src/dnt/track/tracker.py
239 240 241 242 243 244 245 246 247 | |
OCSORTConfig
dataclass
¶
OCSORTConfig(
model: MOTModels = MOTModels.OCSORT,
per_class: bool = False,
extra_kwargs: dict[str, Any] = dict(),
det_thresh: float = 0.3,
max_age: int = 30,
min_hits: int = 3,
iou_threshold: float = 0.3,
asso_func: str = "iou",
delta_t: int = 3,
inertia: float = 0.2,
)
Bases: MOTBaseConfig
OCSORT-specific parameters.
Attributes:
| Name | Type | Description |
|---|---|---|
det_thresh |
float
|
Detection confidence threshold (default: |
max_age |
int
|
Maximum age of unmatched tracks (default: |
min_hits |
int
|
Minimum hits before track confirmation (default: |
iou_threshold |
float
|
IoU threshold for association (default: |
asso_func |
str
|
Association function name (default: |
delta_t |
int
|
Time gap used by motion compensation (default: |
inertia |
float
|
Motion inertia weight (default: |
to_kwargs ¶
to_kwargs() -> dict[str, Any]
Convert dataclass fields to keyword arguments for BoxMOT tracker creation.
Source code in src/dnt/track/tracker.py
189 190 191 192 193 194 195 | |
to_dict ¶
to_dict() -> dict[str, Any]
Return dataclass values as a serializable dictionary.
Source code in src/dnt/track/tracker.py
197 198 199 | |
from_dict
classmethod
¶
from_dict(data: dict[str, Any]) -> MOTBaseConfig
Build a parameter object from a dictionary.
Unknown keys are stored in extra_kwargs.
Source code in src/dnt/track/tracker.py
214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 | |
export_yaml ¶
export_yaml(yaml_file: str) -> None
Export parameters to a YAML file.
Source code in src/dnt/track/tracker.py
232 233 234 235 236 237 | |
import_yaml
classmethod
¶
import_yaml(yaml_file: str) -> MOTBaseConfig
Import parameters from a YAML file.
Source code in src/dnt/track/tracker.py
239 240 241 242 243 244 245 246 247 | |
StrongSORTConfig
dataclass
¶
StrongSORTConfig(
model: MOTModels = MOTModels.STRONGSORT,
per_class: bool = False,
extra_kwargs: dict[str, Any] = dict(),
reid_weights: ReIDWeights
| str
| None = ReIDWeights.OSNET_X1_0_MSMT17,
max_dist: float = 0.2,
max_iou_dist: float = 0.7,
max_age: int = 70,
n_init: int = 3,
nn_budget: int = 100,
ema_alpha: float = 0.9,
mc_lambda: float = 0.995,
)
Bases: MOTBaseConfig
StrongSORT-specific parameters.
Attributes:
| Name | Type | Description |
|---|---|---|
reid_weights |
ReIDWeights | str | None
|
Optional ReID weights path (default: |
max_dist |
float
|
Maximum cosine distance for appearance matching (default: |
max_iou_dist |
float
|
Maximum IoU distance for geometric matching (default: |
max_age |
int
|
Maximum age of unmatched tracks (default: |
n_init |
int
|
Minimum hits before track confirmation (default: |
nn_budget |
int
|
Maximum size of appearance feature gallery (default: |
ema_alpha |
float
|
EMA factor for appearance embeddings (default: |
mc_lambda |
float
|
Motion compensation blending factor (default: |
to_kwargs ¶
to_kwargs() -> dict[str, Any]
Convert dataclass fields to keyword arguments for BoxMOT tracker creation.
Source code in src/dnt/track/tracker.py
189 190 191 192 193 194 195 | |
to_dict ¶
to_dict() -> dict[str, Any]
Return dataclass values as a serializable dictionary.
Source code in src/dnt/track/tracker.py
197 198 199 | |
from_dict
classmethod
¶
from_dict(data: dict[str, Any]) -> MOTBaseConfig
Build a parameter object from a dictionary.
Unknown keys are stored in extra_kwargs.
Source code in src/dnt/track/tracker.py
214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 | |
export_yaml ¶
export_yaml(yaml_file: str) -> None
Export parameters to a YAML file.
Source code in src/dnt/track/tracker.py
232 233 234 235 236 237 | |
import_yaml
classmethod
¶
import_yaml(yaml_file: str) -> MOTBaseConfig
Import parameters from a YAML file.
Source code in src/dnt/track/tracker.py
239 240 241 242 243 244 245 246 247 | |
DeepOCSORTConfig
dataclass
¶
DeepOCSORTConfig(
model: MOTModels = MOTModels.DEEPOCSORT,
per_class: bool = False,
extra_kwargs: dict[str, Any] = dict(),
reid_weights: ReIDWeights
| str
| None = ReIDWeights.OSNET_X1_0_MSMT17,
det_thresh: float = 0.3,
max_age: int = 30,
min_hits: int = 3,
iou_threshold: float = 0.3,
asso_func: str = "iou",
delta_t: int = 3,
inertia: float = 0.2,
)
Bases: MOTBaseConfig
DeepOCSORT-specific parameters.
Attributes:
| Name | Type | Description |
|---|---|---|
reid_weights |
ReIDWeights | str | None
|
Optional ReID weights path (default: |
det_thresh |
float
|
Detection confidence threshold (default: |
max_age |
int
|
Maximum age of unmatched tracks (default: |
min_hits |
int
|
Minimum hits before track confirmation (default: |
iou_threshold |
float
|
IoU threshold for association (default: |
asso_func |
str
|
Association function name (default: |
delta_t |
int
|
Time gap used by motion compensation (default: |
inertia |
float
|
Motion inertia weight (default: |
to_kwargs ¶
to_kwargs() -> dict[str, Any]
Convert dataclass fields to keyword arguments for BoxMOT tracker creation.
Source code in src/dnt/track/tracker.py
189 190 191 192 193 194 195 | |
to_dict ¶
to_dict() -> dict[str, Any]
Return dataclass values as a serializable dictionary.
Source code in src/dnt/track/tracker.py
197 198 199 | |
from_dict
classmethod
¶
from_dict(data: dict[str, Any]) -> MOTBaseConfig
Build a parameter object from a dictionary.
Unknown keys are stored in extra_kwargs.
Source code in src/dnt/track/tracker.py
214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 | |
export_yaml ¶
export_yaml(yaml_file: str) -> None
Export parameters to a YAML file.
Source code in src/dnt/track/tracker.py
232 233 234 235 236 237 | |
import_yaml
classmethod
¶
import_yaml(yaml_file: str) -> MOTBaseConfig
Import parameters from a YAML file.
Source code in src/dnt/track/tracker.py
239 240 241 242 243 244 245 246 247 | |
HybridSORTConfig
dataclass
¶
HybridSORTConfig(
model: MOTModels = MOTModels.HYBRIDSORT,
per_class: bool = False,
extra_kwargs: dict[str, Any] = dict(),
reid_weights: ReIDWeights
| str
| None = ReIDWeights.OSNET_X1_0_MSMT17,
det_thresh: float = 0.3,
max_age: int = 30,
min_hits: int = 3,
iou_threshold: float = 0.3,
asso_func: str = "iou",
)
Bases: MOTBaseConfig
HybridSORT-specific parameters.
Attributes:
| Name | Type | Description |
|---|---|---|
reid_weights |
ReIDWeights | str | None
|
Optional ReID weights path (default: |
det_thresh |
float
|
Detection confidence threshold (default: |
max_age |
int
|
Maximum age of unmatched tracks (default: |
min_hits |
int
|
Minimum hits before track confirmation (default: |
iou_threshold |
float
|
IoU threshold for association (default: |
asso_func |
str
|
Association function name (default: |
to_kwargs ¶
to_kwargs() -> dict[str, Any]
Convert dataclass fields to keyword arguments for BoxMOT tracker creation.
Source code in src/dnt/track/tracker.py
189 190 191 192 193 194 195 | |
to_dict ¶
to_dict() -> dict[str, Any]
Return dataclass values as a serializable dictionary.
Source code in src/dnt/track/tracker.py
197 198 199 | |
from_dict
classmethod
¶
from_dict(data: dict[str, Any]) -> MOTBaseConfig
Build a parameter object from a dictionary.
Unknown keys are stored in extra_kwargs.
Source code in src/dnt/track/tracker.py
214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 | |
export_yaml ¶
export_yaml(yaml_file: str) -> None
Export parameters to a YAML file.
Source code in src/dnt/track/tracker.py
232 233 234 235 236 237 | |
import_yaml
classmethod
¶
import_yaml(yaml_file: str) -> MOTBaseConfig
Import parameters from a YAML file.
Source code in src/dnt/track/tracker.py
239 240 241 242 243 244 245 246 247 | |
SFSORTConfig
dataclass
¶
SFSORTConfig(
model: MOTModels = MOTModels.SFSORT,
per_class: bool = False,
extra_kwargs: dict[str, Any] = dict(),
det_thresh: float = 0.3,
max_age: int = 30,
min_hits: int = 3,
iou_threshold: float = 0.3,
asso_func: str = "iou",
)
Bases: MOTBaseConfig
SFSORT-specific parameters.
Attributes:
| Name | Type | Description |
|---|---|---|
det_thresh |
float
|
Detection confidence threshold (default: |
max_age |
int
|
Maximum age of unmatched tracks (default: |
min_hits |
int
|
Minimum hits before track confirmation (default: |
iou_threshold |
float
|
IoU threshold for association (default: |
asso_func |
str
|
Association function name (default: |
to_kwargs ¶
to_kwargs() -> dict[str, Any]
Convert dataclass fields to keyword arguments for BoxMOT tracker creation.
Source code in src/dnt/track/tracker.py
189 190 191 192 193 194 195 | |
to_dict ¶
to_dict() -> dict[str, Any]
Return dataclass values as a serializable dictionary.
Source code in src/dnt/track/tracker.py
197 198 199 | |
from_dict
classmethod
¶
from_dict(data: dict[str, Any]) -> MOTBaseConfig
Build a parameter object from a dictionary.
Unknown keys are stored in extra_kwargs.
Source code in src/dnt/track/tracker.py
214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 | |
export_yaml ¶
export_yaml(yaml_file: str) -> None
Export parameters to a YAML file.
Source code in src/dnt/track/tracker.py
232 233 234 235 236 237 | |
import_yaml
classmethod
¶
import_yaml(yaml_file: str) -> MOTBaseConfig
Import parameters from a YAML file.
Source code in src/dnt/track/tracker.py
239 240 241 242 243 244 245 246 247 | |
Tracker ¶
Tracker(
config: BoxMOTModelParams | None = None,
config_yaml: str | None = None,
device: str = "auto",
half: bool = False,
output_score_cls: bool = True,
boxmot_verbose: bool = False,
)
Unified interface for BoxMOT tracking and track post-processing.
This class runs BoxMOT tracking given a detection file and source video. It also provides post-processing utilities to infill missing frames, split tracks by large gaps, and drop short tracks.
Attributes:
| Name | Type | Description |
|---|---|---|
TRACK_FIELDS |
list[str]
|
Standard output columns for tracking and post-processing utilities (default: class constant). |
device |
str
|
Device string used by deep trackers (default: |
half |
bool
|
Whether half precision is enabled for deep trackers (default: |
boxmot_model |
MOTModels
|
Selected BoxMOT tracker backend (default: |
boxmot_config |
BoxMOTModelConfig
|
Configuration dataclass instance for BoxMOT tracker creation (default: model-specific defaults). |
boxmot_verbose |
bool
|
If False, suppress BoxMOT INFO/SUCCESS logging output. |
output_score_cls |
bool
|
Whether to include tracker |
REID_WEIGHTS_DIR |
Path
|
Directory where relative ReID weights are resolved and stored. |
DEFAULT_REID_WEIGHT |
str
|
Fallback ReID weight file name used when a model expects ReID and no weight is explicitly set. |
Initialize the tracker.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
config
|
BoxMOTModelConfig
|
Configuration bundle for BoxMOT tracker creation. Tracker backend
is selected from |
None
|
config_yaml
|
str
|
YAML file containing model-aware config. When provided,
values loaded from YAML override |
None
|
device
|
str
|
Device string used by deep trackers (default: |
'auto'
|
half
|
bool
|
Whether half precision is enabled for deep trackers (default: |
False
|
output_score_cls
|
bool
|
If True, output tracker confidence and class values in |
True
|
boxmot_verbose
|
bool
|
If False, suppress BoxMOT INFO/SUCCESS logging output. |
False
|
Source code in src/dnt/track/tracker.py
639 640 641 642 643 644 645 646 647 648 649 650 651 652 653 654 655 656 657 658 659 660 661 662 663 664 665 666 667 668 669 670 671 672 673 674 675 676 677 678 679 680 681 682 683 684 | |
track ¶
track(
det_file: str,
out_file: str,
video_file: str | None = None,
show: bool = False,
video_index: int | None = None,
video_tot: int | None = None,
message: str | None = None,
) -> pd.DataFrame
Run tracking on a single detection file using BoxMOT.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
det_file
|
str
|
Path to detection file in DNT detection format (frame, -, x, y, width, height, confidence, class_id). |
required |
out_file
|
str
|
Path to write tracking results. If empty string, results are not saved. |
required |
video_file
|
str
|
Path to source video file. Required for BoxMOT tracker. |
None
|
show
|
bool
|
If True (default: False), display live tracking preview with bounding boxes and track IDs. Press 's' to toggle preview, 'ESC' to hide, 'q' to stop tracking early. |
False
|
video_index
|
int
|
Index of current video in batch (for progress bar display). |
None
|
video_tot
|
int
|
Total number of videos in batch (for complete progress context). |
None
|
message
|
str | None
|
Optional progress text shown in the progress bar. If None, the video stem is used (default: None). |
None
|
Returns:
| Type | Description |
|---|---|
DataFrame
|
Tracking results with columns: frame, track, x, y, w, h, score, cls, r3, r4 Each row represents one detected object per frame. |
Raises:
| Type | Description |
|---|---|
FileNotFoundError
|
If det_file or video_file does not exist. |
ValueError
|
If video_file is None. |
Notes
The tracker processes detections frame-by-frame, maintaining track IDs across frames. Detection coordinates are converted from (x1, y1, x2, y2) to (x, y, width, height) format for BoxMOT.
Track IDs are persistent across frame sequences and reused if tracks are lost and then re-acquired within track_buffer frames.
Source code in src/dnt/track/tracker.py
686 687 688 689 690 691 692 693 694 695 696 697 698 699 700 701 702 703 704 705 706 707 708 709 710 711 712 713 714 715 716 717 718 719 720 721 722 723 724 725 726 727 728 729 730 731 732 733 734 735 736 737 738 739 740 741 742 743 744 745 746 747 748 749 750 751 752 753 754 755 756 757 758 759 760 761 | |
track_batch ¶
track_batch(
det_files: list[str] | None = None,
video_files: list[str] | None = None,
output_path: str | None = None,
is_overwrite: bool = False,
is_report: bool = True,
message: str | None = None,
) -> list[str]
Run tracking on multiple detection files sequentially.
Parameters:
| Name | Type | Description | Default |
|---|---|---|---|
det_files
|
list[str] | None
|
List of detection file paths. Each file should contain frame-level detections in CSV format. If None (default), returns empty list. |
None
|
video_files
|
list[str] | None
|
List of corresponding source video file paths for each detection file. Length should match det_files. Required for BoxMOT tracking. |
None
|
output_path
|
str | None
|
Directory to save tracking results. Track files are named based on input filename with '_track.txt' suffix. If None (default), tracking still runs but results are not persisted. |
None
|
is_overwrite
|
bool
|
If False (default), skip tracking for videos with existing output files. |
False
|
is_report
|
bool
|
If True (default), include skipped files in returned list. |
True
|
message
|
str | None
|
Optional progress text shown in each tracking progress bar. If None (default), each video's stem is used. |
None
|
Returns:
| Type | Description |
|---|---|
list[str]
|
List of output track file paths. Includes both newly created and existing files (if is_report=True). Empty list if det_files is None. |
Notes
Processing is sequential (not parallel). Each detection file is tracked in order with progress display showing "Tracking X of Y".
Files matching between det_files and video_files by index position. If video_files is shorter than det_files, missing videos are left None and those detections are skipped.
Source code in src/dnt/track/tracker.py
763 764 765 766 767 768 769 770 771 772 773 774 775 776 777 778 779 780 781 782 783 784 785 786 787 788 789 790 791 792 793 794 795 796 797 798 799 800 801 802 803 804 805 806 807 808 809 810 811 812 813 814 815 816 817 818 819 820 821 822 823 824 825 826 827 828 829 830 831 832 833 834 835 836 837 838 839 840 841 842 843 844 845 846 847 848 | |
export_config_to_yaml
staticmethod
¶
export_config_to_yaml(
yaml_file: str, config: BoxMOTModelParams
) -> None
Export model-aware BoxMOT config to a YAML file.
Source code in src/dnt/track/tracker.py
994 995 996 997 998 999 1000 1001 1002 1003 | |
import_config_from_yaml
staticmethod
¶
import_config_from_yaml(
yaml_file: str,
) -> BoxMOTModelParams
Import model-aware BoxMOT config from a YAML file.
Source code in src/dnt/track/tracker.py
1005 1006 1007 1008 1009 1010 1011 1012 1013 1014 1015 1016 | |
export_params_to_yaml
staticmethod
¶
export_params_to_yaml(
yaml_file: str, params: BoxMOTModelParams
) -> None
Export model-aware BoxMOT params to a YAML file (backward-compatible wrapper).
Source code in src/dnt/track/tracker.py
1019 1020 1021 1022 1023 1024 1025 | |
import_params_from_yaml
staticmethod
¶
import_params_from_yaml(
yaml_file: str,
) -> BoxMOTModelParams
Import model-aware BoxMOT params from a YAML file (backward-compatible wrapper).
Source code in src/dnt/track/tracker.py
1027 1028 1029 1030 | |
export_current_config_to_yaml ¶
export_current_config_to_yaml(yaml_file: str) -> None
Export this tracker's active model and config to YAML.
Source code in src/dnt/track/tracker.py
1032 1033 1034 1035 1036 1037 | |
export_current_params_to_yaml ¶
export_current_params_to_yaml(yaml_file: str) -> None
Export this tracker's active model and config to YAML (backward-compatible wrapper).
Source code in src/dnt/track/tracker.py
1039 1040 1041 | |