Loading [MathJax]/extensions/tex2jax.js
  • <xmp id="om0om">
  • <table id="om0om"><noscript id="om0om"></noscript></table>

  • DriveWorks SDK Reference
    5.6.215 Release
    For Test and Development only

    All Data Structures Files Functions Variables Typedefs Enumerations Enumerator Macros Modules Pages
    Pose estimation

    The tutorial shows the general structure of a program that uses the PnP pose estimator to determine the camera pose.

    Initialize the pose estimator

    We select a conservative number of ransac and non-linear optimizer iterations (10 and 10). contextHandle is assumed to be previously initialized dwContextHandle_t.

    dwPnP_initialize(&pnp, 10, 10, contextHandle);
    DW_API_PUBLIC dwStatus dwPnP_initialize(dwPnPHandle_t *obj, size_t ransacIterations, size_t optimizerIterations, dwContextHandle_t ctx)
    Initializes a PnP solver.

    Obtain matches

    dwVector3f worldPoints[BUFFER_SIZE];
    dwVector2f imagePoints[BUFFER_SIZE];
    size_t pointCount;
    // The application must obtain the matches and fill the above three variables
    Defines a two-element single-precision floating-point vector.
    Definition: Types.h:325
    Defines a three-element floating-point vector.
    Definition: Types.h:355

    Undistort feature points

    cameraModel is assumed to be previously initialized dwCameraModelHandle_t

    dwVector2f rays[BUFFER_SIZE];
    for(size_t i = 0; i < pointCount; ++i)
    {
    const auto& point = imagePoints[i];
    auto& ray = rays[i];
    dwCameraModel_pixel2Ray(&ray.x, &ray.y, &ray.z, point.x, point.y, cameraModel);
    }
    DW_API_PUBLIC dwStatus dwCameraModel_pixel2Ray(float32_t *x, float32_t *y, float32_t *z, float32_t u, float32_t v, dwConstCameraModelHandle_t obj)
    Back-projects a 2D point in pixel coordinates to a 3D optical ray direction.

    Estimate pose

    dwTransformation3f worldToCamera;
    dwPnP_solve(&worldToCamera, pointCount, rays, worldPoints, pnp);
    Specifies a 3D rigid transformation.
    Definition: Types.h:536
    DW_API_PUBLIC dwStatus dwPnP_solve(dwTransformation3f *worldToCamera, size_t matchCount, const dwVector3f *rays, const dwVector3f *worldPoints, dwPnPHandle_t obj)
    Estimates the worldToCamera pose based on optical ray to 3D world point correspondences.

    Finally, free previously allocated memory.

    DW_API_PUBLIC dwStatus dwPnP_release(dwPnPHandle_t obj)
    Releases the PnP solver.
    人人超碰97caoporen国产