我正在尝试将一些 opencv 代码从 python 转换为 C++,但有点迷茫。蟒蛇是:
if 0 < R[1,1] < 1:
# If it gets here, the pose is flipped.
# Flip the axes. E.g., Y axis becomes [-y0, -y1, y2].
R *= np.array([
[ 1, -1, 1],
[ 1, -1, 1],
[-1, 1, -1],
])
# Fixup: rotate along the plane spanned by camera's forward (Z) axis and vector to marker's position
forward = np.array([0, 0, 1])
tnorm = T / np.linalg.norm(T)
axis = np.cross(tnorm, forward)
angle = -2*math.acos(tnorm @ forward)
R = cv2.Rodrigues(angle * axis)[0] @ R
到目前为止,我有:
cv::Mat R;
if (0 < R.at<double>(1, 1) < 1) {
// Flip the axes.E.g., Y axis becomes[-y0, -y1, y2].
float mult[9] = { 1, -1, 1, 1, -1, 1,-1, 1, -1 };
cv::Mat FlipAxes = cv::Mat(3, 3, CV_32F, mult);
R *= FlipAxes;
//# Fixup: rotate along the plane spanned by camera's forward (Z) axis and vector to marker's position
cv::Vec3d forward(0, 0, 1);
double tnorm = tvecBest / np.linalg.norm(T)
axis = np.cross(tnorm, forward)
angle = -2 * math.acos(tnorm @ forward)
R = cv2.Rodrigues(angle * axis)[0] * R
}
我迷失在这些行上:
double tnorm = tvecBest / np.linalg.norm(T)
axis = np.cross(tnorm, forward)
angle = -2 * math.acos(tnorm @ forward)
np.linalg.norm在 c++ opencv 中的等价物是什么?
萧十郎
相关分类