|
|
|
"""This module defines the base classes and structures for object tracking in YOLO.""" |
|
|
|
from collections import OrderedDict |
|
|
|
import numpy as np |
|
|
|
|
|
class TrackState: |
|
""" |
|
Enumeration class representing the possible states of an object being tracked. |
|
|
|
Attributes: |
|
New (int): State when the object is newly detected. |
|
Tracked (int): State when the object is successfully tracked in subsequent frames. |
|
Lost (int): State when the object is no longer tracked. |
|
Removed (int): State when the object is removed from tracking. |
|
""" |
|
|
|
New = 0 |
|
Tracked = 1 |
|
Lost = 2 |
|
Removed = 3 |
|
|
|
|
|
class BaseTrack: |
|
""" |
|
Base class for object tracking, providing foundational attributes and methods. |
|
|
|
Attributes: |
|
_count (int): Class-level counter for unique track IDs. |
|
track_id (int): Unique identifier for the track. |
|
is_activated (bool): Flag indicating whether the track is currently active. |
|
state (TrackState): Current state of the track. |
|
history (OrderedDict): Ordered history of the track's states. |
|
features (list): List of features extracted from the object for tracking. |
|
curr_feature (any): The current feature of the object being tracked. |
|
score (float): The confidence score of the tracking. |
|
start_frame (int): The frame number where tracking started. |
|
frame_id (int): The most recent frame ID processed by the track. |
|
time_since_update (int): Frames passed since the last update. |
|
location (tuple): The location of the object in the context of multi-camera tracking. |
|
|
|
Methods: |
|
end_frame: Returns the ID of the last frame where the object was tracked. |
|
next_id: Increments and returns the next global track ID. |
|
activate: Abstract method to activate the track. |
|
predict: Abstract method to predict the next state of the track. |
|
update: Abstract method to update the track with new data. |
|
mark_lost: Marks the track as lost. |
|
mark_removed: Marks the track as removed. |
|
reset_id: Resets the global track ID counter. |
|
""" |
|
|
|
_count = 0 |
|
|
|
def __init__(self): |
|
"""Initializes a new track with unique ID and foundational tracking attributes.""" |
|
self.track_id = 0 |
|
self.is_activated = False |
|
self.state = TrackState.New |
|
self.history = OrderedDict() |
|
self.features = [] |
|
self.curr_feature = None |
|
self.score = 0 |
|
self.start_frame = 0 |
|
self.frame_id = 0 |
|
self.time_since_update = 0 |
|
self.location = (np.inf, np.inf) |
|
|
|
@property |
|
def end_frame(self): |
|
"""Return the last frame ID of the track.""" |
|
return self.frame_id |
|
|
|
@staticmethod |
|
def next_id(): |
|
"""Increment and return the global track ID counter.""" |
|
BaseTrack._count += 1 |
|
return BaseTrack._count |
|
|
|
def activate(self, *args): |
|
"""Abstract method to activate the track with provided arguments.""" |
|
raise NotImplementedError |
|
|
|
def predict(self): |
|
"""Abstract method to predict the next state of the track.""" |
|
raise NotImplementedError |
|
|
|
def update(self, *args, **kwargs): |
|
"""Abstract method to update the track with new observations.""" |
|
raise NotImplementedError |
|
|
|
def mark_lost(self): |
|
"""Mark the track as lost.""" |
|
self.state = TrackState.Lost |
|
|
|
def mark_removed(self): |
|
"""Mark the track as removed.""" |
|
self.state = TrackState.Removed |
|
|
|
@staticmethod |
|
def reset_id(): |
|
"""Reset the global track ID counter.""" |
|
BaseTrack._count = 0 |
|
|