From c3e4f1cd2911d723d3bc6d6ca8e91f7b92db4384 Mon Sep 17 00:00:00 2001 From: Richard Elvira Date: Thu, 23 Jul 2020 19:10:46 +0200 Subject: [PATCH] Fix bug in PoseGraph --- src/LoopClosing.cc | 6 +++--- src/Optimizer.cc | 24 ++++++------------------ 2 files changed, 9 insertions(+), 21 deletions(-) diff --git a/src/LoopClosing.cc b/src/LoopClosing.cc index 4b9514c71d..e431d1a707 100644 --- a/src/LoopClosing.cc +++ b/src/LoopClosing.cc @@ -79,7 +79,7 @@ void LoopClosing::Run() } else { - Verbose::PrintMess("*Merged detected", Verbose::VERBOSITY_NORMAL); + Verbose::PrintMess("*Merged detected", Verbose::VERBOSITY_QUIET); Verbose::PrintMess("Number of KFs in the current map: " + to_string(mpCurrentKF->GetMap()->KeyFramesInMap()), Verbose::VERBOSITY_DEBUG); cv::Mat mTmw = mpMergeMatchedKF->GetPose(); g2o::Sim3 gSmw2(Converter::toMatrix3d(mTmw.rowRange(0, 3).colRange(0, 3)),Converter::toVector3d(mTmw.rowRange(0, 3).col(3)),1.0); @@ -165,7 +165,7 @@ void LoopClosing::Run() vnPR_TypeRecogn.push_back(0); - Verbose::PrintMess("*Loop detected", Verbose::VERBOSITY_NORMAL); + Verbose::PrintMess("*Loop detected", Verbose::VERBOSITY_QUIET); mg2oLoopScw = mg2oLoopSlw; //*mvg2oSim3LoopTcw[nCurrentIndex]; if(mpCurrentKF->GetMap()->IsInertial()) @@ -1745,7 +1745,7 @@ void LoopClosing::MergeLocal() //Apply the transformation { if(mpTracker->mSensor == System::MONOCULAR) - { + { unique_lock currentLock(pCurrentMap->mMutexMapUpdate); // We update the current map with the Merge information for(KeyFrame* pKFi : vpCurrentMapKFs) diff --git a/src/Optimizer.cc b/src/Optimizer.cc index 400c0c8e59..e32ed01cbb 100644 --- a/src/Optimizer.cc +++ b/src/Optimizer.cc @@ -3163,7 +3163,7 @@ void Optimizer::OptimizeEssentialGraph(KeyFrame* pCurKF, vector &vpFi vpVertices[nIDi]=VSim3; } - cout << "Opt_Essential: vpFixedKFs loaded" << endl; + Verbose::PrintMess("Opt_Essential: vpFixedKFs loaded", Verbose::VERBOSITY_DEBUG); set sIdKF; for(KeyFrame* pKFi : vpFixedCorrectedKFs) @@ -3191,7 +3191,6 @@ void Optimizer::OptimizeEssentialGraph(KeyFrame* pCurKF, vector &vpFi VSim3->setId(nIDi); VSim3->setMarginalized(false); - VSim3->_fix_scale = true; //TODO optimizer.addVertex(VSim3); @@ -3219,13 +3218,8 @@ void Optimizer::OptimizeEssentialGraph(KeyFrame* pCurKF, vector &vpFi Eigen::Matrix Rcw = Converter::toMatrix3d(pKFi->GetRotation()); Eigen::Matrix tcw = Converter::toVector3d(pKFi->GetTranslation()); g2o::Sim3 Siw(Rcw,tcw,1.0); - //vScw[nIDi] = Siw; + vScw[nIDi] = Siw; VSim3->setEstimate(Siw); - cv::Mat Tcw_bef = pKFi->mTcwBefMerge; - Eigen::Matrix Rcw_bef = Converter::toMatrix3d(Tcw_bef.rowRange(0,3).colRange(0,3)); - Eigen::Matrix tcw_bef = Converter::toVector3d(Tcw_bef.rowRange(0,3).col(3)); - vScw[nIDi] = g2o::Sim3(Rcw_bef,tcw_bef,1.0); - VSim3->setFixed(false); @@ -3411,12 +3405,9 @@ void Optimizer::OptimizeEssentialGraph(KeyFrame* pCurKF, vector &vpFi cout << "--Distance: " << dist << " meters" << endl; cout << "--To much distance correction in EssentGraph: It has connected " << pKFi->GetVectorCovisibleKeyFrames().size() << " KFs" << endl; } - string strNameFile = pKFi->mNameFile; cv::Mat imLeft = cv::imread(strNameFile, CV_LOAD_IMAGE_UNCHANGED); - cv::cvtColor(imLeft, imLeft, CV_GRAY2BGR); - vector vpMapPointsKFi = pKFi->GetMapPointMatches(); for(int j=0; j &vpFi cv::circle(imLeft, pKFi->mvKeys[j].pt, 2, cv::Scalar(0, 255, 0)); cv::putText(imLeft, strNumOBs, pKFi->mvKeys[j].pt, CV_FONT_HERSHEY_DUPLEX, 1, cv::Scalar(255, 0, 0)); } - string namefile = "./test_OptEssent/Essent_" + to_string(pCurKF->mnId) + "_KF" + to_string(pKFi->mnId) +"_D" + to_string(dist) +".png"; cv::imwrite(namefile, imLeft); }*/ @@ -3453,7 +3443,6 @@ void Optimizer::OptimizeEssentialGraph(KeyFrame* pCurKF, vector &vpFi } else { - }*/ KeyFrame* pRefKF = pMPi->GetReferenceKeyFrame(); g2o::Sim3 Srw; @@ -3472,7 +3461,6 @@ void Optimizer::OptimizeEssentialGraph(KeyFrame* pCurKF, vector &vpFi /*if(pRefKF->mnMergeCorrectedForKF == pCurKF->mnId) { int nIDr = pRefKF->mnId; - Srw = vScw[nIDr]; correctedSwr = vCorrectedSwc[nIDr]; } @@ -3488,17 +3476,17 @@ void Optimizer::OptimizeEssentialGraph(KeyFrame* pCurKF, vector &vpFi Eigen::Matrix twr = Converter::toVector3d(Twr.rowRange(0,3).col(3)); correctedSwr = g2o::Sim3(Rwr,twr,1.0); //} - cout << "Opt_Essential: Loaded the KF reference position" << endl; + //cout << "Opt_Essential: Loaded the KF reference position" << endl; cv::Mat P3Dw = pMPi->GetWorldPos(); Eigen::Matrix eigP3Dw = Converter::toVector3d(P3Dw); Eigen::Matrix eigCorrectedP3Dw = correctedSwr.map(Srw.map(eigP3Dw)); - cout << "Opt_Essential: Calculated the new MP position" << endl; + //cout << "Opt_Essential: Calculated the new MP position" << endl; cv::Mat cvCorrectedP3Dw = Converter::toCvMat(eigCorrectedP3Dw); - cout << "Opt_Essential: Converted the position to the OpenCV format" << endl; + //cout << "Opt_Essential: Converted the position to the OpenCV format" << endl; pMPi->SetWorldPos(cvCorrectedP3Dw); - cout << "Opt_Essential: Loaded the corrected position in the MP object" << endl; + //cout << "Opt_Essential: Loaded the corrected position in the MP object" << endl; pMPi->UpdateNormalAndDepth(); }