/* * Copyright 2016 The Cartographer Authors * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #include "cartographer/io/points_processor_pipeline_builder.h" #include "absl/memory/memory.h" #include "cartographer/io/coloring_points_processor.h" #include "cartographer/io/counting_points_processor.h" #include "cartographer/io/fixed_ratio_sampling_points_processor.h" #include "cartographer/io/frame_id_filtering_points_processor.h" #include "cartographer/io/hybrid_grid_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/null_points_processor.h" #include "cartographer/io/outlier_removing_points_processor.h" #include "cartographer/io/pcd_writing_points_processor.h" #include "cartographer/io/ply_writing_points_processor.h" #include "cartographer/io/probability_grid_points_processor.h" #include "cartographer/io/vertical_range_filtering_points_processor.h" #include "cartographer/io/xray_points_processor.h" #include "cartographer/io/xyz_writing_points_processor.h" #include "cartographer/mapping/proto/trajectory.pb.h" namespace cartographer { namespace io { template void RegisterPlainPointsProcessor( PointsProcessorPipelineBuilder* const builder) { builder->Register( PointsProcessorType::kConfigurationFileActionName, [](common::LuaParameterDictionary* const dictionary, PointsProcessor* const next) -> std::unique_ptr { return PointsProcessorType::FromDictionary(dictionary, next); }); } template void RegisterFileWritingPointsProcessor( const FileWriterFactory& file_writer_factory, PointsProcessorPipelineBuilder* const builder) { builder->Register( PointsProcessorType::kConfigurationFileActionName, [file_writer_factory]( common::LuaParameterDictionary* const dictionary, PointsProcessor* const next) -> std::unique_ptr { return PointsProcessorType::FromDictionary(file_writer_factory, dictionary, next); }); } template void RegisterFileWritingPointsProcessorWithTrajectories( const std::vector& trajectories, const FileWriterFactory& file_writer_factory, PointsProcessorPipelineBuilder* const builder) { builder->Register( PointsProcessorType::kConfigurationFileActionName, [&trajectories, file_writer_factory]( common::LuaParameterDictionary* const dictionary, PointsProcessor* const next) -> std::unique_ptr { return PointsProcessorType::FromDictionary( trajectories, file_writer_factory, dictionary, next); }); } void RegisterBuiltInPointsProcessors( const std::vector& trajectories, const FileWriterFactory& file_writer_factory, PointsProcessorPipelineBuilder* builder) { RegisterPlainPointsProcessor(builder); RegisterPlainPointsProcessor(builder); RegisterPlainPointsProcessor(builder); RegisterPlainPointsProcessor(builder); RegisterPlainPointsProcessor(builder); RegisterPlainPointsProcessor(builder); RegisterPlainPointsProcessor(builder); RegisterPlainPointsProcessor(builder); RegisterFileWritingPointsProcessor( file_writer_factory, builder); RegisterFileWritingPointsProcessor( file_writer_factory, builder); RegisterFileWritingPointsProcessor( file_writer_factory, builder); RegisterFileWritingPointsProcessor( file_writer_factory, builder); RegisterFileWritingPointsProcessorWithTrajectories( trajectories, file_writer_factory, builder); RegisterFileWritingPointsProcessorWithTrajectories< ProbabilityGridPointsProcessor>(trajectories, file_writer_factory, builder); } void PointsProcessorPipelineBuilder::Register(const std::string& name, FactoryFunction factory) { CHECK(factories_.count(name) == 0) << "A points processor named '" << name << "' has already been registered."; factories_[name] = std::move(factory); } PointsProcessorPipelineBuilder::PointsProcessorPipelineBuilder() {} std::vector> PointsProcessorPipelineBuilder::CreatePipeline( common::LuaParameterDictionary* const dictionary) const { std::vector> pipeline; // The last consumer in the pipeline must exist, so that the one created after // it (and being before it in the pipeline) has a valid 'next' to point to. // The last consumer will just drop all points. pipeline.emplace_back(absl::make_unique()); std::vector> configurations = dictionary->GetArrayValuesAsDictionaries(); // We construct the pipeline starting at the back. for (auto it = configurations.rbegin(); it != configurations.rend(); it++) { const std::string action = (*it)->GetString("action"); auto factory_it = factories_.find(action); CHECK(factory_it != factories_.end()) << "Unknown action '" << action << "'. Did you register the correspoinding PointsProcessor?"; pipeline.push_back(factory_it->second(it->get(), pipeline.back().get())); } return pipeline; } } // namespace io } // namespace cartographer