Commit 5a517f5d authored by wangdawei's avatar wangdawei

matcher reset and laser filter

parent 65f57bcd
...@@ -42,7 +42,7 @@ AdjustPPK::AdjustPPK(const string &ieBaseDir, const string &mapDir) ...@@ -42,7 +42,7 @@ AdjustPPK::AdjustPPK(const string &ieBaseDir, const string &mapDir)
LOG(INFO) << "calib_: " << calib_.translation().transpose() LOG(INFO) << "calib_: " << calib_.translation().transpose()
<< " rpy: " << rpy.transpose(); << " rpy: " << rpy.transpose();
trd_.reset(new boost::thread(boost::bind(&AdjustPPK::LoadMap, this))); trd_.reset(new boost::thread(boost::bind(&AdjustPPK::LoadMap, this)));
skipCnt_ = 20; skipCnt_ = 40;
} }
AdjustPPK::~AdjustPPK() AdjustPPK::~AdjustPPK()
...@@ -56,7 +56,7 @@ void AdjustPPK::ConfigConvert(const string &firetimeFile, const string &correcti ...@@ -56,7 +56,7 @@ void AdjustPPK::ConfigConvert(const string &firetimeFile, const string &correcti
{ {
LOG(INFO) << "correctionFile: " << correctionFile; LOG(INFO) << "correctionFile: " << correctionFile;
LOG(INFO) << "firetimeFile: " << firetimeFile; LOG(INFO) << "firetimeFile: " << firetimeFile;
convert_.reset(new pandar_pointcloud::Convert(firetimeFile, correctionFile)); convert_.reset(new pandar_pointcloud::Convert(firetimeFile, correctionFile, true));
LOG(INFO) << "ConfigConvert done"; LOG(INFO) << "ConfigConvert done";
} }
...@@ -231,6 +231,9 @@ void AdjustPPK::LoadMapInfo() ...@@ -231,6 +231,9 @@ void AdjustPPK::LoadMapInfo()
directory_iterator stream_iter(outputDir); directory_iterator stream_iter(outputDir);
directory_iterator stream_end_iter; directory_iterator stream_end_iter;
for(; stream_iter != stream_end_iter; stream_iter++) { for(; stream_iter != stream_end_iter; stream_iter++) {
if(stream_iter->path().extension().string() != ".stream"){
continue;
}
auto fileName = stream_iter->path().stem().string(); auto fileName = stream_iter->path().stem().string();
ulong meshId; ulong meshId;
try { try {
...@@ -488,10 +491,19 @@ bool AdjustPPK::ConfigMap(double timestamp) ...@@ -488,10 +491,19 @@ bool AdjustPPK::ConfigMap(double timestamp)
return false; return false;
} }
if(currMatcher_){ if(currMatcher_){
currMatcher_->unLoadAllBlocks(); // currMatcher_->unLoadAllBlocks();
currMatcher_.reset();
}
// while(!meshVec_.at(meshId).matcher){
// std::this_thread::sleep_for(std::chrono::milliseconds(100));
// }
auto &meshInfo = meshVec_.at(meshId);
if(meshInfo.streamPath != ""){
if(LoadMesh(meshInfo.streamPath, meshInfo.matcher)){
LOG(INFO) << "mesh loaded: " << meshId;
}else{
return false;
} }
while(!meshVec_.at(meshId).matcher){
std::this_thread::sleep_for(std::chrono::milliseconds(100));
} }
currMatcher_ = meshVec_.at(meshId).matcher; currMatcher_ = meshVec_.at(meshId).matcher;
LOG(INFO) << "set currMatcher_: " << meshId; LOG(INFO) << "set currMatcher_: " << meshId;
...@@ -541,16 +553,16 @@ bool AdjustPPK::LocateCloud(const CloudInfoForMatch &cloudInfo) ...@@ -541,16 +553,16 @@ bool AdjustPPK::LocateCloud(const CloudInfoForMatch &cloudInfo)
if(score < 0){ if(score < 0){
guessPose.precision_type = MATCH_PRECISION_INIT; guessPose.precision_type = MATCH_PRECISION_INIT;
currMatcher_->MatchPointCloud(cloudInfo.frame, guessPose, finalGnssPose, finalPose); currMatcher_->MatchPointCloud(cloudInfo.frame, guessPose, finalGnssPose, finalPose);
mapPose_ = finalPose.cast<double>(); mapPose_.translation() = finalPose.translation().cast<double>();
CloseToPPK(0.1); CloseToPPK(0.1);
skipCnt_ = 5; skipCnt_ = 10;
return true; return true;
} }
skipCnt_ = 20; skipCnt_ = 40;
guessPose.map_point = finalPose.cast<double>(); guessPose.map_point = finalPose.cast<double>();
guessPose.precision_type = MATCH_PRECISION_HIGH; guessPose.precision_type = MATCH_PRECISION_HIGH;
currMatcher_->MatchPointCloud(cloudInfo.frame, guessPose, finalGnssPose, finalPose); currMatcher_->MatchPointCloud(cloudInfo.frame, guessPose, finalGnssPose, finalPose);
mapPose_ = finalPose.cast<double>(); mapPose_.translation() = finalPose.translation().cast<double>();
return true; return true;
} }
...@@ -581,9 +593,10 @@ void AdjustPPK::LoadMap() ...@@ -581,9 +593,10 @@ void AdjustPPK::LoadMap()
LOG(INFO) << "mesh exist: " << meshId; LOG(INFO) << "mesh exist: " << meshId;
} }
if(LoadMesh(streamPath, meshInfo.matcher)){ meshInfo.streamPath = streamPath;
LOG(INFO) << "mesh loaded: " << meshId; // if(LoadMesh(streamPath, meshInfo.matcher)){
} // LOG(INFO) << "mesh loaded: " << meshId;
// }
} }
// for(size_t id = period.startId; id <= period.endId; id += 100){ // for(size_t id = period.startId; id <= period.endId; id += 100){
// if(requestQuit_){ // if(requestQuit_){
...@@ -668,7 +681,7 @@ bool AdjustPPK::LoadMesh(const string &streamPath, boost::shared_ptr<VoxelMapMat ...@@ -668,7 +681,7 @@ bool AdjustPPK::LoadMesh(const string &streamPath, boost::shared_ptr<VoxelMapMat
LOG(INFO) << "mesh to load: " << streamPath; LOG(INFO) << "mesh to load: " << streamPath;
VoxelMapMatcherOption option; VoxelMapMatcherOption option;
option.option.filter_resolution = 1.2; option.option.filter_resolution = 1.0;
option.option.cloud_range = 80; option.option.cloud_range = 80;
option.fast_option.accepted_score = 0.3; option.fast_option.accepted_score = 0.3;
option.fast_option.accepted_low_score = 0.4; option.fast_option.accepted_low_score = 0.4;
......
...@@ -45,6 +45,7 @@ struct PCDPathInfo{ ...@@ -45,6 +45,7 @@ struct PCDPathInfo{
struct MashMap{ struct MashMap{
vector<PCDPathInfo> pcdPathVec; vector<PCDPathInfo> pcdPathVec;
boost::shared_ptr<VoxelMapMatcher> matcher; boost::shared_ptr<VoxelMapMatcher> matcher;
string streamPath;
}; };
class AdjustPPK class AdjustPPK
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment