Enable loading unfrozen state (#891)

Enable loading unfrozen state
master
Juraj Oršulić 2018-02-27 20:38:57 +01:00 committed by Christoph Schütte
parent 29875117b3
commit 32b8bd3581
16 changed files with 128 additions and 85 deletions

View File

@ -30,8 +30,8 @@ bool ForwardingProtoStreamWriter::Close() { return writer_callback_(nullptr); }
bool InMemoryProtoStreamReader::ReadProto(google::protobuf::Message* proto) { bool InMemoryProtoStreamReader::ReadProto(google::protobuf::Message* proto) {
if (eof()) return false; if (eof()) return false;
proto->CopyFrom(*map_chunks_.front()); proto->CopyFrom(*state_chunks_.front());
map_chunks_.pop(); state_chunks_.pop();
return true; return true;
} }

View File

@ -51,8 +51,8 @@ class InMemoryProtoStreamReader
: public cartographer::io::ProtoStreamReaderInterface { : public cartographer::io::ProtoStreamReaderInterface {
public: public:
explicit InMemoryProtoStreamReader( explicit InMemoryProtoStreamReader(
std::queue<std::unique_ptr<google::protobuf::Message>>&& map_chunks) std::queue<std::unique_ptr<google::protobuf::Message>>&& state_chunks)
: map_chunks_(std::move(map_chunks)){}; : state_chunks_(std::move(state_chunks)){};
InMemoryProtoStreamReader() = default; InMemoryProtoStreamReader() = default;
~InMemoryProtoStreamReader() = default; ~InMemoryProtoStreamReader() = default;
@ -62,14 +62,14 @@ class InMemoryProtoStreamReader
template <typename MessageType> template <typename MessageType>
void AddProto(const MessageType& proto) { void AddProto(const MessageType& proto) {
map_chunks_.push(common::make_unique<MessageType>(proto)); state_chunks_.push(common::make_unique<MessageType>(proto));
} }
bool ReadProto(google::protobuf::Message* proto) override; bool ReadProto(google::protobuf::Message* proto) override;
bool eof() const override { return map_chunks_.empty(); } bool eof() const override { return state_chunks_.empty(); }
private: private:
std::queue<std::unique_ptr<google::protobuf::Message>> map_chunks_; std::queue<std::unique_ptr<google::protobuf::Message>> state_chunks_;
}; };
} // namespace io } // namespace io

View File

