示例#1
0
def triangulate_midpoint(features, poses):
    """
    Triangulate a landmark from two or more views using the midpoint method.
    """
    assert len(features) > 0
    assert len(features) == len(poses)
    jtj, jtr = np.zeros((3, 3)), np.zeros(3)
    for z, pose in zip(features, poses):
        h = householder(unpr(z))
        a = dots(h, pose.orientation)
        b = dots(h, pose.orientation, pose.position)
        jtj += np.dot(a.T, a)
        jtr += np.dot(a.T, b)
    return np.linalg.solve(jtj, jtr)
示例#2
0
def solve_depth_midpoint(base_feature, base_pose, features, poses):
    """
    Solve for depth of a landmark in a priveleged view using the midpoint method.
    """
    assert len(features) > 0
    assert len(features) == len(poses)
    z0 = normalized(unpr(base_feature))
    jtj, jtr = 0., 0.
    for z, pose in zip(features, poses):
        h = householder(unpr(z))
        a = dots(h, pose.orientation, base_pose.orientation.T, z0)
        b = dots(h, pose.orientation, pose.position - base_pose.position)
        jtj += np.dot(a.T, a)
        jtr += np.dot(a.T, b)
    return jtr / jtj