Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
Tetragramm
GitHub Repository: Tetragramm/opencv
Path: blob/master/apps/interactive-calibration/parametersController.cpp
16337 views
1
// This file is part of OpenCV project.
2
// It is subject to the license terms in the LICENSE file found in the top-level directory
3
// of this distribution and at http://opencv.org/license.html.
4
5
#include "parametersController.hpp"
6
7
#include <iostream>
8
9
template <typename T>
10
static bool readFromNode(cv::FileNode node, T& value)
11
{
12
if(!node.isNone()) {
13
node >> value;
14
return true;
15
}
16
else
17
return false;
18
}
19
20
static bool checkAssertion(bool value, const std::string& msg)
21
{
22
if(!value)
23
std::cerr << "Error: " << msg << std::endl;
24
25
return value;
26
}
27
28
bool calib::parametersController::loadFromFile(const std::string &inputFileName)
29
{
30
cv::FileStorage reader;
31
reader.open(inputFileName, cv::FileStorage::READ);
32
33
if(!reader.isOpened()) {
34
std::cerr << "Warning: Unable to open " << inputFileName <<
35
" Applicatioin stated with default advanced parameters" << std::endl;
36
return true;
37
}
38
39
readFromNode(reader["charuco_dict"], mCapParams.charucoDictName);
40
readFromNode(reader["charuco_square_lenght"], mCapParams.charucoSquareLenght);
41
readFromNode(reader["charuco_marker_size"], mCapParams.charucoMarkerSize);
42
readFromNode(reader["camera_resolution"], mCapParams.cameraResolution);
43
readFromNode(reader["calibration_step"], mCapParams.calibrationStep);
44
readFromNode(reader["max_frames_num"], mCapParams.maxFramesNum);
45
readFromNode(reader["min_frames_num"], mCapParams.minFramesNum);
46
readFromNode(reader["solver_eps"], mInternalParameters.solverEps);
47
readFromNode(reader["solver_max_iters"], mInternalParameters.solverMaxIters);
48
readFromNode(reader["fast_solver"], mInternalParameters.fastSolving);
49
readFromNode(reader["frame_filter_conv_param"], mInternalParameters.filterAlpha);
50
51
bool retValue =
52
checkAssertion(mCapParams.charucoDictName >= 0, "Dict name must be >= 0") &&
53
checkAssertion(mCapParams.charucoMarkerSize > 0, "Marker size must be positive") &&
54
checkAssertion(mCapParams.charucoSquareLenght > 0, "Square size must be positive") &&
55
checkAssertion(mCapParams.minFramesNum > 1, "Minimal number of frames for calibration < 1") &&
56
checkAssertion(mCapParams.calibrationStep > 0, "Calibration step must be positive") &&
57
checkAssertion(mCapParams.maxFramesNum > mCapParams.minFramesNum, "maxFramesNum < minFramesNum") &&
58
checkAssertion(mInternalParameters.solverEps > 0, "Solver precision must be positive") &&
59
checkAssertion(mInternalParameters.solverMaxIters > 0, "Max solver iterations number must be positive") &&
60
checkAssertion(mInternalParameters.filterAlpha >=0 && mInternalParameters.filterAlpha <=1 ,
61
"Frame filter convolution parameter must be in [0,1] interval") &&
62
checkAssertion(mCapParams.cameraResolution.width > 0 && mCapParams.cameraResolution.height > 0,
63
"Wrong camera resolution values");
64
65
reader.release();
66
return retValue;
67
}
68
69
calib::parametersController::parametersController()
70
{
71
}
72
73
calib::captureParameters calib::parametersController::getCaptureParameters() const
74
{
75
return mCapParams;
76
}
77
78
calib::internalParameters calib::parametersController::getInternalParameters() const
79
{
80
return mInternalParameters;
81
}
82
83
bool calib::parametersController::loadFromParser(cv::CommandLineParser &parser)
84
{
85
mCapParams.flipVertical = parser.get<bool>("flip");
86
mCapParams.captureDelay = parser.get<float>("d");
87
mCapParams.squareSize = parser.get<float>("sz");
88
mCapParams.templDst = parser.get<float>("dst");
89
90
if(!checkAssertion(mCapParams.squareSize > 0, "Distance between corners or circles must be positive"))
91
return false;
92
if(!checkAssertion(mCapParams.templDst > 0, "Distance between parts of dual template must be positive"))
93
return false;
94
95
if (parser.has("v")) {
96
mCapParams.source = File;
97
mCapParams.videoFileName = parser.get<std::string>("v");
98
}
99
else {
100
mCapParams.source = Camera;
101
mCapParams.camID = parser.get<int>("ci");
102
}
103
104
std::string templateType = parser.get<std::string>("t");
105
106
if(templateType.find("circles", 0) == 0) {
107
mCapParams.board = AcirclesGrid;
108
mCapParams.boardSize = cv::Size(4, 11);
109
}
110
else if(templateType.find("chessboard", 0) == 0) {
111
mCapParams.board = Chessboard;
112
mCapParams.boardSize = cv::Size(7, 7);
113
}
114
else if(templateType.find("dualcircles", 0) == 0) {
115
mCapParams.board = DoubleAcirclesGrid;
116
mCapParams.boardSize = cv::Size(4, 11);
117
}
118
else if(templateType.find("charuco", 0) == 0) {
119
mCapParams.board = chAruco;
120
mCapParams.boardSize = cv::Size(6, 8);
121
mCapParams.charucoDictName = 0;
122
mCapParams.charucoSquareLenght = 200;
123
mCapParams.charucoMarkerSize = 100;
124
}
125
else {
126
std::cerr << "Wrong template name\n";
127
return false;
128
}
129
130
if(parser.has("w") && parser.has("h")) {
131
mCapParams.boardSize = cv::Size(parser.get<int>("w"), parser.get<int>("h"));
132
if(!checkAssertion(mCapParams.boardSize.width > 0 || mCapParams.boardSize.height > 0,
133
"Board size must be positive"))
134
return false;
135
}
136
137
if(!checkAssertion(parser.get<std::string>("of").find(".xml") > 0,
138
"Wrong output file name: correct format is [name].xml"))
139
return false;
140
141
loadFromFile(parser.get<std::string>("pf"));
142
return true;
143
}
144
145