Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add support for limiting num_threads in tbb task #252

Merged
merged 50 commits into from
Mar 18, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
50 commits
Select commit Hold shift + click to select a range
5e08b68
Add support for limiting num_threads in tbb task
dch4o Nov 2, 2023
fae5b46
Merge remote-tracking branch 'origin/main' into feature/set-num-threads
nachovizzo Feb 11, 2024
24964c8
Make num_threads a paramter of the voxel hash map
nachovizzo Feb 11, 2024
51decb1
This got a bit more hacky but is to avoid hardocding a praamter
nachovizzo Feb 11, 2024
b327258
Propagate max_threads to Python config
nachovizzo Feb 11, 2024
a262e9f
Merge remote-tracking branch 'origin/main' into feature/set-num-threads
nachovizzo Feb 29, 2024
e5044f8
First draft on core library
nachovizzo Mar 1, 2024
6c7e505
Update python API
nachovizzo Mar 1, 2024
80248bb
Rearange
nachovizzo Mar 1, 2024
505ab61
Remove type alias
nachovizzo Mar 1, 2024
1dc13a7
Fix build
nachovizzo Mar 1, 2024
5053877
Wrap constants into a configuration struct
nachovizzo Mar 1, 2024
0e015d9
Split the watters
nachovizzo Mar 1, 2024
d4378b4
It's all about drafts
nachovizzo Mar 1, 2024
ebdfab5
Update python API
nachovizzo Mar 1, 2024
598e1a6
Some renaming just because
nachovizzo Mar 1, 2024
18465fd
Changing names trying to auto-convince myself...
nachovizzo Mar 1, 2024
3606d0c
Fix c++ build
nachovizzo Mar 1, 2024
9fa9f2d
rename function
benemer Mar 4, 2024
ea7b313
renaming variables
benemer Mar 4, 2024
5c8fc25
renaming, should be one neighbor only
benemer Mar 4, 2024
01b11c5
Tizianified a little bit
tizianoGuadagnino Mar 4, 2024
f4a2465
Draft on voxelhashmap
nachovizzo Mar 4, 2024
0cb69a7
Rename
nachovizzo Mar 4, 2024
39e4cbf
Rename Correspondences -> Associations
nachovizzo Mar 4, 2024
b434e04
Move stuff around only
nachovizzo Mar 4, 2024
70a6457
Remove redunant name
nachovizzo Mar 4, 2024
876fedc
They are not there, we need to find them!
nachovizzo Mar 4, 2024
c338afb
Shrink
nachovizzo Mar 4, 2024
2b79370
Tiziano shows to guys -> with for_each
tizianoGuadagnino Mar 4, 2024
d834170
Tiziano shows to guys -> with transform_reduce....sexy
tizianoGuadagnino Mar 4, 2024
b58d352
Merge remote-tracking branch 'origin/nacho/strip_nn_search_from_voxel…
nachovizzo Mar 5, 2024
f88310f
Consistent naming
nachovizzo Mar 5, 2024
8fb80db
Bring comments for readbilty
nachovizzo Mar 5, 2024
f5c1524
rename variable
nachovizzo Mar 5, 2024
318cd86
Sacrifice name for one-liner
nachovizzo Mar 5, 2024
0c823ae
AlignCloudToMap -> AlignPointsToMap
nachovizzo Mar 5, 2024
7a45c9d
Make rename like a book on ProbRob
tizianoGuadagnino Mar 5, 2024
26dd7b0
Revert "Make rename like a book on ProbRob"
nachovizzo Mar 5, 2024
d5a38f4
estimation_threshold -> convergence_criterion
nachovizzo Mar 5, 2024
f2e5d60
Rename threshold also here
benemer Mar 5, 2024
9a80e16
Merge remote-tracking branch 'origin/nacho/strip_nn_search_from_voxel…
nachovizzo Mar 5, 2024
cdafca9
Merge remote-tracking branch 'origin/nacho/strip_nn_search_from_voxel…
nachovizzo Mar 5, 2024
cfadfab
no typos no nacho
nachovizzo Mar 5, 2024
bd063e9
Remove comment
nachovizzo Mar 5, 2024
90e6fc5
Merge remote-tracking branch 'origin/nacho/strip_nn_search_from_voxel…
nachovizzo Mar 5, 2024
cbc831c
Merge remote-tracking branch 'origin/main' into feature/set-num-threads
nachovizzo Mar 5, 2024
af2c31a
reduce diff
nachovizzo Mar 5, 2024
f550a1a
Small improvement. max_num_threads_ always represents what it says
nachovizzo Mar 11, 2024
bb880fd
Remove single letter variable
tizianoGuadagnino Mar 18, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Draft on voxelhashmap
  • Loading branch information
nachovizzo committed Mar 4, 2024
commit f4a246524b6448f4ae8b9278f3875738be4b45fa
20 changes: 19 additions & 1 deletion cpp/kiss_icp/core/Registration.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -51,6 +51,24 @@ void TransformPoints(const Sophus::SE3d &T, std::vector<Eigen::Vector3d> &points
[&](const auto &point) { return T * point; });
}

