Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
L
localize_for_ppk
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wangdawei
localize_for_ppk
Commits
d1a24026
Commit
d1a24026
authored
May 30, 2023
by
wangdawei
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
test
parent
ad67ab18
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
25 additions
and
21 deletions
+25
-21
adjust_ppk.cpp
libs/locate_system/adjust_ppk_by_locate/adjust_ppk.cpp
+19
-15
adjust_ppk.h
libs/locate_system/adjust_ppk_by_locate/adjust_ppk.h
+3
-2
maparea.h
libs/voxel_map/libs/area/maparea.h
+1
-1
mesharea.cpp
libs/voxel_map/libs/area/mesharea.cpp
+0
-1
mesharea.h
libs/voxel_map/libs/area/mesharea.h
+2
-2
No files found.
libs/locate_system/adjust_ppk_by_locate/adjust_ppk.cpp
View file @
d1a24026
...
@@ -242,22 +242,23 @@ void AdjustPPK::CalPPKPeriod()
...
@@ -242,22 +242,23 @@ void AdjustPPK::CalPPKPeriod()
ppkPeriodVec_
.
reserve
(
1000
);
ppkPeriodVec_
.
reserve
(
1000
);
PPKPeriod
period
;
PPKPeriod
period
;
period
.
meshId
=
0
;
period
.
meshId
=
0
;
period
.
period
.
reserve
(
10000
);
for
(
size_t
i
=
0
;
i
<
rawData_
.
size
();
i
++
){
for
(
const
IERawData
&
rawPPK
:
rawData_
){
const
IERawData
&
rawPPK
=
rawData_
.
at
(
i
);
ulong
meshId
=
GetMeshFromPosition
(
rawPPK
.
longitude
,
rawPPK
.
latitude
);
ulong
meshId
=
GetMeshFromPosition
(
rawPPK
.
longitude
,
rawPPK
.
latitude
);
if
(
meshId
!=
period
.
meshId
){
if
(
meshId
!=
period
.
meshId
){
if
(
period
.
period
.
size
()
){
if
(
period
.
startTime
>
0
){
period
.
endTime
=
rawPPK
.
unix_time
;
period
.
endTime
=
rawPPK
.
unix_time
;
period
.
endId
=
i
-
1
;
ppkPeriodVec_
.
emplace_back
(
period
);
ppkPeriodVec_
.
emplace_back
(
period
);
period
.
meshId
=
meshId
;
LOG
(
INFO
)
<<
"period.meshId: "
<<
period
.
meshId
;
LOG
(
INFO
)
<<
"period.meshId: "
<<
period
.
meshId
;
period
.
period
.
resize
(
0
);
}
}
period
.
startTime
=
rawPPK
.
unix_time
;
period
.
startTime
=
rawPPK
.
unix_time
;
period
.
startId
=
i
;
period
.
meshId
=
meshId
;
}
}
period
.
period
.
emplace_back
(
rawPPK
);
}
}
period
.
endTime
=
rawData_
.
back
().
unix_time
;
period
.
endTime
=
rawData_
.
back
().
unix_time
;
period
.
endId
=
rawData_
.
size
()
-
1
;
ppkPeriodVec_
.
emplace_back
(
period
);
ppkPeriodVec_
.
emplace_back
(
period
);
LOG
(
INFO
)
<<
"ppkPeriodVec_.size(): "
<<
ppkPeriodVec_
.
size
();
LOG
(
INFO
)
<<
"ppkPeriodVec_.size(): "
<<
ppkPeriodVec_
.
size
();
}
}
...
@@ -309,7 +310,7 @@ bool AdjustPPK::Undisort(
...
@@ -309,7 +310,7 @@ bool AdjustPPK::Undisort(
PointCloudJ
mappedFrame
;
PointCloudJ
mappedFrame
;
CloudPreprocess
::
Instance
()
->
Undisort
(
CloudPreprocess
::
Instance
()
->
Undisort
(
frame
,
undisortedFrame
,
&
mappedFrame
,
rawFrame
.
cloud
.
back
().
time
,
&
periodPose
,
framePose
,
increasePose
);
frame
,
undisortedFrame
,
&
mappedFrame
,
rawFrame
.
cloud
.
back
().
time
,
&
periodPose
,
framePose
,
increasePose
);
//
pcl::io::savePCDFileBinary(ieBaseDir_ + "/baseCloud/" + to_string(rawFrame.timestamp) + "_mapped.pcd", mappedFrame);
pcl
::
io
::
savePCDFileBinary
(
ieBaseDir_
+
"/baseCloud/"
+
to_string
(
rawFrame
.
timestamp
)
+
"_mapped.pcd"
,
mappedFrame
);
cloudInfo
.
frame
=
undisortedFrame
;
cloudInfo
.
frame
=
undisortedFrame
;
cloudInfo
.
filterPoseInfo
.
increasePose
=
increasePose
;
cloudInfo
.
filterPoseInfo
.
increasePose
=
increasePose
;
cloudInfo
.
timestamp
=
rawFrame
.
timestamp
;
cloudInfo
.
timestamp
=
rawFrame
.
timestamp
;
...
@@ -373,10 +374,11 @@ bool AdjustPPK::LocateCloud(const CloudInfoForMatch &cloudInfo)
...
@@ -373,10 +374,11 @@ bool AdjustPPK::LocateCloud(const CloudInfoForMatch &cloudInfo)
guessPose
.
movement
=
cloudInfo
.
filterPoseInfo
.
increasePose
.
translation
().
norm
();
guessPose
.
movement
=
cloudInfo
.
filterPoseInfo
.
increasePose
.
translation
().
norm
();
guessPose
.
rotation
=
fabs
(
increaseRpy
.
z
());
guessPose
.
rotation
=
fabs
(
increaseRpy
.
z
());
guessPose
.
use_gnss
=
false
;
guessPose
.
use_gnss
=
false
;
LOG
(
INFO
)
<<
"currMatcher_ ptr: "
<<
currMatcher_
.
get
();
if
(
!
currMatcher_
->
IsMapLoaded
(
mapPose_
.
translation
().
cast
<
double
>
())){
if
(
!
currMatcher_
->
IsMapLoaded
(
mapPose_
.
translation
().
cast
<
double
>
())){
currMatcher_
->
loadArea
(
mapPose_
.
translation
().
cast
<
double
>
());
currMatcher_
->
loadArea
(
mapPose_
.
translation
().
cast
<
double
>
());
}
}
ofs
<<
setprecision
(
16
)
<<
cloudInfo
.
timestamp
<<
", "
<<
mapPose_
.
translation
().
x
()
<<
", "
<<
mapPose_
.
translation
().
y
()
<<
", "
<<
mapPose_
.
translation
().
z
()
<<
endl
;
guessPose
.
precision_type
=
MATCH_PRECISION_FAST
;
guessPose
.
precision_type
=
MATCH_PRECISION_FAST
;
float
score
=
currMatcher_
->
MatchPointCloud
(
cloudInfo
.
frame
,
guessPose
,
finalGnssPose
,
mapPose_
);
float
score
=
currMatcher_
->
MatchPointCloud
(
cloudInfo
.
frame
,
guessPose
,
finalGnssPose
,
mapPose_
);
if
(
score
<
0.45
){
if
(
score
<
0.45
){
...
@@ -385,8 +387,6 @@ bool AdjustPPK::LocateCloud(const CloudInfoForMatch &cloudInfo)
...
@@ -385,8 +387,6 @@ bool AdjustPPK::LocateCloud(const CloudInfoForMatch &cloudInfo)
guessPose
.
map_point
=
mapPose_
.
cast
<
double
>
();
guessPose
.
map_point
=
mapPose_
.
cast
<
double
>
();
guessPose
.
precision_type
=
MATCH_PRECISION_HIGH
;
guessPose
.
precision_type
=
MATCH_PRECISION_HIGH
;
currMatcher_
->
MatchPointCloud
(
cloudInfo
.
frame
,
guessPose
,
finalGnssPose
,
mapPose_
);
currMatcher_
->
MatchPointCloud
(
cloudInfo
.
frame
,
guessPose
,
finalGnssPose
,
mapPose_
);
ofs
<<
setprecision
(
16
)
<<
cloudInfo
.
timestamp
<<
", "
<<
mapPose_
.
translation
().
x
()
<<
", "
<<
mapPose_
.
translation
().
y
()
<<
", "
<<
mapPose_
.
translation
().
z
()
<<
endl
;
return
true
;
return
true
;
}
}
...
@@ -415,9 +415,12 @@ void AdjustPPK::LoadMap()
...
@@ -415,9 +415,12 @@ void AdjustPPK::LoadMap()
LOG
(
INFO
)
<<
"mesh exist: "
<<
meshId
;
LOG
(
INFO
)
<<
"mesh exist: "
<<
meshId
;
}
}
LoadMesh
(
streamPath
,
meshInfo
.
matcher
);
if
(
LoadMesh
(
streamPath
,
meshInfo
.
matcher
)){
LOG
(
INFO
)
<<
"mesh loaded: "
<<
meshId
LOG
(
INFO
)
<<
"mesh loaded: "
<<
meshId
;
<<
" ptr: "
<<
meshInfo
.
matcher
.
get
();
for
(
size_t
id
=
period
.
startId
;
id
<=
period
.
endId
;
id
+=
100
){
meshInfo
.
matcher
->
loadArea
(
localPoseVec_
.
at
(
id
).
pose
.
translation
());
}
}
}
}
}
}
...
@@ -444,11 +447,11 @@ void AdjustPPK::Compress(const vector<string> &pcdPathVec,
...
@@ -444,11 +447,11 @@ void AdjustPPK::Compress(const vector<string> &pcdPathVec,
blockSerializer
.
configSerialization
();
blockSerializer
.
configSerialization
();
}
}
void
AdjustPPK
::
LoadMesh
(
const
string
&
streamPath
,
boost
::
shared_ptr
<
VoxelMapMatcher
>
&
matcher
)
bool
AdjustPPK
::
LoadMesh
(
const
string
&
streamPath
,
boost
::
shared_ptr
<
VoxelMapMatcher
>
&
matcher
)
{
{
if
(
!
boost
::
filesystem
::
exists
(
streamPath
)){
if
(
!
boost
::
filesystem
::
exists
(
streamPath
)){
LOG
(
WARNING
)
<<
"streamPath not exists: "
<<
streamPath
;
LOG
(
WARNING
)
<<
"streamPath not exists: "
<<
streamPath
;
return
;
return
false
;
}
}
LOG
(
INFO
)
<<
"mesh to load: "
<<
streamPath
;
LOG
(
INFO
)
<<
"mesh to load: "
<<
streamPath
;
...
@@ -459,6 +462,7 @@ void AdjustPPK::LoadMesh(const string &streamPath, boost::shared_ptr<VoxelMapMat
...
@@ -459,6 +462,7 @@ void AdjustPPK::LoadMesh(const string &streamPath, boost::shared_ptr<VoxelMapMat
option
.
fast_option
.
accepted_low_score
=
0.55
;
option
.
fast_option
.
accepted_low_score
=
0.55
;
matcher
.
reset
(
new
VoxelMapMatcher
(
option
));
matcher
.
reset
(
new
VoxelMapMatcher
(
option
));
matcher
->
SetMapPath
(
streamPath
);
matcher
->
SetMapPath
(
streamPath
);
return
true
;
}
}
}
// end of namespace
}
// end of namespace
libs/locate_system/adjust_ppk_by_locate/adjust_ppk.h
View file @
d1a24026
...
@@ -14,10 +14,11 @@
...
@@ -14,10 +14,11 @@
#include "serialize/blockserializer.h"
#include "serialize/blockserializer.h"
struct
PPKPeriod
{
struct
PPKPeriod
{
vector
<
IERawData
>
period
;
ulong
meshId
;
ulong
meshId
;
double
startTime
=
-
1
;
double
startTime
=
-
1
;
double
endTime
=
-
1
;
double
endTime
=
-
1
;
uint32_t
startId
=
0
;
uint32_t
endId
=
0
;
int
InPeriod
(
double
timestamp
){
int
InPeriod
(
double
timestamp
){
LOG_EVERY_N
(
INFO
,
99
)
<<
setprecision
(
15
)
<<
"timestamp "
<<
timestamp
LOG_EVERY_N
(
INFO
,
99
)
<<
setprecision
(
15
)
<<
"timestamp "
<<
timestamp
...
@@ -78,7 +79,7 @@ private:
...
@@ -78,7 +79,7 @@ private:
void
Compress
(
const
vector
<
string
>
&
pcdPathVec
,
void
Compress
(
const
vector
<
string
>
&
pcdPathVec
,
const
string
&
streamPath
);
const
string
&
streamPath
);
void
LoadMesh
(
const
string
&
streamPath
,
bool
LoadMesh
(
const
string
&
streamPath
,
boost
::
shared_ptr
<
VoxelMapMatcher
>
&
matcher
);
boost
::
shared_ptr
<
VoxelMapMatcher
>
&
matcher
);
private
:
private
:
string
ieBaseDir_
;
string
ieBaseDir_
;
...
...
libs/voxel_map/libs/area/maparea.h
View file @
d1a24026
...
@@ -88,7 +88,7 @@ public:
...
@@ -88,7 +88,7 @@ public:
}
}
inline
bool
IsMapLoaded
(
const
Vector3d
&
pose
)
inline
bool
IsMapLoaded
(
const
Vector3d
&
pose
)
{
{
LOG
(
INFO
)
<<
"pose: "
<<
pose
.
transpose
();
//
LOG(INFO) << "pose: " << pose.transpose();
return
currMesh_
->
IsAreaLoaded
(
pose
);
return
currMesh_
->
IsAreaLoaded
(
pose
);
}
}
...
...
libs/voxel_map/libs/area/mesharea.cpp
View file @
d1a24026
...
@@ -271,7 +271,6 @@ void MeshArea::loadBlockAtArea(const Vector3d &position)
...
@@ -271,7 +271,6 @@ void MeshArea::loadBlockAtArea(const Vector3d &position)
Vector2i
centerIndex
=
Vector2i
centerIndex
=
calShiftedIndex
(
position
.
x
(),
position
.
y
());
calShiftedIndex
(
position
.
x
(),
position
.
y
());
LOG
(
INFO
)
<<
"shiftedIndexToLoad: "
<<
centerIndex
.
transpose
();
LOG
(
INFO
)
<<
"shiftedIndexToLoad: "
<<
centerIndex
.
transpose
();
LOG
(
INFO
)
<<
"offset_: "
<<
offset_
.
transpose
();
vector
<
Vector2i
>
neighbors
;
vector
<
Vector2i
>
neighbors
;
if
(
fstLoadMap
){
if
(
fstLoadMap
){
neighbors
=
firstLoadNeighbors_
;
neighbors
=
firstLoadNeighbors_
;
...
...
libs/voxel_map/libs/area/mesharea.h
View file @
d1a24026
...
@@ -73,8 +73,8 @@ public:
...
@@ -73,8 +73,8 @@ public:
}
}
Vector2i
shiftedIndexToLoad
=
Vector2i
shiftedIndexToLoad
=
calShiftedIndex
(
pose
.
x
(),
pose
.
y
());
calShiftedIndex
(
pose
.
x
(),
pose
.
y
());
LOG
(
INFO
)
<<
"pose: "
<<
pose
.
transpose
()
//
LOG(INFO) << "pose: " << pose.transpose()
<<
" shiftedIndexToLoad: "
<<
shiftedIndexToLoad
.
transpose
();
//
<< " shiftedIndexToLoad: " << shiftedIndexToLoad.transpose();
return
checkBlockAtAreaToLoad
(
shiftedIndexToLoad
);
return
checkBlockAtAreaToLoad
(
shiftedIndexToLoad
);
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment