NASA Astrobee Robot Software  0.19.1
Flight software for the Astrobee robots operating inside the International Space Station.
nonlinear_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_NONLINEAR_OPTIMIZER_H_
20 #define OPTIMIZERS_NONLINEAR_OPTIMIZER_H_
21 
23 #include <optimizers/optimizer.h>
24 
25 #include <gtsam/nonlinear/LevenbergMarquardtOptimizer.h>
26 #include <gtsam/nonlinear/NonlinearFactorGraph.h>
27 
28 #include <boost/serialization/serialization.hpp>
29 
30 namespace optimizers {
31 class NonlinearOptimizer : public Optimizer {
32  public:
33  explicit NonlinearOptimizer(const NonlinearOptimizerParams& params);
34 
35  // Default constructor for serialization only
36  NonlinearOptimizer() = default;
37 
38  virtual ~NonlinearOptimizer() = default;
39 
40  // Performs Levenberg-Marquardt nonlinear optimization using GTSAM on the factor graph.
41  bool Optimize(const gtsam::NonlinearFactorGraph& factors, gtsam::Values& values) final;
42 
43  int iterations() const final;
44 
45  private:
46  // Set optimization params based on provided NonlinearOptimizerParams.
47  void SetOptimizationParams();
48 
49  // Order nodes in the graph for keys that will be marginalized.
50  // Allows for more efficient optimization.
51  void SetOrdering(const gtsam::NonlinearFactorGraph& factors, const gtsam::KeyVector& old_keys);
52 
53  // Serialization function
55  template <class Archive>
56  void serialize(Archive& ar, const unsigned int file_version) {
57  ar& BOOST_SERIALIZATION_NVP(params_);
58  ar& BOOST_SERIALIZATION_NVP(levenberg_marquardt_params_);
59  }
60 
62  gtsam::LevenbergMarquardtParams levenberg_marquardt_params_;
63  int iterations_;
64 };
65 } // namespace optimizers
66 
67 #endif // OPTIMIZERS_NONLINEAR_OPTIMIZER_H_
optimizers::NonlinearOptimizer::iterations
int iterations() const final
Definition: nonlinear_optimizer.cc:65
optimizers::NonlinearOptimizerParams
Definition: nonlinear_optimizer_params.h:24
optimizers::Optimizer
Definition: optimizer.h:33
optimizers
Definition: isam2_optimizer.h:33
optimizers::NonlinearOptimizer
Definition: nonlinear_optimizer.h:31
optimizers::NonlinearOptimizer::~NonlinearOptimizer
virtual ~NonlinearOptimizer()=default
optimizers::NonlinearOptimizer::NonlinearOptimizer
NonlinearOptimizer()=default
optimizers::NonlinearOptimizer::Optimize
bool Optimize(const gtsam::NonlinearFactorGraph &factors, gtsam::Values &values) final
Definition: nonlinear_optimizer.cc:30
nonlinear_optimizer_params.h
optimizer.h
optimizers::NonlinearOptimizer::access
friend class boost::serialization::access
Definition: nonlinear_optimizer.h:54