Path: blob/master/apps/interactive-calibration/parametersController.cpp
16337 views
// This file is part of OpenCV project.1// It is subject to the license terms in the LICENSE file found in the top-level directory2// of this distribution and at http://opencv.org/license.html.34#include "parametersController.hpp"56#include <iostream>78template <typename T>9static bool readFromNode(cv::FileNode node, T& value)10{11if(!node.isNone()) {12node >> value;13return true;14}15else16return false;17}1819static bool checkAssertion(bool value, const std::string& msg)20{21if(!value)22std::cerr << "Error: " << msg << std::endl;2324return value;25}2627bool calib::parametersController::loadFromFile(const std::string &inputFileName)28{29cv::FileStorage reader;30reader.open(inputFileName, cv::FileStorage::READ);3132if(!reader.isOpened()) {33std::cerr << "Warning: Unable to open " << inputFileName <<34" Applicatioin stated with default advanced parameters" << std::endl;35return true;36}3738readFromNode(reader["charuco_dict"], mCapParams.charucoDictName);39readFromNode(reader["charuco_square_lenght"], mCapParams.charucoSquareLenght);40readFromNode(reader["charuco_marker_size"], mCapParams.charucoMarkerSize);41readFromNode(reader["camera_resolution"], mCapParams.cameraResolution);42readFromNode(reader["calibration_step"], mCapParams.calibrationStep);43readFromNode(reader["max_frames_num"], mCapParams.maxFramesNum);44readFromNode(reader["min_frames_num"], mCapParams.minFramesNum);45readFromNode(reader["solver_eps"], mInternalParameters.solverEps);46readFromNode(reader["solver_max_iters"], mInternalParameters.solverMaxIters);47readFromNode(reader["fast_solver"], mInternalParameters.fastSolving);48readFromNode(reader["frame_filter_conv_param"], mInternalParameters.filterAlpha);4950bool retValue =51checkAssertion(mCapParams.charucoDictName >= 0, "Dict name must be >= 0") &&52checkAssertion(mCapParams.charucoMarkerSize > 0, "Marker size must be positive") &&53checkAssertion(mCapParams.charucoSquareLenght > 0, "Square size must be positive") &&54checkAssertion(mCapParams.minFramesNum > 1, "Minimal number of frames for calibration < 1") &&55checkAssertion(mCapParams.calibrationStep > 0, "Calibration step must be positive") &&56checkAssertion(mCapParams.maxFramesNum > mCapParams.minFramesNum, "maxFramesNum < minFramesNum") &&57checkAssertion(mInternalParameters.solverEps > 0, "Solver precision must be positive") &&58checkAssertion(mInternalParameters.solverMaxIters > 0, "Max solver iterations number must be positive") &&59checkAssertion(mInternalParameters.filterAlpha >=0 && mInternalParameters.filterAlpha <=1 ,60"Frame filter convolution parameter must be in [0,1] interval") &&61checkAssertion(mCapParams.cameraResolution.width > 0 && mCapParams.cameraResolution.height > 0,62"Wrong camera resolution values");6364reader.release();65return retValue;66}6768calib::parametersController::parametersController()69{70}7172calib::captureParameters calib::parametersController::getCaptureParameters() const73{74return mCapParams;75}7677calib::internalParameters calib::parametersController::getInternalParameters() const78{79return mInternalParameters;80}8182bool calib::parametersController::loadFromParser(cv::CommandLineParser &parser)83{84mCapParams.flipVertical = parser.get<bool>("flip");85mCapParams.captureDelay = parser.get<float>("d");86mCapParams.squareSize = parser.get<float>("sz");87mCapParams.templDst = parser.get<float>("dst");8889if(!checkAssertion(mCapParams.squareSize > 0, "Distance between corners or circles must be positive"))90return false;91if(!checkAssertion(mCapParams.templDst > 0, "Distance between parts of dual template must be positive"))92return false;9394if (parser.has("v")) {95mCapParams.source = File;96mCapParams.videoFileName = parser.get<std::string>("v");97}98else {99mCapParams.source = Camera;100mCapParams.camID = parser.get<int>("ci");101}102103std::string templateType = parser.get<std::string>("t");104105if(templateType.find("circles", 0) == 0) {106mCapParams.board = AcirclesGrid;107mCapParams.boardSize = cv::Size(4, 11);108}109else if(templateType.find("chessboard", 0) == 0) {110mCapParams.board = Chessboard;111mCapParams.boardSize = cv::Size(7, 7);112}113else if(templateType.find("dualcircles", 0) == 0) {114mCapParams.board = DoubleAcirclesGrid;115mCapParams.boardSize = cv::Size(4, 11);116}117else if(templateType.find("charuco", 0) == 0) {118mCapParams.board = chAruco;119mCapParams.boardSize = cv::Size(6, 8);120mCapParams.charucoDictName = 0;121mCapParams.charucoSquareLenght = 200;122mCapParams.charucoMarkerSize = 100;123}124else {125std::cerr << "Wrong template name\n";126return false;127}128129if(parser.has("w") && parser.has("h")) {130mCapParams.boardSize = cv::Size(parser.get<int>("w"), parser.get<int>("h"));131if(!checkAssertion(mCapParams.boardSize.width > 0 || mCapParams.boardSize.height > 0,132"Board size must be positive"))133return false;134}135136if(!checkAssertion(parser.get<std::string>("of").find(".xml") > 0,137"Wrong output file name: correct format is [name].xml"))138return false;139140loadFromFile(parser.get<std::string>("pf"));141return true;142}143144145