Adds a HybridGridPoints processor (#323)
parent
cff0c73857
commit
7ce73858ef
|
@ -0,0 +1,67 @@
|
||||||
|
#include "cartographer/io/hybrid_grid_points_processor.h"
|
||||||
|
|
||||||
|
#include <memory>
|
||||||
|
#include <string>
|
||||||
|
|
||||||
|
#include "Eigen/Core"
|
||||||
|
#include "cartographer/common/make_unique.h"
|
||||||
|
#include "cartographer/io/file_writer.h"
|
||||||
|
#include "cartographer/io/points_batch.h"
|
||||||
|
#include "cartographer/io/points_processor.h"
|
||||||
|
#include "cartographer/mapping_3d/hybrid_grid.h"
|
||||||
|
#include "cartographer/mapping_3d/range_data_inserter.h"
|
||||||
|
#include "cartographer/sensor/range_data.h"
|
||||||
|
#include "glog/logging.h"
|
||||||
|
|
||||||
|
namespace cartographer {
|
||||||
|
namespace io {
|
||||||
|
|
||||||
|
HybridGridPointsProcessor::HybridGridPointsProcessor(
|
||||||
|
const double voxel_size,
|
||||||
|
const mapping_3d::proto::RangeDataInserterOptions&
|
||||||
|
range_data_inserter_options,
|
||||||
|
std::unique_ptr<FileWriter> file_writer, PointsProcessor* const next)
|
||||||
|
: next_(next),
|
||||||
|
range_data_inserter_(range_data_inserter_options),
|
||||||
|
hybrid_grid_(voxel_size),
|
||||||
|
file_writer_(std::move(file_writer)) {}
|
||||||
|
|
||||||
|
std::unique_ptr<HybridGridPointsProcessor>
|
||||||
|
HybridGridPointsProcessor::FromDictionary(
|
||||||
|
FileWriterFactory file_writer_factory,
|
||||||
|
common::LuaParameterDictionary* const dictionary,
|
||||||
|
PointsProcessor* const next) {
|
||||||
|
return common::make_unique<HybridGridPointsProcessor>(
|
||||||
|
dictionary->GetDouble("voxel_size"),
|
||||||
|
mapping_3d::CreateRangeDataInserterOptions(
|
||||||
|
dictionary->GetDictionary("range_data_inserter").get()),
|
||||||
|
file_writer_factory(dictionary->GetString("filename")), next);
|
||||||
|
}
|
||||||
|
|
||||||
|
void HybridGridPointsProcessor::Process(std::unique_ptr<PointsBatch> batch) {
|
||||||
|
range_data_inserter_.Insert({batch->origin, batch->points, {}},
|
||||||
|
&hybrid_grid_);
|
||||||
|
next_->Process(std::move(batch));
|
||||||
|
}
|
||||||
|
|
||||||
|
PointsProcessor::FlushResult HybridGridPointsProcessor::Flush() {
|
||||||
|
const mapping_3d::proto::HybridGrid hybrid_grid_proto =
|
||||||
|
mapping_3d::ToProto(hybrid_grid_);
|
||||||
|
string serialized;
|
||||||
|
hybrid_grid_proto.SerializeToString(&serialized);
|
||||||
|
file_writer_->Write(serialized.data(), serialized.size());
|
||||||
|
CHECK(file_writer_->Close());
|
||||||
|
|
||||||
|
switch (next_->Flush()) {
|
||||||
|
case FlushResult::kRestartStream:
|
||||||
|
LOG(FATAL) << "Hybrid grid generation must be configured to occur after "
|
||||||
|
"any stages that require multiple passes.";
|
||||||
|
|
||||||
|
case FlushResult::kFinished:
|
||||||
|
return FlushResult::kFinished;
|
||||||
|
}
|
||||||
|
LOG(FATAL) << "Failed to receive FlushResult::kFinished";
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace io
|
||||||
|
} // namespace cartographer
|
|
@ -0,0 +1,55 @@
|
||||||
|
#ifndef CARTOGRAPHER_IO_HYBRID_GRID_POINTS_PROCESSOR_H_
|
||||||
|
#define CARTOGRAPHER_IO_HYBRID_GRID_POINTS_PROCESSOR_H_
|
||||||
|
|
||||||
|
// Library used for inserting range data points into a hybrid grid.
|
||||||
|
|
||||||
|
#include <memory>
|
||||||
|
#include <string>
|
||||||
|
|
||||||
|
#include "cartographer/io/file_writer.h"
|
||||||
|
#include "cartographer/io/points_batch.h"
|
||||||
|
#include "cartographer/io/points_processor.h"
|
||||||
|
#include "cartographer/mapping_3d/hybrid_grid.h"
|
||||||
|
#include "cartographer/mapping_3d/proto/range_data_inserter_options.pb.h"
|
||||||
|
#include "cartographer/mapping_3d/range_data_inserter.h"
|
||||||
|
|
||||||
|
namespace cartographer {
|
||||||
|
namespace io {
|
||||||
|
|
||||||
|
// Creates a hybrid grid of the points with voxels being 'voxel_size'
|
||||||
|
// big. 'range_data_inserter' options are used to configure the range
|
||||||
|
// data ray tracing through the hybrid grid.
|
||||||
|
class HybridGridPointsProcessor : public PointsProcessor {
|
||||||
|
public:
|
||||||
|
constexpr static const char* kConfigurationFileActionName =
|
||||||
|
"write_hybrid_grid";
|
||||||
|
HybridGridPointsProcessor(double voxel_size,
|
||||||
|
const mapping_3d::proto::RangeDataInserterOptions&
|
||||||
|
range_data_inserter_options,
|
||||||
|
std::unique_ptr<FileWriter> file_writer,
|
||||||
|
PointsProcessor* next);
|
||||||
|
HybridGridPointsProcessor(const HybridGridPointsProcessor&) = delete;
|
||||||
|
HybridGridPointsProcessor& operator=(const HybridGridPointsProcessor&) =
|
||||||
|
delete;
|
||||||
|
|
||||||
|
static std::unique_ptr<HybridGridPointsProcessor> FromDictionary(
|
||||||
|
FileWriterFactory file_writer_factory,
|
||||||
|
common::LuaParameterDictionary* dictionary, PointsProcessor* next);
|
||||||
|
|
||||||
|
~HybridGridPointsProcessor() override {}
|
||||||
|
|
||||||
|
void Process(std::unique_ptr<PointsBatch> batch) override;
|
||||||
|
FlushResult Flush() override;
|
||||||
|
|
||||||
|
private:
|
||||||
|
PointsProcessor* const next_;
|
||||||
|
|
||||||
|
mapping_3d::RangeDataInserter range_data_inserter_;
|
||||||
|
mapping_3d::HybridGrid hybrid_grid_;
|
||||||
|
std::unique_ptr<FileWriter> file_writer_;
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace io
|
||||||
|
} // namespace cartographer
|
||||||
|
|
||||||
|
#endif // CARTOGRAPHER_IO_HYBRID_GRID_POINTS_PROCESSOR_H_
|
|
@ -20,6 +20,7 @@
|
||||||
#include "cartographer/io/coloring_points_processor.h"
|
#include "cartographer/io/coloring_points_processor.h"
|
||||||
#include "cartographer/io/counting_points_processor.h"
|
#include "cartographer/io/counting_points_processor.h"
|
||||||
#include "cartographer/io/fixed_ratio_sampling_points_processor.h"
|
#include "cartographer/io/fixed_ratio_sampling_points_processor.h"
|
||||||
|
#include "cartographer/io/hybrid_grid_points_processor.h"
|
||||||
#include "cartographer/io/intensity_to_color_points_processor.h"
|
#include "cartographer/io/intensity_to_color_points_processor.h"
|
||||||
#include "cartographer/io/min_max_range_filtering_points_processor.h"
|
#include "cartographer/io/min_max_range_filtering_points_processor.h"
|
||||||
#include "cartographer/io/null_points_processor.h"
|
#include "cartographer/io/null_points_processor.h"
|
||||||
|
@ -74,6 +75,8 @@ void RegisterBuiltInPointsProcessors(
|
||||||
file_writer_factory, builder);
|
file_writer_factory, builder);
|
||||||
RegisterFileWritingPointsProcessor<XyzWriterPointsProcessor>(
|
RegisterFileWritingPointsProcessor<XyzWriterPointsProcessor>(
|
||||||
file_writer_factory, builder);
|
file_writer_factory, builder);
|
||||||
|
RegisterFileWritingPointsProcessor<HybridGridPointsProcessor>(
|
||||||
|
file_writer_factory, builder);
|
||||||
|
|
||||||
// X-Ray is an odd ball since it requires the trajectory to figure out the
|
// X-Ray is an odd ball since it requires the trajectory to figure out the
|
||||||
// different building levels we walked on to separate the images.
|
// different building levels we walked on to separate the images.
|
||||||
|
|
Loading…
Reference in New Issue