Repository for OpenCV's extra modules
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

7.3 KiB

Tracking diagrams

General diagram

@startuml{tracking_uml_general.png} package "Tracker" package "TrackerFeature" package "TrackerSampler" package "TrackerModel"

Tracker -> TrackerModel: create Tracker -> TrackerSampler: create Tracker -> TrackerFeature: create @enduml

Tracker diagram

@startuml{tracking_uml_tracking.png} package "Tracker package" #DDDDDD {

class Algorithm

class Tracker{ Ptr featureSet; Ptr sampler;

Ptr model;
+static Ptr create(const string& trackerType);
+bool init(const Mat& image, const Rect& boundingBox);
+bool update(const Mat& image, Rect& boundingBox);
}
class Tracker
note right: Tracker is the general interface for each specialized trackers
class TrackerMIL{
+static Ptr createTracker(const TrackerMIL::Params &parameters);
+virtual ~TrackerMIL();
}
class TrackerBoosting{
+static Ptr createTracker(const TrackerBoosting::Params &parameters);
+virtual ~TrackerBoosting();
}
Algorithm <
Tracker <
Tracker <

note "Single instance of the Tracker" as N1 TrackerBoosting .. N1 TrackerMIL .. N1 }

@enduml

TrackerFeatureSet diagram

@startuml{tracking_uml_feature.png} package "TrackerFeature package" #DDDDDD {

class TrackerFeatureSet{ -vector<pair<string, Ptr > > features -vector responses ... TrackerFeatureSet();

~TrackerFeatureSet();
+extraction(const std::vector& images);
+selection();
+removeOutliers();
+vector response getResponses();
+vector<pair<string TrackerFeatureType, Ptr > > getTrackerFeatures();
+bool addTrackerFeature(string trackerFeatureType);
+bool addTrackerFeature(Ptr& feature);
-clearResponses();
}

class TrackerFeature <>{ static Ptr = create(const string& trackerFeatureType); compute(const std::vector& images, Mat& response); selection(Mat& response, int npoints); } note bottom: Can be specialized as in table II\nA tracker can use more types of features

class TrackerFeatureFeature2D{

-vector keypoints
TrackerFeatureFeature2D(string detectorType, string descriptorType);
~TrackerFeatureFeature2D();
---
compute(const std::vector& images, Mat& response);
selection( Mat& response, int npoints);
}
class TrackerFeatureHOG{
TrackerFeatureHOG();
~TrackerFeatureHOG();
---
compute(const std::vector& images, Mat& response);
selection(Mat& response, int npoints);
}

TrackerFeatureSet *-- TrackerFeature TrackerFeature <|-- TrackerFeatureHOG TrackerFeature <|-- TrackerFeatureFeature2D

note "Per readability and simplicity in this diagram\n there are only two TrackerFeature but you\n can considering the implementation of the other TrackerFeature" as N1 TrackerFeatureHOG .. N1 TrackerFeatureFeature2D .. N1 }

@enduml

TrackerModel diagram

@startuml{tracking_uml_model.png} package "TrackerModel package" #DDDDDD {

class Typedef << (T,#FF7700) >>{ ConfidenceMap Trajectory }

class TrackerModel{ -vector confidenceMaps; -Trajectory trajectory; -Ptr stateEstimator; ... TrackerModel(); ~TrackerModel();

+bool setTrackerStateEstimator(Ptr<TrackerStateEstimator> trackerStateEstimator);
+Ptr<TrackerStateEstimator> getTrackerStateEstimator();

+void modelEstimation(const vector<Mat>& responses);
+void modelUpdate();
+void setLastTargetState(const Ptr<TrackerTargetState> lastTargetState);
+void runStateEstimator();

+const vector<ConfidenceMap>& getConfidenceMaps();
+const ConfidenceMap& getLastConfidenceMap();

} class TrackerTargetState <>{

Point2f targetPosition;
Point2f getTargetPosition();
void setTargetPosition(Point2f position);
}
class TrackerTargetState
note bottom: Each tracker can create own state

class TrackerStateEstimator <>{ ~TrackerStateEstimator(); static Ptr create(const String& trackeStateEstimatorType); Ptr estimate(const vector& confidenceMaps) void update(vector& confidenceMaps) }

class TrackerStateEstimatorSVM{ TrackerStateEstimatorSVM() ~TrackerStateEstimatorSVM() Ptr estimate(const vector& confidenceMaps) void update(vector& confidenceMaps) } class TrackerStateEstimatorMILBoosting{ TrackerStateEstimatorMILBoosting() ~TrackerStateEstimatorMILBoosting() Ptr estimate(const vector& confidenceMaps) void update(vector& confidenceMaps) }

TrackerModel -> TrackerStateEstimator: create TrackerModel *-- TrackerTargetState TrackerStateEstimator <|-- TrackerStateEstimatorMILBoosting TrackerStateEstimator <|-- TrackerStateEstimatorSVM } @enduml

TrackerSampler diagram

@startuml{tracking_uml_sampler.png} package "TrackerSampler package" #DDDDDD {

class TrackerSampler{ -vector<pair<String, Ptr > > samplers -vector samples; ... TrackerSampler(); ~TrackerSampler(); +sampling(const Mat& image, Rect boundingBox); +const vector<pair<String, Ptr > >& getSamplers(); +const vector& getSamples(); +bool addTrackerSamplerAlgorithm(String trackerSamplerAlgorithmType);

+bool addTrackerSamplerAlgorithm(Ptr& sampler);
-void clearSamples();
}

class TrackerSamplerAlgorithm{ ~TrackerSamplerAlgorithm(); +static Ptr create(const String& trackerSamplerType); +bool sampling(const Mat& image, Rect boundingBox, vector& sample); } note bottom: A tracker could sample the target\nor it could sample the target and the background

class TrackerSamplerCS{ TrackerSamplerCS(); ~TrackerSamplerCS(); +bool sampling(const Mat& image, Rect boundingBox, vector& sample); } class TrackerSamplerCSC{ TrackerSamplerCSC(); ~TrackerSamplerCSC(); +bool sampling(const Mat& image, Rect boundingBox, vector& sample); }

} @enduml

MultiTracker diagram

@startuml{tracking_uml_multiple.png} package "MultiTracker" package "Tracker"

MultiTracker -> Tracker: create

note top of Tracker: Several classes can be generated. @enduml

@startuml{multi_tracker_uml.png}

class MultiTracker{ MultiTracker(const String& trackerType = "" ); ~MultiTracker(); +bool add( const Mat& image, const Rect2d& boundingBox ); +bool add( const String& trackerType, const Mat& image, const Rect2d& boundingBox ); +bool add(const String& trackerType, const Mat& image, std::vector boundingBox); +bool add(const Mat& image, std::vector boundingBox); +bool update( const Mat& image, std::vector & boundingBox );

+std::vector objects;
#std::vector< Ptr > trackerList;
#String defaultAlgorithm;
}

@enduml