NASA Astrobee Robot Software  0.19.1
Flight software for the Astrobee robots operating inside the International Space Station.
measurement_based_factor_adder.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 FACTOR_ADDERS_MEASUREMENT_BASED_FACTOR_ADDER_H_
20 #define FACTOR_ADDERS_MEASUREMENT_BASED_FACTOR_ADDER_H_
21 
24 
25 namespace factor_adders {
26 template <typename MeasurementType>
27 // FactorAdder that stores measurements in a measurement buffer
28 // and uses these to create factors given a time range.
30  public:
31  explicit MeasurementBasedFactorAdder(const FactorAdderParams& params);
32  virtual ~MeasurementBasedFactorAdder() = default;
33 
34  // Adds factors then removes old measurements.
35  // Requires implementation of AddMeasurementBasedFactors.
36  int AddFactors(const localization_common::Time oldest_allowed_time,
37  const localization_common::Time newest_allowed_time, gtsam::NonlinearFactorGraph& factors) final;
38 
39  // Add measurement to measurement buffer.
40  void AddMeasurement(const MeasurementType& measurement);
41 
42  // Remove old measurements from measurement buffer.
43  void RemoveOldMeasurements(const localization_common::Time oldest_allowed_time);
44 
45  protected:
46  // Helper function to process measurements in valid time range and remove processed ones
47  // from the measurement buffer.
48  // Removes the measurement if the process_measurement_function returns true.
50  const localization_common::Time oldest_allowed_time, const localization_common::Time newest_allowed_time,
51  const std::function<bool(const MeasurementType&, gtsam::NonlinearFactorGraph&)>& process_measurement_function,
52  gtsam::NonlinearFactorGraph& factors);
53 
54  // Wrapper for ProcessMeasurements that doesn't use factors.
55  void ProcessMeasurements(const localization_common::Time oldest_allowed_time,
56  const localization_common::Time newest_allowed_time,
57  const std::function<bool(const MeasurementType&)>& process_measurement_function);
58 
60 
61  private:
62  // Adds factors based on measurements.
63  // Removes used measurements from measurement buffer.
64  virtual int AddMeasurementBasedFactors(const localization_common::Time oldest_allowed_time,
65  const localization_common::Time newest_allowed_time,
66  gtsam::NonlinearFactorGraph& factors) = 0;
67 
68  // Serialization function
69  friend class boost::serialization::access;
70  template <class Archive>
71  void serialize(Archive& ar, const unsigned int file_version) {
72  ar& BOOST_SERIALIZATION_BASE_OBJECT_NVP(FactorAdder);
73  ar& BOOST_SERIALIZATION_NVP(measurements_);
74  }
75 };
76 
77 // Implementation
78 template <typename MeasurementType>
80  : FactorAdder(params) {}
81 
82 template <typename MeasurementType>
84  const localization_common::Time newest_allowed_time,
85  gtsam::NonlinearFactorGraph& factors) {
86  const int num_added_factors = AddMeasurementBasedFactors(oldest_allowed_time, newest_allowed_time, factors);
87  RemoveOldMeasurements(oldest_allowed_time);
88  return num_added_factors;
89 }
90 
91 template <typename MeasurementType>
92 void MeasurementBasedFactorAdder<MeasurementType>::AddMeasurement(const MeasurementType& measurement) {
93  measurements_.Add(measurement.timestamp, measurement);
94 }
95 
96 template <typename MeasurementType>
98  const localization_common::Time oldest_allowed_timestamp) {
99  measurements_.RemoveOldValues(oldest_allowed_timestamp);
100 }
101 
102 template <typename MeasurementType>
104  const localization_common::Time oldest_allowed_time, const localization_common::Time newest_allowed_time,
105  const std::function<bool(const MeasurementType&, gtsam::NonlinearFactorGraph&)>& process_measurement_function,
106  gtsam::NonlinearFactorGraph& factors) {
107  auto& measurements = measurements_.set();
108  for (auto it = measurements.begin(); it != measurements.end();) {
109  const auto& measurement = it->second;
110  const auto timestamp = it->first;
111  if (timestamp >= oldest_allowed_time && timestamp <= newest_allowed_time &&
112  process_measurement_function(measurement, factors)) {
113  // Remove used measurements.
114  it = measurements.erase(it);
115  } else {
116  ++it;
117  }
118  }
119 }
120 
121 template <typename MeasurementType>
123  const localization_common::Time oldest_allowed_time, const localization_common::Time newest_allowed_time,
124  const std::function<bool(const MeasurementType&)>& process_measurement_function) {
125  gtsam::NonlinearFactorGraph dummy_factors;
126  ProcessMeasurements(
127  oldest_allowed_time, newest_allowed_time,
128  [&process_measurement_function](const MeasurementType& measurement, gtsam::NonlinearFactorGraph& factors) {
129  return process_measurement_function(measurement);
130  },
131  dummy_factors);
132 }
133 } // namespace factor_adders
134 
135 #endif // FACTOR_ADDERS_MEASUREMENT_BASED_FACTOR_ADDER_H_
factor_adders::MeasurementBasedFactorAdder::ProcessMeasurements
void ProcessMeasurements(const localization_common::Time oldest_allowed_time, const localization_common::Time newest_allowed_time, const std::function< bool(const MeasurementType &, gtsam::NonlinearFactorGraph &)> &process_measurement_function, gtsam::NonlinearFactorGraph &factors)
Definition: measurement_based_factor_adder.h:103
factor_adder.h
factor_adders::FactorAdder
Definition: factor_adder.h:33
factor_adders::MeasurementBasedFactorAdder::RemoveOldMeasurements
void RemoveOldMeasurements(const localization_common::Time oldest_allowed_time)
Definition: measurement_based_factor_adder.h:97
factor_adders::FactorAdderParams
Definition: factor_adder_params.h:23
factor_adders::MeasurementBasedFactorAdder::MeasurementBasedFactorAdder
MeasurementBasedFactorAdder(const FactorAdderParams &params)
Definition: measurement_based_factor_adder.h:79
timestamped_set.h
localization_common::TimestampedSet< MeasurementType >
factor_adders::MeasurementBasedFactorAdder::measurements_
localization_common::TimestampedSet< MeasurementType > measurements_
Definition: measurement_based_factor_adder.h:59
factor_adders::MeasurementBasedFactorAdder::~MeasurementBasedFactorAdder
virtual ~MeasurementBasedFactorAdder()=default
factor_adders::MeasurementBasedFactorAdder
Definition: measurement_based_factor_adder.h:29
factor_adders
Definition: depth_odometry_factor_adder.h:31
factor_adders::MeasurementBasedFactorAdder::AddFactors
int AddFactors(const localization_common::Time oldest_allowed_time, const localization_common::Time newest_allowed_time, gtsam::NonlinearFactorGraph &factors) final
Definition: measurement_based_factor_adder.h:83
imu_integration::AddMeasurement
void AddMeasurement(const localization_measurements::ImuMeasurement &imu_measurement, localization_common::Time &last_added_imu_measurement_time, gtsam::PreintegratedCombinedMeasurements &pim)
Definition: utilities.cc:54
localization_common::Time
double Time
Definition: time.h:23
factor_adders::MeasurementBasedFactorAdder::AddMeasurement
void AddMeasurement(const MeasurementType &measurement)
Definition: measurement_based_factor_adder.h:92