// Function to obtain the KNN of one point
Eigen::Vector3d GetClosestNeighborInMap(const Eigen::Vector3d &point,
const kiss_icp::VoxelHashMap &voxel_map) {
const auto &voxels = voxel_map.GetVoxelNeighborhoodAroundPoint(point);
const auto &neighbors = voxel_map.PointCloud(voxels);
Eigen::Vector3d closest_neighbor;
double closest_distance2 = std::numeric_limits<double>::max();
std::for_each(neighbors.cbegin(), neighbors.cend(), [&](const auto &neighbor) {
double distance = (neighbor - point).squaredNorm();
if (distance < closest_distance2) {
closest_neighbor = neighbor;
closest_distance2 = distance;
}
});

return closest_neighbor;
}

LinearSystem BuildLinearSystem(const CorrespondenceVector &associations, double kernel) {
auto compute_jacobian_and_residual = [&](auto i) {
const auto &[p_source, p_target] = associations[i];
Expand Down Expand Up @@ -106,7 +124,7 @@ CorrespondenceVector GetCorrespondences(const std::vector<Eigen::Vector3d> &poin
CorrespondenceVector res) -> CorrespondenceVector {
res.reserve(r.size());
for (const auto &point : r) {
Eigen::Vector3d closest_neighbor = voxel_map.GetClosestNeighbor(point);
Eigen::Vector3d closest_neighbor = GetClosestNeighborInMap(point, voxel_map);
if ((closest_neighbor - point).norm() < max_correspondance_distance) {
res.emplace_back(point, closest_neighbor);
}
Expand Down
42 changes: 15 additions & 27 deletions cpp/kiss_icp/core/VoxelHashMap.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -31,46 +31,34 @@

namespace kiss_icp {

// Function to obtain the KNN of one point
Eigen::Vector3d VoxelHashMap::GetClosestNeighbor(const Eigen::Vector3d &point) const {
std::vector<VoxelHashMap::Voxel> VoxelHashMap::GetVoxelNeighborhoodAroundPoint(
const Eigen::Vector3d &point, int adjacent_voxels) const {
auto kx = static_cast<int>(point[0] / voxel_size_);
auto ky = static_cast<int>(point[1] / voxel_size_);
auto kz = static_cast<int>(point[2] / voxel_size_);
std::vector<kiss_icp::VoxelHashMap::Voxel> voxels;
voxels.reserve(27);
for (int i = kx - 1; i < kx + 1 + 1; ++i) {
for (int j = ky - 1; j < ky + 1 + 1; ++j) {
for (int k = kz - 1; k < kz + 1 + 1; ++k) {
voxels.emplace_back(i, j, k);
std::vector<Voxel> voxel_neighborhood;
for (int i = kx - adjacent_voxels; i < kx + adjacent_voxels + 1; ++i) {
for (int j = ky - adjacent_voxels; j < ky + adjacent_voxels + 1; ++j) {
for (int k = kz - adjacent_voxels; k < kz + adjacent_voxels + 1; ++k) {
voxel_neighborhood.emplace_back(i, j, k);
}
}
}
return voxel_neighborhood;
}

std::vector<Eigen::Vector3d> neighbors;
neighbors.reserve(static_cast<size_t>(27 * max_points_per_voxel_));
std::vector<Eigen::Vector3d> VoxelHashMap::PointCloud(const std::vector<Voxel> &voxels) const {
std::vector<Eigen::Vector3d> points;
points.reserve(voxels.size() * static_cast<size_t>(max_points_per_voxel_));
std::for_each(voxels.cbegin(), voxels.cend(), [&](const auto &voxel) {
auto search = map_.find(voxel);
if (search != map_.end()) {
const auto &points = search->second.points;
if (!points.empty()) {
for (const auto &point : points) {
neighbors.emplace_back(point);
}
for (const auto &point : search->second.points) {
points.emplace_back(point);
}
}
});

Eigen::Vector3d closest_neighbor;
double closest_distance2 = std::numeric_limits<double>::max();
std::for_each(neighbors.cbegin(), neighbors.cend(), [&](const auto &neighbor) {
double distance = (neighbor - point).squaredNorm();
if (distance < closest_distance2) {
closest_neighbor = neighbor;
closest_distance2 = distance;
}
});

return closest_neighbor;
return points;
}

std::vector<Eigen::Vector3d> VoxelHashMap::Pointcloud() const {
Expand Down
4 changes: 3 additions & 1 deletion cpp/kiss_icp/core/VoxelHashMap.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -62,7 +62,9 @@ struct VoxelHashMap {
void AddPoints(const std::vector<Eigen::Vector3d> &points);
void RemovePointsFarFromLocation(const Eigen::Vector3d &origin);
std::vector<Eigen::Vector3d> Pointcloud() const;
Eigen::Vector3d GetClosestNeighbor(const Eigen::Vector3d &point) const;
std::vector<Eigen::Vector3d> GetPointsInVoxels(const std::vector<Voxel> &voxels) const;
std::vector<Voxel> GetVoxelNeighborhoodAroundPoint(const Eigen::Vector3d &point,
int adjacent_voxels = 1) const;

double voxel_size_;
double max_distance_;
Expand Down