@ -439,7 +439,6 @@ void PoseGraph2D::AddSubmapFromProto(
submap_id, submap_id,
pose_graph::OptimizationProblem2D::SubmapData{global_submap_pose_2d}); pose_graph::OptimizationProblem2D::SubmapData{global_submap_pose_2d});
AddWorkItem([this, submap_id, global_submap_pose_2d]() REQUIRES(mutex_) { AddWorkItem([this, submap_id, global_submap_pose_2d]() REQUIRES(mutex_) {
CHECK_EQ(frozen_trajectories_.count(submap_id.trajectory_id), 1);
submap_data_.at(submap_id).state = SubmapState::kFinished; submap_data_.at(submap_id).state = SubmapState::kFinished;
optimization_problem_.InsertSubmap(submap_id, global_submap_pose_2d); optimization_problem_.InsertSubmap(submap_id, global_submap_pose_2d);
}); });
@ -457,7 +456,6 @@ void PoseGraph2D::AddNodeFromProto(const transform::Rigid3d& global_pose,
trajectory_nodes_.Insert(node_id, TrajectoryNode{constant_data, global_pose}); trajectory_nodes_.Insert(node_id, TrajectoryNode{constant_data, global_pose});
AddWorkItem([this, node_id, global_pose]() REQUIRES(mutex_) { AddWorkItem([this, node_id, global_pose]() REQUIRES(mutex_) {
CHECK_EQ(frozen_trajectories_.count(node_id.trajectory_id), 1);
const auto& constant_data = trajectory_nodes_.at(node_id).constant_data; const auto& constant_data = trajectory_nodes_.at(node_id).constant_data;
const auto gravity_alignment_inverse = transform::Rigid3d::Rotation( const auto gravity_alignment_inverse = transform::Rigid3d::Rotation(
constant_data->gravity_alignment.inverse()); constant_data->gravity_alignment.inverse());

View File

@ -455,7 +455,6 @@ void PoseGraph3D::AddSubmapFromProto(
submap_id, submap_id,
pose_graph::OptimizationProblem3D::SubmapData{global_submap_pose}); pose_graph::OptimizationProblem3D::SubmapData{global_submap_pose});
AddWorkItem([this, submap_id, global_submap_pose]() REQUIRES(mutex_) { AddWorkItem([this, submap_id, global_submap_pose]() REQUIRES(mutex_) {
CHECK_EQ(frozen_trajectories_.count(submap_id.trajectory_id), 1);
submap_data_.at(submap_id).state = SubmapState::kFinished; submap_data_.at(submap_id).state = SubmapState::kFinished;
optimization_problem_.InsertSubmap(submap_id, global_submap_pose); optimization_problem_.InsertSubmap(submap_id, global_submap_pose);
}); });
@ -473,7 +472,6 @@ void PoseGraph3D::AddNodeFromProto(const transform::Rigid3d& global_pose,
trajectory_nodes_.Insert(node_id, TrajectoryNode{constant_data, global_pose}); trajectory_nodes_.Insert(node_id, TrajectoryNode{constant_data, global_pose});
AddWorkItem([this, node_id, global_pose]() REQUIRES(mutex_) { AddWorkItem([this, node_id, global_pose]() REQUIRES(mutex_) {
CHECK_EQ(frozen_trajectories_.count(node_id.trajectory_id), 1);
const auto& constant_data = trajectory_nodes_.at(node_id).constant_data; const auto& constant_data = trajectory_nodes_.at(node_id).constant_data;
optimization_problem_.InsertTrajectoryNode( optimization_problem_.InsertTrajectoryNode(
node_id, constant_data->time, constant_data->local_pose, global_pose); node_id, constant_data->time, constant_data->local_pose, global_pose);

View File

@ -276,9 +276,11 @@ void MapBuilder::SerializeState(io::ProtoStreamWriterInterface* const writer) {
writer->WriteProto(proto); writer->WriteProto(proto);
} }
} }
// TODO(pifon2a, ojura): serialize landmarks
} }
void MapBuilder::LoadMap(io::ProtoStreamReaderInterface* const reader) { void MapBuilder::LoadState(io::ProtoStreamReaderInterface* const reader,
bool load_frozen_state) {
proto::PoseGraph pose_graph_proto; proto::PoseGraph pose_graph_proto;
CHECK(reader->ReadProto(&pose_graph_proto)); CHECK(reader->ReadProto(&pose_graph_proto));
proto::AllTrajectoryBuilderOptions all_builder_options_proto; proto::AllTrajectoryBuilderOptions all_builder_options_proto;
@ -298,8 +300,18 @@ void MapBuilder::LoadMap(io::ProtoStreamReaderInterface* const reader) {
.second) .second)
<< "Duplicate trajectory ID: " << trajectory_proto.trajectory_id(); << "Duplicate trajectory ID: " << trajectory_proto.trajectory_id();
trajectory_proto.set_trajectory_id(new_trajectory_id); trajectory_proto.set_trajectory_id(new_trajectory_id);
if (load_frozen_state) {
pose_graph_->FreezeTrajectory(new_trajectory_id); pose_graph_->FreezeTrajectory(new_trajectory_id);
} }
}
// Apply the calculated remapping to constraints in the pose graph proto.
for (auto& constraint_proto : *pose_graph_proto.mutable_constraint()) {
constraint_proto.mutable_submap_id()->set_trajectory_id(
trajectory_remapping.at(constraint_proto.submap_id().trajectory_id()));
constraint_proto.mutable_node_id()->set_trajectory_id(
trajectory_remapping.at(constraint_proto.node_id().trajectory_id()));
}
MapById<SubmapId, transform::Rigid3d> submap_poses; MapById<SubmapId, transform::Rigid3d> submap_poses;
for (const proto::Trajectory& trajectory_proto : for (const proto::Trajectory& trajectory_proto :
@ -348,24 +360,49 @@ void MapBuilder::LoadMap(io::ProtoStreamReaderInterface* const reader) {
trajectory_remapping.at(proto.trajectory_data().trajectory_id())); trajectory_remapping.at(proto.trajectory_data().trajectory_id()));
pose_graph_->SetTrajectoryDataFromProto(proto.trajectory_data()); pose_graph_->SetTrajectoryDataFromProto(proto.trajectory_data());
} }
// TODO(ojura): Deserialize IMU, odometry and fixed frame pose data when if (!load_frozen_state) {
// loading unfrozen trajectories. if (proto.has_imu_data()) {
pose_graph_->AddImuData(
trajectory_remapping.at(proto.imu_data().trajectory_id()),
sensor::FromProto(proto.imu_data().imu_data()));
}
if (proto.has_odometry_data()) {
pose_graph_->AddOdometryData(
trajectory_remapping.at(proto.odometry_data().trajectory_id()),
sensor::FromProto(proto.odometry_data().odometry_data()));
}
if (proto.has_fixed_frame_pose_data()) {
pose_graph_->AddFixedFramePoseData(
trajectory_remapping.at(
proto.fixed_frame_pose_data().trajectory_id()),
sensor::FromProto(
proto.fixed_frame_pose_data().fixed_frame_pose_data()));
}
// TODO(pifon2a, ojura): deserialize landmarks
}
} }
if (load_frozen_state) {
// Add information about which nodes belong to which submap. // Add information about which nodes belong to which submap.
// Required for 3D pure localization.
for (const proto::PoseGraph::Constraint& constraint_proto : for (const proto::PoseGraph::Constraint& constraint_proto :
pose_graph_proto.constraint()) { pose_graph_proto.constraint()) {
if (constraint_proto.tag() != if (constraint_proto.tag() !=
mapping::proto::PoseGraph::Constraint::INTRA_SUBMAP) { mapping::proto::PoseGraph::Constraint::INTRA_SUBMAP) {
continue; continue;
} }
const NodeId node_id{ pose_graph_->AddNodeToSubmap(
trajectory_remapping.at(constraint_proto.node_id().trajectory_id()), NodeId{constraint_proto.node_id().trajectory_id(),
constraint_proto.node_id().node_index()}; constraint_proto.node_id().node_index()},
const SubmapId submap_id{ SubmapId{constraint_proto.submap_id().trajectory_id(),
trajectory_remapping.at(constraint_proto.submap_id().trajectory_id()), constraint_proto.submap_id().submap_index()});
constraint_proto.submap_id().submap_index()}; }
pose_graph_->AddNodeToSubmap(node_id, submap_id); } else {
// When loading unfrozen trajectories, 'AddSerializedConstraints' will
// take care of adding information about which nodes belong to which
// submap.
pose_graph_->AddSerializedConstraints(
FromProto(pose_graph_proto.constraint()));
} }
CHECK(reader->eof()); CHECK(reader->eof());
} }

