From 7cf62b3416931c6888097b45e75c49e8aca8835d Mon Sep 17 00:00:00 2001 From: Daniil Date: Wed, 14 Oct 2020 16:52:05 +0300 Subject: [PATCH 1/2] Intensities from Lidar topic into the generated PCD Signed-off-by: Daniil Khaninaev --- .../io/pcd_writing_points_processor.cc | 33 ++++++++++++++----- .../io/pcd_writing_points_processor.h | 1 + 2 files changed, 26 insertions(+), 8 deletions(-) diff --git a/cartographer/io/pcd_writing_points_processor.cc b/cartographer/io/pcd_writing_points_processor.cc index abd2c98119..9a52762163 100644 --- a/cartographer/io/pcd_writing_points_processor.cc +++ b/cartographer/io/pcd_writing_points_processor.cc @@ -32,20 +32,25 @@ namespace { // Writes the PCD header claiming 'num_points' will follow it into // 'output_file'. -void WriteBinaryPcdHeader(const bool has_color, const int64 num_points, - FileWriter* const file_writer) { +void WriteBinaryPcdHeader(const bool has_color, const bool has_intensities, + const int64 num_points, FileWriter* const file_writer) { std::string color_header_field = !has_color ? "" : " rgb"; std::string color_header_type = !has_color ? "" : " U"; std::string color_header_size = !has_color ? "" : " 4"; std::string color_header_count = !has_color ? "" : " 1"; + std::string intensity_header_field = !has_intensities ? "" : " intensity"; + std::string intensity_header_type = !has_intensities ? "" : " F"; + std::string intensity_header_size = !has_intensities ? "" : " 4"; + std::string intensity_header_count = !has_intensities ? "" : " 1"; + std::ostringstream stream; stream << "# generated by Cartographer\n" << "VERSION .7\n" - << "FIELDS x y z" << color_header_field << "\n" - << "SIZE 4 4 4" << color_header_size << "\n" - << "TYPE F F F" << color_header_type << "\n" - << "COUNT 1 1 1" << color_header_count << "\n" + << "FIELDS x y z" << intensity_header_field << color_header_field <<"\n" + << "SIZE 4 4 4" << intensity_header_size << color_header_size << "\n" + << "TYPE F F F" << intensity_header_type << color_header_type << "\n" + << "COUNT 1 1 1" << intensity_header_count << color_header_count << "\n" << "WIDTH " << std::setw(15) << std::setfill('0') << num_points << "\n" << "HEIGHT 1\n" << "VIEWPOINT 0 0 0 1 0 0 0\n" @@ -65,6 +70,12 @@ void WriteBinaryPcdPointCoordinate(const Eigen::Vector3f& point, CHECK(file_writer->Write(buffer, 12)); } +void WriteBinaryPcdIntensity(const float intensity, + FileWriter* const file_writer) { + CHECK(file_writer->Write(reinterpret_cast(&intensity), + sizeof(float))); +} + void WriteBinaryPcdPointColor(const Uint8Color& color, FileWriter* const file_writer) { char buffer[4]; @@ -91,10 +102,11 @@ PcdWritingPointsProcessor::PcdWritingPointsProcessor( : next_(next), num_points_(0), has_colors_(false), + has_intensities_(false), file_writer_(std::move(file_writer)) {} PointsProcessor::FlushResult PcdWritingPointsProcessor::Flush() { - WriteBinaryPcdHeader(has_colors_, num_points_, file_writer_.get()); + WriteBinaryPcdHeader(has_colors_, has_intensities_, num_points_, file_writer_.get()); CHECK(file_writer_->Close()); switch (next_->Flush()) { @@ -116,7 +128,8 @@ void PcdWritingPointsProcessor::Process(std::unique_ptr batch) { if (num_points_ == 0) { has_colors_ = !batch->colors.empty(); - WriteBinaryPcdHeader(has_colors_, 0, file_writer_.get()); + has_intensities_ = !batch->intensities.empty(); + WriteBinaryPcdHeader(has_colors_, has_intensities_, 0, file_writer_.get()); } for (size_t i = 0; i < batch->points.size(); ++i) { WriteBinaryPcdPointCoordinate(batch->points[i].position, @@ -125,6 +138,10 @@ void PcdWritingPointsProcessor::Process(std::unique_ptr batch) { WriteBinaryPcdPointColor(ToUint8Color(batch->colors[i]), file_writer_.get()); } + if (has_intensities_) { + WriteBinaryPcdIntensity(batch->intensities[i], + file_writer_.get()); + } ++num_points_; } next_->Process(std::move(batch)); diff --git a/cartographer/io/pcd_writing_points_processor.h b/cartographer/io/pcd_writing_points_processor.h index 4e209a72f3..3afa729ee3 100644 --- a/cartographer/io/pcd_writing_points_processor.h +++ b/cartographer/io/pcd_writing_points_processor.h @@ -48,6 +48,7 @@ class PcdWritingPointsProcessor : public PointsProcessor { int64 num_points_; bool has_colors_; + bool has_intensities_; std::unique_ptr file_writer_; }; From 6fab93e344715384ae7c5eaeb72725b16c5d0910 Mon Sep 17 00:00:00 2001 From: Daniil Khaninaev Date: Thu, 15 Oct 2020 14:18:26 +0300 Subject: [PATCH 2/2] Update pcd_writing_points_processor.cc 1. Added the keyword const to PCD headers. 2. Changed writing intensity from reinterpret_cast to memcpy due undefined behavior Signed-off-by: Daniil Khaninaev --- .../io/pcd_writing_points_processor.cc | 23 ++++++++++--------- 1 file changed, 12 insertions(+), 11 deletions(-) diff --git a/cartographer/io/pcd_writing_points_processor.cc b/cartographer/io/pcd_writing_points_processor.cc index 9a52762163..a871b6e1b8 100644 --- a/cartographer/io/pcd_writing_points_processor.cc +++ b/cartographer/io/pcd_writing_points_processor.cc @@ -34,15 +34,15 @@ namespace { // 'output_file'. void WriteBinaryPcdHeader(const bool has_color, const bool has_intensities, const int64 num_points, FileWriter* const file_writer) { - std::string color_header_field = !has_color ? "" : " rgb"; - std::string color_header_type = !has_color ? "" : " U"; - std::string color_header_size = !has_color ? "" : " 4"; - std::string color_header_count = !has_color ? "" : " 1"; + const std::string color_header_field = !has_color ? "" : " rgb"; + const std::string color_header_type = !has_color ? "" : " U"; + const std::string color_header_size = !has_color ? "" : " 4"; + const std::string color_header_count = !has_color ? "" : " 1"; - std::string intensity_header_field = !has_intensities ? "" : " intensity"; - std::string intensity_header_type = !has_intensities ? "" : " F"; - std::string intensity_header_size = !has_intensities ? "" : " 4"; - std::string intensity_header_count = !has_intensities ? "" : " 1"; + const std::string intensity_header_field = !has_intensities ? "" : " intensity"; + const std::string intensity_header_type = !has_intensities ? "" : " F"; + const std::string intensity_header_size = !has_intensities ? "" : " 4"; + const std::string intensity_header_count = !has_intensities ? "" : " 1"; std::ostringstream stream; stream << "# generated by Cartographer\n" @@ -71,9 +71,10 @@ void WriteBinaryPcdPointCoordinate(const Eigen::Vector3f& point, } void WriteBinaryPcdIntensity(const float intensity, - FileWriter* const file_writer) { - CHECK(file_writer->Write(reinterpret_cast(&intensity), - sizeof(float))); + FileWriter* const file_writer) { + char buffer[4]; + memcpy(buffer, &intensity, sizeof(float)); + CHECK(file_writer->Write(buffer, 4)); } void WriteBinaryPcdPointColor(const Uint8Color& color,