从YML文件OPENCV C 初始化摄像机参数

initialize Camera parameters from yml file opencv C++

本文关键字:初始化 摄像机 参数 OPENCV YML 文件      更新时间:2023-10-16

我保存了在https://github.com/opencv/opencv/blob/master/master/samples/cpp/cpp/cpp/cpp/stitching_detailed.cpp中定义的相机。这是相机参数结构的样子:

struct CV_EXPORTS CameraParams
{
    CameraParams();
    CameraParams(const CameraParams& other);
    const CameraParams& operator =(const CameraParams& other);
    Mat K() const;
    double focal; // Focal length
    double aspect; // Aspect ratio
    double ppx; // Principal point X
    double ppy; // Principal point Y
    Mat R; // Rotation
    Mat t; // Translation
};

我使用以下脚本将此相机参数写入YML文件:

<cameraParams> cameras;
FileStorage fs(fileName, FileStorage::WRITE);
fs << "K" << cameras.K();
fs << "R" << cameras.R;
fs << "t" << cameras.t;
fs << "ppx" << cameras.ppx;
fs << "ppy" << cameras.ppy;
fs << "focal" << cameras.focal;
fs << "aspect" << cameras.aspect;
fs.release();

这是文件内容的样子:

%YAML:1.0
---
K: !!opencv-matrix
  rows: 3
  cols: 3
  dt: d
  data: [ 2.4125938056164614e+003, 0., 447., 0.,
      2.4125938056164614e+003, 3.3550000000000000e+002, 0., 0., 1. ]
R: !!opencv-matrix
  rows: 3
  cols: 3
  dt: f
  data: [ -9.67408061e-001, 7.91518241e-002, -2.40534484e-001,
      -4.17553373e-002, -9.86752093e-001, -1.56770796e-001,
      -2.49756604e-001, -1.41617730e-001, 9.57896829e-001 ]
t: !!opencv-matrix
  rows: 3
  cols: 1
  dt: d
  data: [ 0., 0., 0. ]
ppx: 447.
ppy: 3.3550000000000000e+002
focal: 2.4125938056164614e+003
aspect: 1.

现在,我想使用这些相同的参数并重新读取它们,但这不起作用(会出现运行时间错误)。这是使用的读取函数:

    Mat K, R, t;
    double ppx, ppy, focal, aspect;
    FileStorage fs(fileName, FileStorage::READ);
    fs["K"] >> K;
    fs["R"] >> R;
    fs["t"] >> t;
    fs["ppx"] >> ppx;
    fs["ppy"] >> ppy;
    fs["focal"] >> focal;
    fs["aspect"] >> aspect;
    camerasTest[i].K() = (Mat)K;
    camerasTest[i].R = R;
    camerasTest[i].t = t;
    camerasTest[i].ppx = (double)ppx;
    camerasTest[i].ppy = (double)ppy;
    camerasTest[i].focal = (double)focal;
    camerasTest[i].aspect = (double)aspect;
    fs.release()

如何解决此问题?

在'k'的初始化中存在错误。我进行了更改,然后开始工作。

for (int i = 0; i < num_images; ++i)
{
    Mat_<float> K;
    cameras[i].K().convertTo(K, CV_32F);
}