HCY_Graduation_Project/include/Tracking.h

241 lines
7.9 KiB
C
Raw Permalink Normal View History

2024-06-21 15:44:42 +08:00
/**
* This file is part of ORB-SLAM2.
*
* Copyright (C) 2014-2016 Raúl Mur-Artal <raulmur at unizar dot es> (University of Zaragoza)
* For more information see <https://github.com/raulmur/ORB_SLAM2>
*
* ORB-SLAM2 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-SLAM2 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-SLAM2. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef TRACKING_H
#define TRACKING_H
#include <opencv2/core/core.hpp>
#include <opencv2/features2d/features2d.hpp>
#include <opencv2/opencv.hpp>
#include <opencv2/imgproc.hpp>
#include <utility>
#include "Viewer.h"
#include "FrameDrawer.h"
#include "Map.h"
#include "LocalMapping.h"
#include "LoopClosing.h"
#include "Frame.h"
#include "ORBVocabulary.h"
#include "KeyFrameDatabase.h"
#include "ORBextractor.h"
#include "Initializer.h"
#include "MapDrawer.h"
#include "System.h"
#include <mutex>
namespace ORB_SLAM2
{
class Viewer;
class FrameDrawer;
class Map;
class LocalMapping;
class LoopClosing;
class System;
class Tracking
{
public:
Tracking(System *pSys, ORBVocabulary *pVoc, FrameDrawer *pFrameDrawer, MapDrawer *pMapDrawer, Map *pMap,
KeyFrameDatabase *pKFDB, const string &strSettingPath, const int sensor);
// Preprocess the input and call Track(). Extract features and performs stereo matching.
cv::Mat GrabImageStereo(const cv::Mat &imRectLeft, const cv::Mat &imRectRight, const double &timestamp, vector<vector<double>> &vvLabel, cv::Mat &imbev, double &delta_t);
cv::Mat GrabImageRGBD(const cv::Mat &imRGB, const cv::Mat &imD, const double &timestamp, const vector<vector<double>> &vvLabel);
cv::Mat GrabImageMonocular(const cv::Mat &im, const double &timestamp);
void Get_Motion_Car_V(Car *car);
void SetLocalMapper(LocalMapping *pLocalMapper);
void SetLoopClosing(LoopClosing *pLoopClosing);
void SetViewer(Viewer *pViewer);
void updateCarPos(Car *car);
void PredictCarPos(Car *car);
bool needCreate(vector<double> &bbox, int &index, int &n);
void updateCarState(); // 更新车辆各种信息
bool mbcreateKeyFrame;
// Load new settings
// The focal lenght should be similar or scale prediction will fail when projecting points
// TODO: Modify MapPoint::PredictScale to take into account focal lenght
void ChangeCalibration(const string &strSettingPath);
// Use this function if you have deactivated local mapping and you only want to localize the camera.
void InformOnlyTracking(const bool &flag);
// 获得相对位姿 --by钟
inline cv::Mat GetVelocity() { return this->mVelocity; }
void bev_current_bevworld(cv::Point &p_c, cv::Point &p_l, cv::Mat &T12);
public:
// Tracking states
enum eTrackingState
{
SYSTEM_NOT_READY = -1,
NO_IMAGES_YET = 0,
NOT_INITIALIZED = 1,
OK = 2,
LOST = 3
};
eTrackingState mState;
eTrackingState mLastProcessedState;
vector<pair<int, vector<vector<int>>>> mvpivvconnet;
// Input sensor
int mSensor;
// 保存上一帧的位姿
cv::Mat mLastFrame_Tcw;
// Current Frame
vector<vector<int>> mvvCarV; // 存储车辆的的像素坐标及速度
Frame mCurrentFrame;
cv::Mat mImGray;
cv::Mat mImRGB;
cv::Mat mMap_car;
// Initialization Variables (Monocular)
std::vector<int> mvIniLastMatches;
std::vector<int> mvIniMatches;
std::vector<cv::Point2f> mvbPrevMatched;
std::vector<cv::Point3f> mvIniP3D;
Frame mInitialFrame;
// Lists used to recover the full camera trajectory at the end of the execution.
// Basically we store the reference keyframe for each frame and its relative transformation
list<cv::Mat> mlRelativeFramePoses;
list<KeyFrame *> mlpReferences;
list<double> mlFrameTimes;
list<bool> mlbLost;
// True if local mapping is deactivated and we are performing only localization
bool mbOnlyTracking;
double mdelta_t;
void
Reset();
protected:
// Main tracking function. It is independent of the input sensor.
void Track();
void Track_Car();
// Map initialization for stereo and RGB-D
void StereoInitialization();
// Map initialization for monocular
void MonocularInitialization();
void CreateInitialMapMonocular();
void CheckReplacedInLastFrame();
bool TrackReferenceKeyFrame();
void UpdateLastFrame();
bool TrackWithMotionModel();
bool Relocalization();
void world2bev(vector<cv::Mat> &vm_3d_w, vector<cv::Point> &vp_bev, cv::Mat &Tcw); // 世界坐标转bev像素
void UpdateLocalMap();
void UpdateLocalPoints();
void UpdateLocalKeyFrames();
bool TrackLocalMap();
void SearchLocalPoints();
bool NeedNewKeyFrame();
void CreateNewKeyFrame();
float get_IOU(cv::Point *PointArray1, cv::Point *PointArray2);
void get_bbx(const vector<double> &label1, std ::vector<cv::Point> &pts, double scale);
// In case of performing only localization, this flag is true when there are no matches to
// points in the map. Still tracking will continue if there are enough matches with temporal points.
// In that case we are doing visual odometry. The system will try to do relocalization to recover
// "zero-drift" localization to the map.
bool mbVO;
// Other Thread Pointers
LocalMapping *mpLocalMapper;
LoopClosing *mpLoopClosing;
// ORB
ORBextractor *mpORBextractorLeft, *mpORBextractorRight;
ORBextractor *mpIniORBextractor;
// BoW
ORBVocabulary *mpORBVocabulary;
KeyFrameDatabase *mpKeyFrameDB;
// Initalization (only for monocular)
Initializer *mpInitializer;
// Local Map
KeyFrame *mpReferenceKF;
std::vector<KeyFrame *> mvpLocalKeyFrames;
std::vector<MapPoint *> mvpLocalMapPoints;
std::vector<Car *> mvpCar;
// System
System *mpSystem;
// Drawers
Viewer *mpViewer;
FrameDrawer *mpFrameDrawer;
MapDrawer *mpMapDrawer;
// Map
Map *mpMap;
// Calibration matrix
cv::Mat mK;
cv::Mat mDistCoef;
cv::Mat m_bev_K; // bev内参矩阵
cv::Mat m_bev_K_invers; // bev内参矩阵的逆
float mbf;
// New KeyFrame rules (according to fps)
int mMinFrames;
int mMaxFrames;
// Threshold close/far points
// Points seen as close by the stereo/RGBD sensor are considered reliable
// and inserted from just one frame. Far points requiere a match in two keyframes.
float mThDepth;
// For RGB-D inputs only. For some datasets (e.g. TUM) the depthmap values are scaled.
float mDepthMapFactor;
// Current matches in frame
int mnMatchesInliers;
// Last Frame, KeyFrame and Relocalisation Info
KeyFrame *mpLastKeyFrame;
Frame mLastFrame;
unsigned int mnLastKeyFrameId;
unsigned int mnLastRelocFrameId;
// Motion Model
cv::Mat mVelocity;
// Color order (true RGB, false BGR, ignored if grayscale)
bool mbRGB;
list<MapPoint *> mlpTemporalPoints;
};
} // namespace ORB_SLAM
#endif // TRACKING_H