orb_slam3_details/include/Settings.h

236 lines
7.2 KiB
C++

/**
* This file is part of ORB-SLAM3
*
* Copyright (C) 2017-2021 Carlos Campos, Richard Elvira, Juan J. Gómez Rodríguez, José M.M. Montiel and Juan D. Tardós, University of Zaragoza.
* Copyright (C) 2014-2016 Raúl Mur-Artal, José M.M. Montiel and Juan D. Tardós, University of Zaragoza.
*
* ORB-SLAM3 is free software: you can redistribute it and/or modify it under the terms of the GNU General Public
* License as published by the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* ORB-SLAM3 is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even
* the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License along with ORB-SLAM3.
* If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef ORB_SLAM3_SETTINGS_H
#define ORB_SLAM3_SETTINGS_H
// Flag to activate the measurement of time in each process (track,localmap, place recognition).
//#define REGISTER_TIMES
#include "CameraModels/GeometricCamera.h"
#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>
#include <string>
namespace ORB_SLAM3 {
class System;
//TODO: change to double instead of float
class Settings {
public:
/*
* Enum for the different camera types implemented
*/
enum CameraType {
PinHole = 0,
Rectified = 1,
KannalaBrandt = 2
};
/*
* Delete default constructor
*/
Settings() = delete;
/*
* Constructor from file
*/
Settings(const std::string &configFile, const int& sensor);
/*
* Ostream operator overloading to dump settings to the terminal
*/
friend std::ostream &operator<<(std::ostream &output, const Settings &s);
/*
* Getter methods
*/
CameraType cameraType() {return cameraType_;}
GeometricCamera* camera1() {return calibration1_;}
GeometricCamera* camera2() {return calibration2_;}
cv::Mat camera1DistortionCoef() {return cv::Mat(vPinHoleDistorsion1_.size(),1,CV_32F,vPinHoleDistorsion1_.data());}
cv::Mat camera2DistortionCoef() {return cv::Mat(vPinHoleDistorsion2_.size(),1,CV_32F,vPinHoleDistorsion1_.data());}
Sophus::SE3f Tlr() {return Tlr_;}
float bf() {return bf_;}
float b() {return b_;}
float thDepth() {return thDepth_;}
bool needToUndistort() {return bNeedToUndistort_;}
cv::Size newImSize() {return newImSize_;}
float fps() {return fps_;}
bool rgb() {return bRGB_;}
bool needToResize() {return bNeedToResize1_;}
bool needToRectify() {return bNeedToRectify_;}
float noiseGyro() {return noiseGyro_;}
float noiseAcc() {return noiseAcc_;}
float gyroWalk() {return gyroWalk_;}
float accWalk() {return accWalk_;}
float imuFrequency() {return imuFrequency_;}
Sophus::SE3f Tbc() {return Tbc_;}
bool insertKFsWhenLost() {return insertKFsWhenLost_;}
float depthMapFactor() {return depthMapFactor_;}
int nFeatures() {return nFeatures_;}
int nLevels() {return nLevels_;}
float initThFAST() {return initThFAST_;}
float minThFAST() {return minThFAST_;}
float scaleFactor() {return scaleFactor_;}
float keyFrameSize() {return keyFrameSize_;}
float keyFrameLineWidth() {return keyFrameLineWidth_;}
float graphLineWidth() {return graphLineWidth_;}
float pointSize() {return pointSize_;}
float cameraSize() {return cameraSize_;}
float cameraLineWidth() {return cameraLineWidth_;}
float viewPointX() {return viewPointX_;}
float viewPointY() {return viewPointY_;}
float viewPointZ() {return viewPointZ_;}
float viewPointF() {return viewPointF_;}
float imageViewerScale() {return imageViewerScale_;}
std::string atlasLoadFile() {return sLoadFrom_;}
std::string atlasSaveFile() {return sSaveto_;}
float thFarPoints() {return thFarPoints_;}
cv::Mat M1l() {return M1l_;}
cv::Mat M2l() {return M2l_;}
cv::Mat M1r() {return M1r_;}
cv::Mat M2r() {return M2r_;}
private:
template<typename T>
T readParameter(cv::FileStorage& fSettings, const std::string& name, bool& found,const bool required = true){
cv::FileNode node = fSettings[name];
if(node.empty()){
if(required){
std::cerr << name << " required parameter does not exist, aborting..." << std::endl;
exit(-1);
}
else{
std::cerr << name << " optional parameter does not exist..." << std::endl;
found = false;
return T();
}
}
else{
found = true;
return (T) node;
}
}
void readCamera1(cv::FileStorage& fSettings);
void readCamera2(cv::FileStorage& fSettings);
void readImageInfo(cv::FileStorage& fSettings);
void readIMU(cv::FileStorage& fSettings);
void readRGBD(cv::FileStorage& fSettings);
void readORB(cv::FileStorage& fSettings);
void readViewer(cv::FileStorage& fSettings);
void readLoadAndSave(cv::FileStorage& fSettings);
void readOtherParameters(cv::FileStorage& fSettings);
void precomputeRectificationMaps();
int sensor_;
CameraType cameraType_; //Camera type
/*
* Visual stuff
*/
GeometricCamera* calibration1_, *calibration2_; //Camera calibration
GeometricCamera* originalCalib1_, *originalCalib2_;
std::vector<float> vPinHoleDistorsion1_, vPinHoleDistorsion2_;
cv::Size originalImSize_, newImSize_;
float fps_;
bool bRGB_;
bool bNeedToUndistort_;
bool bNeedToRectify_;
bool bNeedToResize1_, bNeedToResize2_;
Sophus::SE3f Tlr_;
float thDepth_;
float bf_, b_;
/*
* Rectification stuff
*/
cv::Mat M1l_, M2l_;
cv::Mat M1r_, M2r_;
/*
* Inertial stuff
*/
float noiseGyro_, noiseAcc_;
float gyroWalk_, accWalk_;
float imuFrequency_;
Sophus::SE3f Tbc_;
bool insertKFsWhenLost_;
/*
* RGBD stuff
*/
float depthMapFactor_;
/*
* ORB stuff
*/
int nFeatures_;
float scaleFactor_;
int nLevels_;
int initThFAST_, minThFAST_;
/*
* Viewer stuff
*/
float keyFrameSize_;
float keyFrameLineWidth_;
float graphLineWidth_;
float pointSize_;
float cameraSize_;
float cameraLineWidth_;
float viewPointX_, viewPointY_, viewPointZ_, viewPointF_;
float imageViewerScale_;
/*
* Save & load maps
*/
std::string sLoadFrom_, sSaveto_;
/*
* Other stuff
*/
float thFarPoints_;
};
};
#endif //ORB_SLAM3_SETTINGS_H