oh_my_loam/common/utils.h

83 lines
2.8 KiB
C
Raw Normal View History

2020-10-09 21:04:25 +08:00
#pragma once
#include "types.h"
2020-10-09 21:04:25 +08:00
2020-10-12 21:09:32 +08:00
namespace oh_my_loam {
2020-10-09 21:04:25 +08:00
template <typename PointT>
2020-10-12 21:09:32 +08:00
inline double DistanceSqure(const PointT& pt) {
return pt.x * pt.x + pt.y * pt.y + pt.z * pt.z;
2020-10-09 21:04:25 +08:00
}
template <typename PointT>
2020-10-12 21:09:32 +08:00
inline double Distance(const PointT& pt) {
return std::sqrt(pt.x * pt.x + pt.y * pt.y + pt.z * pt.z);
2020-10-09 21:04:25 +08:00
}
template <typename PointT>
inline double IsFinite(const PointT& pt) {
return std::isfinite(pt.x) && std::isfinite(pt.y) && std::isfinite(pt.z);
}
// normalize an angle to [-pi, pi)
2020-10-16 18:08:31 +08:00
double NormalizeAngle(double ang);
2020-10-09 21:04:25 +08:00
2020-10-12 21:09:32 +08:00
template <typename PointT>
void DrawPointCloud(const pcl::PointCloud<PointT>& cloud, const Color& color,
const std::string& id, PCLVisualizer* const viewer,
int pt_size = 3) {
PCLColorHandlerCustom<PointT> color_handler(cloud.makeShared(), color.r,
color.g, color.b);
viewer->addPointCloud<PointT>(cloud.makeShared(), color_handler, id);
viewer->setPointCloudRenderingProperties(
pcl::visualization::PCL_VISUALIZER_POINT_SIZE, pt_size, id);
}
template <typename PointT>
void DrawPointCloud(const pcl::PointCloud<PointT>& cloud,
const std::string& field, const std::string& id,
PCLVisualizer* const viewer, int pt_size = 3) {
PCLColorHandlerGenericField<PointT> color_handler(cloud.makeShared(), field);
viewer->addPointCloud<PointT>(cloud.makeShared(), color_handler, id);
viewer->setPointCloudRenderingProperties(
pcl::visualization::PCL_VISUALIZER_POINT_SIZE, pt_size, id);
2020-10-09 21:04:25 +08:00
}
2020-10-16 18:08:31 +08:00
template <typename PointT>
void RemovePointsIf(const pcl::PointCloud<PointT>& cloud_in,
pcl::PointCloud<PointT>* const cloud_out,
std::function<bool(const PointT&)> cond) {
if (&cloud_in != cloud_out) {
cloud_out->header = cloud_in.header;
cloud_out->points.resize(cloud_in.size());
}
size_t j = 0;
for (size_t i = 0; i < cloud_in.size(); ++i) {
const auto pt = cloud_in.points[i];
if (cond(pt)) continue;
cloud_out->points[j++] = pt;
}
cloud_out->points.resize(j);
cloud_out->height = 1;
cloud_out->width = static_cast<uint32_t>(j);
cloud_out->is_dense = true;
}
template <typename PointT>
void RemoveNaNPoint(const pcl::PointCloud<PointT>& cloud_in,
pcl::PointCloud<PointT>* const cloud_out) {
RemovePointsIf<PointT>(cloud_in, cloud_out,
[](const PointT& pt) { return !IsFinite(pt); });
}
template <typename PointT>
void RemoveClosedPoints(const pcl::PointCloud<PointT>& cloud_in,
pcl::PointCloud<PointT>* const cloud_out,
double min_dist = 0.1) {
RemovePointsIf<PointT>(cloud_in, cloud_out, [&](const PointT& pt) {
return DistanceSqure(pt) < min_dist * min_dist;
});
}
2020-10-13 01:07:59 +08:00
} // namespace oh_my_loam