NASA Astrobee Robot Software  0.19.1
Flight software for the Astrobee robots operating inside the International Space Station.
isam2_optimizer.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 OPTIMIZERS_ISAM2_OPTIMIZER_H_
20 #define OPTIMIZERS_ISAM2_OPTIMIZER_H_
21 
23 #include <optimizers/optimizer.h>
24 
25 #include <gtsam/nonlinear/NonlinearFactorGraph.h>
26 #include <gtsam/nonlinear/ISAM2.h>
27 #include <gtsam/nonlinear/ISAM2Params.h>
28 
29 #include <boost/serialization/serialization.hpp>
30 
31 #include <memory>
32 
33 namespace optimizers {
34 class ISAM2Optimizer : public Optimizer {
35  public:
36  explicit ISAM2Optimizer(const ISAM2OptimizerParams& params);
37 
38  // Default constructor for serialization only
39  ISAM2Optimizer() = default;
40 
41  virtual ~ISAM2Optimizer() = default;
42 
43  // Performs Levenberg-Marquardt nonlinear optimization using GTSAM on the factor graph.
44  bool Optimize(const gtsam::NonlinearFactorGraph& factors, gtsam::Values& values) final;
45 
46  int iterations() const final;
47 
48  private:
49  // Set optimization params based on provided ISAM2OptimizerParams.
50  void SetOptimizationParams();
51 
52  // Serialization function
54  template <class Archive>
55  void serialize(Archive& ar, const unsigned int file_version) {
56  ar& BOOST_SERIALIZATION_NVP(params_);
57  ar& BOOST_SERIALIZATION_NVP(isam2_params_);
58  ar& BOOST_SERIALIZATION_NVP(isam2_);
59  ar& BOOST_SERIALIZATION_NVP(previous_factors_);
60  ar& BOOST_SERIALIZATION_NVP(previous_values_);
61  }
62 
63  ISAM2OptimizerParams params_;
64  gtsam::ISAM2Params isam2_params_;
65  std::unique_ptr<gtsam::ISAM2> isam2_;
66  // Previous factors and values, stored since ISAM2 only expects new factors
67  // and values to be added during optimization.
68  gtsam::NonlinearFactorGraph previous_factors_;
69  gtsam::Values previous_values_;
70 };
71 } // namespace optimizers
72 
73 #endif // OPTIMIZERS_ISAM2_OPTIMIZER_H_
optimizers::ISAM2Optimizer::Optimize
bool Optimize(const gtsam::NonlinearFactorGraph &factors, gtsam::Values &values) final
Definition: isam2_optimizer.cc:31
optimizers::Optimizer
Definition: optimizer.h:33
optimizers
Definition: isam2_optimizer.h:33
optimizers::ISAM2Optimizer::~ISAM2Optimizer
virtual ~ISAM2Optimizer()=default
optimizers::ISAM2Optimizer
Definition: isam2_optimizer.h:34
optimizers::ISAM2Optimizer::iterations
int iterations() const final
Definition: isam2_optimizer.cc:58
optimizers::ISAM2Optimizer::ISAM2Optimizer
ISAM2Optimizer()=default
optimizers::ISAM2Optimizer::access
friend class boost::serialization::access
Definition: isam2_optimizer.h:53
optimizers::ISAM2OptimizerParams
Definition: isam2_optimizer_params.h:24
optimizer.h
isam2_optimizer_params.h