summaryrefslogtreecommitdiffhomepage
path: root/ftnoir_tracker_pt
diff options
context:
space:
mode:
authorStanislaw Halik <sthalik@misaki.pl>2015-07-20 08:13:06 +0200
committerStanislaw Halik <sthalik@misaki.pl>2015-07-20 08:13:36 +0200
commite89c2b1034692eb1365715a089b7035e6d837719 (patch)
tree1ee2fc1a29c4e62eac403bd2092f0b51943c1578 /ftnoir_tracker_pt
parent20827ce134033e2370c6858905d2faca5c240602 (diff)
pt: change point internal representation
Store points as pixel coordinates, not -0.5->0.5. This has no effect on tracking as POSIT is robust enough not to care.
Diffstat (limited to 'ftnoir_tracker_pt')
-rw-r--r--ftnoir_tracker_pt/ftnoir_tracker_pt.cpp11
-rw-r--r--ftnoir_tracker_pt/point_extractor.cpp3
2 files changed, 6 insertions, 8 deletions
diff --git a/ftnoir_tracker_pt/ftnoir_tracker_pt.cpp b/ftnoir_tracker_pt/ftnoir_tracker_pt.cpp
index 8ccfe2c4..b8f40e50 100644
--- a/ftnoir_tracker_pt/ftnoir_tracker_pt.cpp
+++ b/ftnoir_tracker_pt/ftnoir_tracker_pt.cpp
@@ -58,7 +58,7 @@ float Tracker_PT::get_focal_length()
static constexpr double pi = 3.1415926f;
const double diag = sqrt(w * w + h * h)/w, diag_fov = static_cast<int>(s.fov) * pi / 180.;
const double fov = 2.*atan(tan(diag_fov/2.0)/sqrt(1. + diag*diag));
- return .5 / tan(.5 * fov);
+ return w*.5 / tan(.5 * fov);
}
void Tracker_PT::run()
@@ -108,18 +108,17 @@ void Tracker_PT::run()
for (unsigned i = 0; i < points.size(); i++)
{
auto& p = points[i];
- auto p2 = cv::Point(p[0] * frame.cols + frame.cols/2, -p[1] * frame.cols + frame.rows/2);
cv::Scalar color(0, 255, 0);
if (i == points.size()-1)
color = cv::Scalar(0, 0, 255);
cv::line(frame,
- cv::Point(p2.x - 20, p2.y),
- cv::Point(p2.x + 20, p2.y),
+ cv::Point(p[0] - 20, p[1]),
+ cv::Point(p[0] + 20, p[1]),
color,
4);
cv::line(frame,
- cv::Point(p2.x, p2.y - 20),
- cv::Point(p2.x, p2.y + 20),
+ cv::Point(p[0], p[1] - 20),
+ cv::Point(p[0], p[1] + 20),
color,
4);
}
diff --git a/ftnoir_tracker_pt/point_extractor.cpp b/ftnoir_tracker_pt/point_extractor.cpp
index e81e3aa0..cc9dbce1 100644
--- a/ftnoir_tracker_pt/point_extractor.cpp
+++ b/ftnoir_tracker_pt/point_extractor.cpp
@@ -211,8 +211,7 @@ std::vector<Vec2f> PointExtractor::extract_points(Mat& frame)
for (auto& b : simple_blob::merge(blobs))
{
auto pos = b.effective_pos();
- Vec2f p((pos[0] - W/2)/W, -(pos[1] - H/2)/W);
- points.push_back(p);
+ points.push_back(pos);
}
vector<Mat> channels_;