当前位置: 首页>>代码示例>>C++>>正文


C++ Mat::checkVector方法代码示例

本文整理汇总了C++中cv::Mat::checkVector方法的典型用法代码示例。如果您正苦于以下问题:C++ Mat::checkVector方法的具体用法?C++ Mat::checkVector怎么用?C++ Mat::checkVector使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在cv::Mat的用法示例。


在下文中一共展示了Mat::checkVector方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: if

    mrpt::vision::pnp::epnp::epnp(const cv::Mat& cameraMatrix, const cv::Mat& opoints, const cv::Mat& ipoints)
    {
      if (cameraMatrix.depth() == CV_32F)
          init_camera_parameters<float>(cameraMatrix);
      else
        init_camera_parameters<double>(cameraMatrix);

      number_of_correspondences = std::max(opoints.checkVector(3, CV_32F), opoints.checkVector(3, CV_64F));

      pws.resize(3 * number_of_correspondences);
      us.resize(2 * number_of_correspondences);

      if (opoints.depth() == ipoints.depth())
      {
        if (opoints.depth() == CV_32F)
          init_points<cv::Point3f,cv::Point2f>(opoints, ipoints);
        else
          init_points<cv::Point3d,cv::Point2d>(opoints, ipoints);
      }
      else if (opoints.depth() == CV_32F)
        init_points<cv::Point3f,cv::Point2d>(opoints, ipoints);
      else
        init_points<cv::Point3d,cv::Point2f>(opoints, ipoints);

      alphas.resize(4 * number_of_correspondences);
      pcs.resize(3 * number_of_correspondences);

      max_nr = 0;
      A1 = NULL;
      A2 = NULL;
    }
开发者ID:GYengera,项目名称:mrpt,代码行数:31,代码来源:epnp.cpp

示例2: if

int p3p::solve(std::vector<cv::Mat>& Rs, std::vector<cv::Mat>& tvecs, const cv::Mat& opoints, const cv::Mat& ipoints)
{
    CV_INSTRUMENT_REGION();

    double rotation_matrix[4][3][3] = {}, translation[4][3] = {};
    std::vector<double> points;
    if (opoints.depth() == ipoints.depth())
    {
        if (opoints.depth() == CV_32F)
            extract_points<cv::Point3f,cv::Point2f>(opoints, ipoints, points);
        else
            extract_points<cv::Point3d,cv::Point2d>(opoints, ipoints, points);
    }
    else if (opoints.depth() == CV_32F)
        extract_points<cv::Point3f,cv::Point2d>(opoints, ipoints, points);
    else
        extract_points<cv::Point3d,cv::Point2f>(opoints, ipoints, points);

    const bool p4p = std::max(opoints.checkVector(3, CV_32F), opoints.checkVector(3, CV_64F)) == 4;
    int solutions = solve(rotation_matrix, translation,
                          points[0], points[1], points[2], points[3], points[4],
                          points[5], points[6], points[7], points[8], points[9],
                          points[10], points[11], points[12], points[13], points[14],
                          points[15], points[16], points[17], points[18], points[19],
                          p4p);

    for (int i = 0; i < solutions; i++) {
        cv::Mat R, tvec;
        cv::Mat(3, 1, CV_64F, translation[i]).copyTo(tvec);
        cv::Mat(3, 3, CV_64F, rotation_matrix[i]).copyTo(R);

        Rs.push_back(R);
        tvecs.push_back(tvec);
    }

    return solutions;
}
开发者ID:manhhomienbienthuy,项目名称:opencv,代码行数:37,代码来源:p3p.cpp


注:本文中的cv::Mat::checkVector方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。