-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathMapPoint.cc
34 lines (26 loc) · 1.27 KB
/
MapPoint.cc
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
// Copyright 2008 Isis Innovation Limited
#include "MapPoint.h"
#include "KeyFrame.h"
namespace PTAMM {
void MapPoint::RefreshPixelVectors()
{
KeyFrame &k = *pPatchSourceKF;
// Find patch pos in KF camera coords
// Actually this might not exactly correspond to the patch pos!
// Treat it as a general point on the plane.
Vector<3> v3PlanePoint_C = k.se3CfromW * v3WorldPos;
// Find the height of this above the plane.
// Assumes the normal is pointing toward the camera.
double dCamHeight = fabs(v3PlanePoint_C * v3Normal_NC);
double dPixelRate = fabs(v3Center_NC * v3Normal_NC);
double dOneRightRate = fabs(v3OneRightFromCenter_NC * v3Normal_NC);
double dOneDownRate = fabs(v3OneDownFromCenter_NC * v3Normal_NC);
// Find projections onto plane
Vector<3> v3CenterOnPlane_C = v3Center_NC * dCamHeight / dPixelRate;
Vector<3> v3OneRightOnPlane_C = v3OneRightFromCenter_NC * dCamHeight / dOneRightRate;
Vector<3> v3OneDownOnPlane_C = v3OneDownFromCenter_NC * dCamHeight / dOneDownRate;
// Find differences of these projections in the world frame
v3PixelRight_W = k.se3CfromW.get_rotation().inverse() * (v3OneRightOnPlane_C - v3CenterOnPlane_C);
v3PixelDown_W = k.se3CfromW.get_rotation().inverse() * (v3OneDownOnPlane_C - v3CenterOnPlane_C);
}
}