Class VisOdomMonoDepthPnP<T extends boofcv.struct.image.ImageBase<T>>

  • All Implemented Interfaces:
    org.ddogleg.struct.VerbosePrint

    public class VisOdomMonoDepthPnP<T extends boofcv.struct.image.ImageBase<T>>
    extends VisOdomBundlePnPBase<VisOdomMonoDepthPnP.Track>
    Full 6-DOF visual odometry where a ranging device is assumed for pixels in the primary view and the motion is estimated using a Estimate1ofPnP. Range is usually estimated using stereo cameras, structured light or time of flight sensors. New features are added and removed as needed. Features are removed if they are not part of the inlier feature set for some number of consecutive frames. New features are detected and added if the inlier set falls below a threshold or every turn. Non-linear refinement is optional and appears to provide a very modest improvement in performance. It is recommended that motion is estimated using a P3P algorithm, which is the minimal case. Adding features every frame can be computationally expensive, but having too few features being tracked will degrade accuracy. The algorithm was designed to minimize magic numbers and to be insensitive to small changes in their values. Due to the level of abstraction, it can't take full advantage of the sensors used to estimate 3D feature locations. For example if a stereo camera is used then 3-view geometry can't be used to improve performance.
    • Constructor Detail

      • VisOdomMonoDepthPnP

        public VisOdomMonoDepthPnP​(org.ddogleg.fitting.modelset.ModelMatcher<georegression.struct.se.Se3_F64,​boofcv.struct.geo.Point2D3D> motionEstimator,
                                   ImagePixelTo3D pixelTo3D,
                                   boofcv.abst.geo.RefinePnP refine,
                                   boofcv.abst.tracker.PointTracker<T> tracker,
                                   boofcv.abst.geo.bundle.BundleAdjustment<boofcv.abst.geo.bundle.SceneStructureMetric> bundleAdjustment)
        Configures magic numbers and estimation algorithms.
        Parameters:
        motionEstimator - PnP motion estimator. P3P algorithm is recommended/
        pixelTo3D - Computes the 3D location of pixels.
        refine - Optional algorithm for refining the pose estimate. Can be null.
        tracker - Point feature tracker.
    • Method Detail

      • process

        public boolean process​(T image)
        Estimates the motion given the left camera image. The latest information required by ImagePixelTo3D should be passed to the class before invoking this function.
        Parameters:
        image - Camera image.
        Returns:
        true if successful or false if it failed
      • setCamera

        public void setCamera​(boofcv.struct.calib.CameraPinholeBrown camera)
        Sets the known fixed camera parameters