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 ¶meters); |
+virtual ~TrackerMIL(); |
} |
class TrackerBoosting{ |
+static Ptr createTracker(const TrackerBoosting::Params ¶meters); |
+virtual ~TrackerBoosting(); |
} |
Algorithm < |
Tracker < |
Tracker < |
note "Single instance of the Tracker" as N1 TrackerBoosting .. N1 TrackerMIL .. N1 }
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 }
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; |
} |