View File

@ -63,7 +63,8 @@ class MapBuilder : public MapBuilderInterface {
void SerializeState(io::ProtoStreamWriterInterface* writer) override; void SerializeState(io::ProtoStreamWriterInterface* writer) override;
void LoadMap(io::ProtoStreamReaderInterface* reader) override; void LoadState(io::ProtoStreamReaderInterface* reader,
bool load_frozen_state) override;
int num_trajectory_builders() const override; int num_trajectory_builders() const override;

View File

@ -80,8 +80,9 @@ class MapBuilderInterface {
// Serializes the current state to a proto stream. // Serializes the current state to a proto stream.
virtual void SerializeState(io::ProtoStreamWriterInterface* writer) = 0; virtual void SerializeState(io::ProtoStreamWriterInterface* writer) = 0;
// Loads submaps from a proto stream into a new frozen trajectory. // Loads the SLAM state from a proto stream.
virtual void LoadMap(io::ProtoStreamReaderInterface* reader) = 0; virtual void LoadState(io::ProtoStreamReaderInterface* reader,
bool load_frozen_state) = 0;
virtual int num_trajectory_builders() const = 0; virtual int num_trajectory_builders() const = 0;

View File

@ -14,7 +14,7 @@
* limitations under the License. * limitations under the License.
*/ */
#include "cartographer_grpc/handlers/load_map_handler.h" #include "cartographer_grpc/handlers/load_state_handler.h"
#include "cartographer/common/make_unique.h" #include "cartographer/common/make_unique.h"
#include "cartographer/io/in_memory_proto_stream.h" #include "cartographer/io/in_memory_proto_stream.h"
@ -26,24 +26,25 @@
namespace cartographer_grpc { namespace cartographer_grpc {
namespace handlers { namespace handlers {
void LoadMapHandler::OnRequest(const proto::LoadMapRequest& request) { void LoadStateHandler::OnRequest(const proto::LoadStateRequest& request) {
switch (request.map_chunk_case()) { switch (request.state_chunk_case()) {
case proto::LoadMapRequest::kPoseGraph: case proto::LoadStateRequest::kPoseGraph:
reader_.AddProto(request.pose_graph()); reader_.AddProto(request.pose_graph());
break; break;
case proto::LoadMapRequest::kAllTrajectoryBuilderOptions: case proto::LoadStateRequest::kAllTrajectoryBuilderOptions:
reader_.AddProto(request.all_trajectory_builder_options()); reader_.AddProto(request.all_trajectory_builder_options());
break; break;
case proto::LoadMapRequest::kSerializedData: case proto::LoadStateRequest::kSerializedData:
reader_.AddProto(request.serialized_data()); reader_.AddProto(request.serialized_data());
break; break;
default: default:
LOG(FATAL) << "Unhandled proto::LoadMapRequest case."; LOG(FATAL) << "Unhandled proto::LoadStateRequest case.";
} }
} }
void LoadMapHandler::OnReadsDone() { void LoadStateHandler::OnReadsDone() {
GetContext<MapBuilderContextInterface>()->map_builder().LoadMap(&reader_); GetContext<MapBuilderContextInterface>()->map_builder().LoadState(&reader_,
true);
Send(cartographer::common::make_unique<google::protobuf::Empty>()); Send(cartographer::common::make_unique<google::protobuf::Empty>());
} }

View File

@ -14,8 +14,8 @@
* limitations under the License. * limitations under the License.
*/ */
#ifndef CARTOGRAPHER_GRPC_HANDLERS_LOAD_MAP_HANDLER_H #ifndef CARTOGRAPHER_GRPC_HANDLERS_LOAD_STATE_HANDLER_H
#define CARTOGRAPHER_GRPC_HANDLERS_LOAD_MAP_HANDLER_H #define CARTOGRAPHER_GRPC_HANDLERS_LOAD_STATE_HANDLER_H
#include "cartographer/io/in_memory_proto_stream.h" #include "cartographer/io/in_memory_proto_stream.h"
#include "cartographer_grpc/framework/rpc_handler.h" #include "cartographer_grpc/framework/rpc_handler.h"
@ -25,14 +25,14 @@
namespace cartographer_grpc { namespace cartographer_grpc {
namespace handlers { namespace handlers {
class LoadMapHandler class LoadStateHandler
: public framework::RpcHandler<framework::Stream<proto::LoadMapRequest>, : public framework::RpcHandler<framework::Stream<proto::LoadStateRequest>,
google::protobuf::Empty> { google::protobuf::Empty> {
public: public:
std::string method_name() const override { std::string method_name() const override {
return "/cartographer_grpc.proto.MapBuilderService/LoadMap"; return "/cartographer_grpc.proto.MapBuilderService/LoadState";
} }
void OnRequest(const proto::LoadMapRequest& request) override; void OnRequest(const proto::LoadStateRequest& request) override;
void OnReadsDone() override; void OnReadsDone() override;
private: private:
@ -42,4 +42,4 @@ class LoadMapHandler
} // namespace handlers } // namespace handlers
} // namespace cartographer_grpc } // namespace cartographer_grpc
#endif // CARTOGRAPHER_GRPC_HANDLERS_LOAD_MAP_HANDLER_H #endif // CARTOGRAPHER_GRPC_HANDLERS_LOAD_STATE_HANDLER_H

View File

@ -14,7 +14,7 @@
* limitations under the License. * limitations under the License.
*/ */
#include "cartographer_grpc/handlers/write_map_handler.h" #include "cartographer_grpc/handlers/write_state_handler.h"
#include "cartographer/common/make_unique.h" #include "cartographer/common/make_unique.h"
#include "cartographer/io/in_memory_proto_stream.h" #include "cartographer/io/in_memory_proto_stream.h"
@ -26,7 +26,7 @@
namespace cartographer_grpc { namespace cartographer_grpc {
namespace handlers { namespace handlers {
void WriteMapHandler::OnRequest(const google::protobuf::Empty& request) { void WriteStateHandler::OnRequest(const google::protobuf::Empty& request) {
auto writer = GetWriter(); auto writer = GetWriter();
cartographer::io::ForwardingProtoStreamWriter proto_stream_writer( cartographer::io::ForwardingProtoStreamWriter proto_stream_writer(
[writer](const google::protobuf::Message* proto) { [writer](const google::protobuf::Message* proto) {
@ -36,7 +36,7 @@ void WriteMapHandler::OnRequest(const google::protobuf::Empty& request) {
} }
auto response = auto response =
cartographer::common::make_unique<proto::WriteMapResponse>(); cartographer::common::make_unique<proto::WriteStateResponse>();
if (proto->GetTypeName() == "cartographer.mapping.proto.PoseGraph") { if (proto->GetTypeName() == "cartographer.mapping.proto.PoseGraph") {
response->mutable_pose_graph()->CopyFrom(*proto); response->mutable_pose_graph()->CopyFrom(*proto);
} else if (proto->GetTypeName() == } else if (proto->GetTypeName() ==

View File

@ -14,8 +14,8 @@
* limitations under the License. * limitations under the License.
*/ */
#ifndef CARTOGRAPHER_GRPC_HANDLERS_WRITE_MAP_HANDLER_H #ifndef CARTOGRAPHER_GRPC_HANDLERS_WRITE_STATE_HANDLER_H
#define CARTOGRAPHER_GRPC_HANDLERS_WRITE_MAP_HANDLER_H #define CARTOGRAPHER_GRPC_HANDLERS_WRITE_STATE_HANDLER_H
#include "cartographer_grpc/framework/rpc_handler.h" #include "cartographer_grpc/framework/rpc_handler.h"
#include "cartographer_grpc/proto/map_builder_service.pb.h" #include "cartographer_grpc/proto/map_builder_service.pb.h"
@ -24,12 +24,12 @@
namespace cartographer_grpc { namespace cartographer_grpc {
namespace handlers { namespace handlers {
class WriteMapHandler class WriteStateHandler : public framework::RpcHandler<
: public framework::RpcHandler<google::protobuf::Empty, google::protobuf::Empty,
framework::Stream<proto::WriteMapResponse>> { framework::Stream<proto::WriteStateResponse>> {
public: public:
std::string method_name() const override { std::string method_name() const override {
return "/cartographer_grpc.proto.MapBuilderService/WriteMap"; return "/cartographer_grpc.proto.MapBuilderService/WriteState";
} }
void OnRequest(const google::protobuf::Empty& request) override; void OnRequest(const google::protobuf::Empty& request) override;
}; };
@ -37,4 +37,4 @@ class WriteMapHandler
} // namespace handlers } // namespace handlers
} // namespace cartographer_grpc } // namespace cartographer_grpc
#endif // CARTOGRAPHER_GRPC_HANDLERS_WRITE_MAP_HANDLER_H #endif // CARTOGRAPHER_GRPC_HANDLERS_WRITE_STATE_HANDLER_H

View File

@ -30,10 +30,10 @@
#include "cartographer_grpc/handlers/get_local_to_global_transform_handler.h" #include "cartographer_grpc/handlers/get_local_to_global_transform_handler.h"
#include "cartographer_grpc/handlers/get_submap_handler.h" #include "cartographer_grpc/handlers/get_submap_handler.h"
#include "cartographer_grpc/handlers/get_trajectory_node_poses_handler.h" #include "cartographer_grpc/handlers/get_trajectory_node_poses_handler.h"
#include "cartographer_grpc/handlers/load_map_handler.h" #include "cartographer_grpc/handlers/load_state_handler.h"
#include "cartographer_grpc/handlers/receive_local_slam_results_handler.h" #include "cartographer_grpc/handlers/receive_local_slam_results_handler.h"
#include "cartographer_grpc/handlers/run_final_optimization_handler.h" #include "cartographer_grpc/handlers/run_final_optimization_handler.h"
#include "cartographer_grpc/handlers/write_map_handler.h" #include "cartographer_grpc/handlers/write_state_handler.h"
#include "cartographer_grpc/sensor/serialization.h" #include "cartographer_grpc/sensor/serialization.h"
#include "glog/logging.h" #include "glog/logging.h"
@ -75,9 +75,9 @@ MapBuilderServer::MapBuilderServer(
server_builder.RegisterHandler<handlers::GetAllSubmapPosesHandler>(); server_builder.RegisterHandler<handlers::GetAllSubmapPosesHandler>();
server_builder.RegisterHandler<handlers::GetLocalToGlobalTransformHandler>(); server_builder.RegisterHandler<handlers::GetLocalToGlobalTransformHandler>();
server_builder.RegisterHandler<handlers::GetConstraintsHandler>(); server_builder.RegisterHandler<handlers::GetConstraintsHandler>();
server_builder.RegisterHandler<handlers::LoadMapHandler>(); server_builder.RegisterHandler<handlers::LoadStateHandler>();
server_builder.RegisterHandler<handlers::RunFinalOptimizationHandler>(); server_builder.RegisterHandler<handlers::RunFinalOptimizationHandler>();
server_builder.RegisterHandler<handlers::WriteMapHandler>(); server_builder.RegisterHandler<handlers::WriteStateHandler>();
grpc_server_ = server_builder.Build(); grpc_server_ = server_builder.Build();
grpc_server_->SetExecutionContext( grpc_server_->SetExecutionContext(
cartographer::common::make_unique<MapBuilderContext>(this)); cartographer::common::make_unique<MapBuilderContext>(this));

View File

@ -18,8 +18,8 @@
#include "cartographer_grpc/handlers/add_trajectory_handler.h" #include "cartographer_grpc/handlers/add_trajectory_handler.h"
#include "cartographer_grpc/handlers/finish_trajectory_handler.h" #include "cartographer_grpc/handlers/finish_trajectory_handler.h"
#include "cartographer_grpc/handlers/get_submap_handler.h" #include "cartographer_grpc/handlers/get_submap_handler.h"
#include "cartographer_grpc/handlers/load_map_handler.h" #include "cartographer_grpc/handlers/load_state_handler.h"
#include "cartographer_grpc/handlers/write_map_handler.h" #include "cartographer_grpc/handlers/write_state_handler.h"
#include "cartographer_grpc/proto/map_builder_service.pb.h" #include "cartographer_grpc/proto/map_builder_service.pb.h"
#include "cartographer_grpc/sensor/serialization.h" #include "cartographer_grpc/sensor/serialization.h"
#include "glog/logging.h" #include "glog/logging.h"
@ -93,19 +93,19 @@ std::string MapBuilderStub::SubmapToProto(
void MapBuilderStub::SerializeState( void MapBuilderStub::SerializeState(
cartographer::io::ProtoStreamWriterInterface* writer) { cartographer::io::ProtoStreamWriterInterface* writer) {
google::protobuf::Empty request; google::protobuf::Empty request;
framework::Client<handlers::WriteMapHandler> client(client_channel_); framework::Client<handlers::WriteStateHandler> client(client_channel_);
CHECK(client.Write(request)); CHECK(client.Write(request));
proto::WriteMapResponse response; proto::WriteStateResponse response;
while (client.Read(&response)) { while (client.Read(&response)) {
// writer->WriteProto(response); // writer->WriteProto(response);
switch (response.map_chunk_case()) { switch (response.state_chunk_case()) {
case proto::WriteMapResponse::kPoseGraph: case proto::WriteStateResponse::kPoseGraph:
writer->WriteProto(response.pose_graph()); writer->WriteProto(response.pose_graph());
break; break;
case proto::WriteMapResponse::kAllTrajectoryBuilderOptions: case proto::WriteStateResponse::kAllTrajectoryBuilderOptions:
writer->WriteProto(response.all_trajectory_builder_options()); writer->WriteProto(response.all_trajectory_builder_options());
break; break;
case proto::WriteMapResponse::kSerializedData: case proto::WriteStateResponse::kSerializedData:
writer->WriteProto(response.serialized_data()); writer->WriteProto(response.serialized_data());
break; break;
default: default:
@ -115,23 +115,27 @@ void MapBuilderStub::SerializeState(
CHECK(writer->Close()); CHECK(writer->Close());
} }
void MapBuilderStub::LoadMap( void MapBuilderStub::LoadState(
cartographer::io::ProtoStreamReaderInterface* reader) { cartographer::io::ProtoStreamReaderInterface* reader,
framework::Client<handlers::LoadMapHandler> client(client_channel_); const bool load_frozen_state) {
if (!load_frozen_state) {
LOG(FATAL) << "Not implemented";
}
framework::Client<handlers::LoadStateHandler> client(client_channel_);
// Request with a PoseGraph proto is sent first. // Request with a PoseGraph proto is sent first.
{ {
proto::LoadMapRequest request; proto::LoadStateRequest request;
CHECK(reader->ReadProto(request.mutable_pose_graph())); CHECK(reader->ReadProto(request.mutable_pose_graph()));
CHECK(client.Write(request)); CHECK(client.Write(request));
} }
// Request with an AllTrajectoryBuilderOptions should be second. // Request with an AllTrajectoryBuilderOptions should be second.
{ {
proto::LoadMapRequest request; proto::LoadStateRequest request;
CHECK(reader->ReadProto(request.mutable_all_trajectory_builder_options())); CHECK(reader->ReadProto(request.mutable_all_trajectory_builder_options()));
CHECK(client.Write(request)); CHECK(client.Write(request));
} }
// Multiple requests with SerializedData are sent after. // Multiple requests with SerializedData are sent after.
proto::LoadMapRequest request; proto::LoadStateRequest request;
while (reader->ReadProto(request.mutable_serialized_data())) { while (reader->ReadProto(request.mutable_serialized_data())) {
CHECK(client.Write(request)); CHECK(client.Write(request));
} }

View File

@ -50,7 +50,8 @@ class MapBuilderStub : public cartographer::mapping::MapBuilderInterface {
cartographer::mapping::proto::SubmapQuery::Response* response) override; cartographer::mapping::proto::SubmapQuery::Response* response) override;
void SerializeState( void SerializeState(
cartographer::io::ProtoStreamWriterInterface* writer) override; cartographer::io::ProtoStreamWriterInterface* writer) override;
void LoadMap(cartographer::io::ProtoStreamReaderInterface* reader) override; void LoadState(cartographer::io::ProtoStreamReaderInterface* reader,
bool load_frozen_state) override;
int num_trajectory_builders() const override; int num_trajectory_builders() const override;
cartographer::mapping::PoseGraphInterface* pose_graph() override; cartographer::mapping::PoseGraphInterface* pose_graph() override;
const std::vector< const std::vector<

View File

@ -102,8 +102,8 @@ message GetSubmapRequest {
cartographer.mapping.proto.SubmapId submap_id = 1; cartographer.mapping.proto.SubmapId submap_id = 1;
} }
message LoadMapRequest { message LoadStateRequest {
oneof map_chunk { oneof state_chunk {
cartographer.mapping.proto.PoseGraph pose_graph = 1; cartographer.mapping.proto.PoseGraph pose_graph = 1;
cartographer.mapping.proto.AllTrajectoryBuilderOptions cartographer.mapping.proto.AllTrajectoryBuilderOptions
all_trajectory_builder_options = 2; all_trajectory_builder_options = 2;
@ -162,8 +162,8 @@ message AddLocalSlamResultDataRequest {
cartographer.mapping.proto.LocalSlamResultData local_slam_result_data = 2; cartographer.mapping.proto.LocalSlamResultData local_slam_result_data = 2;
} }
message WriteMapResponse { message WriteStateResponse {
oneof map_chunk { oneof state_chunk {
cartographer.mapping.proto.PoseGraph pose_graph = 1; cartographer.mapping.proto.PoseGraph pose_graph = 1;
cartographer.mapping.proto.AllTrajectoryBuilderOptions cartographer.mapping.proto.AllTrajectoryBuilderOptions
all_trajectory_builder_options = 2; all_trajectory_builder_options = 2;
@ -234,9 +234,10 @@ service MapBuilderService {
rpc RunFinalOptimization(google.protobuf.Empty) rpc RunFinalOptimization(google.protobuf.Empty)
returns (google.protobuf.Empty); returns (google.protobuf.Empty);
// Adds map data in the order defined by ProtoStreamReader. // Adds serialized SLAM state data in the order defined by ProtoStreamReader.
rpc LoadMap(stream LoadMapRequest) returns (google.protobuf.Empty); rpc LoadState(stream LoadStateRequest) returns (google.protobuf.Empty);
// Receives map data in the order defined by ProtoStreamWriter. // Receives serialized SLAM state data in the order defined by
rpc WriteMap(google.protobuf.Empty) returns (stream WriteMapResponse); // ProtoStreamWriter.
rpc WriteState(google.protobuf.Empty) returns (stream WriteStateResponse);
} }

View File

@ -51,7 +51,8 @@ class MockMapBuilder : public cartographer::mapping::MapBuilderInterface {
cartographer::mapping::proto::SubmapQuery::Response *)); cartographer::mapping::proto::SubmapQuery::Response *));
MOCK_METHOD1(SerializeState, MOCK_METHOD1(SerializeState,
void(cartographer::io::ProtoStreamWriterInterface *)); void(cartographer::io::ProtoStreamWriterInterface *));
MOCK_METHOD1(LoadMap, void(cartographer::io::ProtoStreamReaderInterface *)); MOCK_METHOD2(LoadState,
void(cartographer::io::ProtoStreamReaderInterface *, bool));
MOCK_CONST_METHOD0(num_trajectory_builders, int()); MOCK_CONST_METHOD0(num_trajectory_builders, int());
MOCK_METHOD0(pose_graph, cartographer::mapping::PoseGraphInterface *()); MOCK_METHOD0(pose_graph, cartographer::mapping::PoseGraphInterface *());
MOCK_CONST_METHOD0( MOCK_CONST_METHOD0(