X-Git-Url: http://47.100.26.94:8080/?a=blobdiff_plain;f=src%2FTracker.cpp;h=50bc82044dbe3e6ddfd42a2e5a5149b9b11238db;hb=3ff9a5ad691b8dca9d91f8e9786a8d08d31b70fa;hp=2d353a75af7c0c58dc2735eb5e49063981879127;hpb=5675c1a74ffcb95725eb11463e51cfebbc88a15e;p=trackerpp.git diff --git a/src/Tracker.cpp b/src/Tracker.cpp index 2d353a7..50bc820 100644 --- a/src/Tracker.cpp +++ b/src/Tracker.cpp @@ -5,24 +5,40 @@ using namespace cv; static const int MaxLost = 5; -Tracker::Tracker(int id) : id(id) +Tracker::Tracker(const cv::Mat& image,int id) : id(id) { status = TrackerStatus::Fire; preStatus = TrackerStatus::Fire; -} -Tracker::~Tracker() -{ + // TODO + // init KalmanFilter + this->kf.transitionMatrix = (Mat_(4, 4) << + 1, 0, 1, 0, + 0, 1, 0, 1, + 0, 0, 1, 0, + 0, 0, 0, 1); + + this->kf.measurementMatrix = (Mat_(2, 2) << + 1, 0, 0, 0, + 0, 1, 0, 0); + + this->kf.processNoiseCov = 1e-5 * Mat_::eye(4, 4); + this->kf.measurementNoiseCov = 1e-1 * Mat_::ones(2, 2); + this->kf.errorCovPost = 1. * Mat_::ones(4, 4); } -void Tracker::addPatch(Patch* p) +Tracker::~Tracker() { - patches.push_back(p); - if (patches.size() > Metrics::MaxPatch){ - patches.erase(patches.end()); - } } +//void Tracker::addPatch(Patch* p) +//{ +// patches.push_back(p); +// if (patches.size() > Metrics::MaxPatch){ +// patches.erase(patches.end()); +// } +//} +// void Tracker::updateState(const Mat& image) { preStatus = this->status;