NASA Astrobee Robot Software  0.19.1
Flight software for the Astrobee robots operating inside the International Space Station.
pose_node_adder_model.h
Go to the documentation of this file.
1 /* Copyright (c) 2017, United States Government, as represented by the
2  * Administrator of the National Aeronautics and Space Administration.
3  *
4  * All rights reserved.
5  *
6  * The Astrobee platform is licensed under the Apache License, Version 2.0
7  * (the "License"); you may not use this file except in compliance with the
8  * License. You may obtain a copy of the License at
9  *
10  * http://www.apache.org/licenses/LICENSE-2.0
11  *
12  * Unless required by applicable law or agreed to in writing, software
13  * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
14  * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
15  * License for the specific language governing permissions and limitations
16  * under the License.
17  */
18 
19 #ifndef NODE_ADDERS_POSE_NODE_ADDER_MODEL_H_
20 #define NODE_ADDERS_POSE_NODE_ADDER_MODEL_H_
21 
28 
29 #include <gtsam/inference/Key.h>
30 #include <gtsam/geometry/Pose3.h>
31 #include <gtsam/nonlinear/Marginals.h>
32 
33 #include <utility>
34 
35 class GraphVIO;
36 
37 namespace node_adders {
39  localization_measurements::PoseWithCovarianceMeasurement, gtsam::Pose3> {
40  using Base =
42  gtsam::Pose3>;
44 
45  public:
47 
48  explicit PoseNodeAdderModel(const Params& params) : Base(params) {}
49 
50  gtsam::KeyVector AddNode(const localization_common::Time timestamp, NodesType& nodes) const final;
51  boost::optional<std::pair<gtsam::Pose3, gtsam::SharedNoiseModel>> RelativeNodeAndNoise(
52  const localization_common::Time timestamp_a, const localization_common::Time timestamp_b) const final;
54  // Keeps lower_bound measurement <= oldest_allowed_time to use for interpolation if needed.
55  void RemoveMeasurements(const localization_common::Time oldest_allowed_time);
56  bool CanAddNode(const localization_common::Time timestamp) const final;
57  // Sets pose covariance interpolater for relative odometry pose node creation
60  pose_covariance_interpolater);
61  // Accessor to pose interpolater
63 
64  private:
65  // Serialization function
67  template <class Archive>
68  void serialize(Archive& ar, const unsigned int file_version) {
69  ar& BOOST_SERIALIZATION_BASE_OBJECT_NVP(Base);
70  ar& BOOST_SERIALIZATION_NVP(pose_interpolater_);
71  }
72 
74 };
75 } // namespace node_adders
76 
77 #endif // NODE_ADDERS_POSE_NODE_ADDER_MODEL_H_
marginals_pose_covariance_interpolater.h
between_factor_node_adder_model.h
node_adders::BetweenFactorNodeAdderModel::Base
NodeAdderModelType Base
Definition: between_factor_node_adder_model.h:42
node_adders::PoseNodeAdderModel::RemoveMeasurements
void RemoveMeasurements(const localization_common::Time oldest_allowed_time)
Definition: pose_node_adder_model.cc:61
nodes
Definition: combined_nav_state_nodes.h:24
node_adders
Definition: between_factor_node_adder_model.h:35
node_adders::PoseNodeAdderModel::CanAddNode
bool CanAddNode(const localization_common::Time timestamp) const final
Definition: pose_node_adder_model.cc:66
node_adders::PoseNodeAdderModel
Definition: pose_node_adder_model.h:38
node_adders::BetweenFactorNodeAdderModel
Definition: between_factor_node_adder_model.h:39
node_adders::PoseNodeAdderModel::AddMeasurement
void AddMeasurement(const localization_measurements::PoseWithCovarianceMeasurement &measurement)
Definition: pose_node_adder_model.cc:57
node_adders::PoseNodeAdderModel::RelativeNodeAndNoise
boost::optional< std::pair< gtsam::Pose3, gtsam::SharedNoiseModel > > RelativeNodeAndNoise(const localization_common::Time timestamp_a, const localization_common::Time timestamp_b) const final
Definition: pose_node_adder_model.cc:44
node_adders::PoseNodeAdderModel::access
friend class boost::serialization::access
Definition: pose_node_adder_model.h:66
timestamped_nodes.h
node_adders::PoseNodeAdderModel::PoseNodeAdderModel
PoseNodeAdderModel(const Params &params)
Definition: pose_node_adder_model.h:48
localization_common::TimestampedInterpolater
Definition: timestamped_interpolater.h:40
nodes::TimestampedNodes
Definition: timestamped_nodes.h:28
node_adders::PoseNodeAdderModel::AddNode
gtsam::KeyVector AddNode(const localization_common::Time timestamp, NodesType &nodes) const final
Definition: pose_node_adder_model.cc:28
pose_with_covariance_interpolater.h
node_adders::PoseNodeAdderModel::SetPoseCovarianceInterpolater
void SetPoseCovarianceInterpolater(const std::shared_ptr< localization_common::MarginalsPoseCovarianceInterpolater< nodes::CombinedNavStateNodes >> &pose_covariance_interpolater)
Definition: pose_node_adder_model.cc:70
localization_measurements::PoseWithCovarianceMeasurement
Definition: pose_with_covariance_measurement.h:31
node_adders::TimestampedNodeAdderModelParams
Definition: timestamped_node_adder_model_params.h:24
localization_common::Time
double Time
Definition: time.h:23
localization_common::MarginalsPoseCovarianceInterpolater
Definition: marginals_pose_covariance_interpolater.h:30
combined_nav_state_nodes.h
node_adders::PoseNodeAdderModel::pose_interpolater
localization_common::PoseWithCovarianceInterpolater & pose_interpolater()
Definition: pose_node_adder_model.cc:76
pose_with_covariance_measurement.h