Skip to content

Commit

Permalink
Clean up use of MapBuilderInterface. (#1776)
Browse files Browse the repository at this point in the history
Moves options next to the interface like we do for other interfaces.
Adds a factory function to remove the need for direct use of MapBuilder.

Signed-off-by: Wolfgang Hess <whess@lyft.com>
  • Loading branch information
wohe committed Nov 6, 2020
1 parent 38dcf65 commit b1ce24d
Show file tree
Hide file tree
Showing 11 changed files with 64 additions and 31 deletions.
9 changes: 5 additions & 4 deletions cartographer/cloud/internal/client_server_test.cc
Original file line number Diff line number Diff line change
Expand Up @@ -29,12 +29,13 @@
#include "cartographer/mapping/internal/testing/mock_trajectory_builder.h"
#include "cartographer/mapping/internal/testing/test_helpers.h"
#include "cartographer/mapping/local_slam_result_data.h"
#include "cartographer/mapping/map_builder.h"
#include "glog/logging.h"
#include "gmock/gmock.h"
#include "gtest/gtest.h"

using ::cartographer::io::testing::ProtoReaderFromStrings;
using ::cartographer::mapping::MapBuilder;
using ::cartographer::mapping::CreateMapBuilder;
using ::cartographer::mapping::MapBuilderInterface;
using ::cartographer::mapping::PoseGraphInterface;
using ::cartographer::mapping::TrajectoryBuilderInterface;
Expand Down Expand Up @@ -139,15 +140,15 @@ class ClientServerTestBase : public T {
}

void InitializeRealServer() {
auto map_builder = absl::make_unique<MapBuilder>(
map_builder_server_options_.map_builder_options());
auto map_builder =
CreateMapBuilder(map_builder_server_options_.map_builder_options());
server_ = absl::make_unique<MapBuilderServer>(map_builder_server_options_,
std::move(map_builder));
EXPECT_TRUE(server_ != nullptr);
}

void InitializeRealUploadingServer() {
auto map_builder = absl::make_unique<MapBuilder>(
auto map_builder = CreateMapBuilder(
uploading_map_builder_server_options_.map_builder_options());
uploading_server_ = absl::make_unique<MapBuilderServer>(
uploading_map_builder_server_options_, std::move(map_builder));
Expand Down
1 change: 0 additions & 1 deletion cartographer/cloud/internal/map_builder_server.h
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,6 @@
#include "cartographer/mapping/3d/submap_3d.h"
#include "cartographer/mapping/internal/submap_controller.h"
#include "cartographer/mapping/local_slam_result_data.h"
#include "cartographer/mapping/map_builder.h"
#include "cartographer/mapping/trajectory_builder_interface.h"
#include "cartographer/metrics/family_factory.h"
#include "cartographer/sensor/internal/dispatchable.h"
Expand Down
2 changes: 1 addition & 1 deletion cartographer/cloud/map_builder_server_main.cc
Original file line number Diff line number Diff line change
Expand Up @@ -50,7 +50,7 @@ void Run(const std::string& configuration_directory,
proto::MapBuilderServerOptions map_builder_server_options =
LoadMapBuilderServerOptions(configuration_directory,
configuration_basename);
auto map_builder = absl::make_unique<mapping::MapBuilder>(
auto map_builder = mapping::CreateMapBuilder(
map_builder_server_options.map_builder_options());
std::unique_ptr<MapBuilderServerInterface> map_builder_server =
CreateMapBuilderServer(map_builder_server_options,
Expand Down
2 changes: 1 addition & 1 deletion cartographer/cloud/map_builder_server_options.cc
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@

#include "absl/memory/memory.h"
#include "cartographer/common/configuration_file_resolver.h"
#include "cartographer/mapping/map_builder.h"
#include "cartographer/mapping/map_builder_interface.h"

namespace cartographer {
namespace cloud {
Expand Down
2 changes: 1 addition & 1 deletion cartographer/common/configuration_files_test.cc
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@
#include "cartographer/common/config.h"
#include "cartographer/common/configuration_file_resolver.h"
#include "cartographer/common/lua_parameter_dictionary.h"
#include "cartographer/mapping/map_builder.h"
#include "cartographer/mapping/map_builder_interface.h"
#include "gtest/gtest.h"

namespace cartographer {
Expand Down
1 change: 0 additions & 1 deletion cartographer/io/serialization_format_migration.cc
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,6 @@
#include "cartographer/mapping/id.h"
#include "cartographer/mapping/internal/3d/pose_graph_3d.h"
#include "cartographer/mapping/internal/3d/scan_matching/rotational_scan_matcher.h"
#include "cartographer/mapping/map_builder.h"
#include "cartographer/mapping/map_builder_interface.h"
#include "cartographer/mapping/pose_graph.h"
#include "cartographer/mapping/probability_values.h"
Expand Down
23 changes: 5 additions & 18 deletions cartographer/mapping/map_builder.cc
Original file line number Diff line number Diff line change
Expand Up @@ -74,24 +74,6 @@ void MaybeAddPureLocalizationTrimmer(

} // namespace

proto::MapBuilderOptions CreateMapBuilderOptions(
common::LuaParameterDictionary* const parameter_dictionary) {
proto::MapBuilderOptions options;
options.set_use_trajectory_builder_2d(
parameter_dictionary->GetBool("use_trajectory_builder_2d"));
options.set_use_trajectory_builder_3d(
parameter_dictionary->GetBool("use_trajectory_builder_3d"));
options.set_num_background_threads(
parameter_dictionary->GetNonNegativeInt("num_background_threads"));
options.set_collate_by_trajectory(
parameter_dictionary->GetBool("collate_by_trajectory"));
*options.mutable_pose_graph_options() = CreatePoseGraphOptions(
parameter_dictionary->GetDictionary("pose_graph").get());
CHECK_NE(options.use_trajectory_builder_2d(),
options.use_trajectory_builder_3d());
return options;
}

MapBuilder::MapBuilder(const proto::MapBuilderOptions& options)
: options_(options), thread_pool_(options.num_background_threads()) {
CHECK(options.use_trajectory_builder_2d() ^
Expand Down Expand Up @@ -414,5 +396,10 @@ std::map<int, int> MapBuilder::LoadStateFromFile(
return LoadState(&stream, load_frozen_state);
}

std::unique_ptr<MapBuilderInterface> CreateMapBuilder(
const proto::MapBuilderOptions& options) {
return absl::make_unique<MapBuilder>(options);
}

} // namespace mapping
} // namespace cartographer
6 changes: 3 additions & 3 deletions cartographer/mapping/map_builder.h
Original file line number Diff line number Diff line change
Expand Up @@ -28,9 +28,6 @@
namespace cartographer {
namespace mapping {

proto::MapBuilderOptions CreateMapBuilderOptions(
common::LuaParameterDictionary *const parameter_dictionary);

// Wires up the complete SLAM stack with TrajectoryBuilders (for local submaps)
// and a PoseGraph for loop closure.
class MapBuilder : public MapBuilderInterface {
Expand Down Expand Up @@ -98,6 +95,9 @@ class MapBuilder : public MapBuilderInterface {
all_trajectory_builder_options_;
};

std::unique_ptr<MapBuilderInterface> CreateMapBuilder(
const proto::MapBuilderOptions& options);

} // namespace mapping
} // namespace cartographer

Expand Down
43 changes: 43 additions & 0 deletions cartographer/mapping/map_builder_interface.cc
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
/*
* 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/mapping/map_builder_interface.h"

#include "cartographer/mapping/pose_graph.h"

namespace cartographer {
namespace mapping {

proto::MapBuilderOptions CreateMapBuilderOptions(
common::LuaParameterDictionary* const parameter_dictionary) {
proto::MapBuilderOptions options;
options.set_use_trajectory_builder_2d(
parameter_dictionary->GetBool("use_trajectory_builder_2d"));
options.set_use_trajectory_builder_3d(
parameter_dictionary->GetBool("use_trajectory_builder_3d"));
options.set_num_background_threads(
parameter_dictionary->GetNonNegativeInt("num_background_threads"));
options.set_collate_by_trajectory(
parameter_dictionary->GetBool("collate_by_trajectory"));
*options.mutable_pose_graph_options() = CreatePoseGraphOptions(
parameter_dictionary->GetDictionary("pose_graph").get());
CHECK_NE(options.use_trajectory_builder_2d(),
options.use_trajectory_builder_3d());
return options;
}

} // namespace mapping
} // namespace cartographer
4 changes: 4 additions & 0 deletions cartographer/mapping/map_builder_interface.h
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@
#include "cartographer/io/proto_stream_interface.h"
#include "cartographer/mapping/id.h"
#include "cartographer/mapping/pose_graph_interface.h"
#include "cartographer/mapping/proto/map_builder_options.pb.h"
#include "cartographer/mapping/proto/submap_visualization.pb.h"
#include "cartographer/mapping/proto/trajectory_builder_options.pb.h"
#include "cartographer/mapping/submaps.h"
Expand All @@ -35,6 +36,9 @@
namespace cartographer {
namespace mapping {

proto::MapBuilderOptions CreateMapBuilderOptions(
common::LuaParameterDictionary* const parameter_dictionary);

// This interface is used for both library and RPC implementations.
// Implementations wire up the complete SLAM stack.
class MapBuilderInterface {
Expand Down
2 changes: 1 addition & 1 deletion cartographer/mapping/map_builder_test.cc
Original file line number Diff line number Diff line change
Expand Up @@ -64,7 +64,7 @@ class MapBuilderTestBase : public T {
}

void BuildMapBuilder() {
map_builder_ = absl::make_unique<MapBuilder>(map_builder_options_);
map_builder_ = CreateMapBuilder(map_builder_options_);
}

void SetOptionsTo3D() {
Expand Down

0 comments on commit b1ce24d

Please sign in to comment.