MRPT  1.9.9
graphslam/include/mrpt/graphslam/types.h
Go to the documentation of this file.
1 /* +------------------------------------------------------------------------+
2  | Mobile Robot Programming Toolkit (MRPT) |
3  | http://www.mrpt.org/ |
4  | |
5  | Copyright (c) 2005-2018, Individual contributors, see AUTHORS file |
6  | See: http://www.mrpt.org/Authors - All rights reserved. |
7  | Released under BSD License. See details in http://www.mrpt.org/License |
8  +------------------------------------------------------------------------+ */
9 #pragma once
10 
12 #include <mrpt/poses/SE_traits.h>
14 #include <functional>
15 
16 namespace mrpt
17 {
18 /** SLAM methods related to graphs of pose constraints
19  * \sa mrpt::graphs::CNetworkOfPoses \ingroup mrpt_graphslam_grp
20  */
21 namespace graphslam
22 {
23 /** \addtogroup mrpt_graphslam_grp
24  * @{ */
25 
26 /** Auxiliary traits template for use among graph-slam problems to make life
27  * easier with these complicated, long data type names
28  * \tparam GRAPH_T This will typically be any
29  * mrpt::graphs::CNetworkOfPoses<...>
30  */
31 template <class GRAPH_T>
33 {
34  /** Typ: mrpt::graphs::CNetworkOfPoses<...> */
35  using graph_t = GRAPH_T;
37  using edge_map_entry_t = typename graph_t::edges_map_t::value_type;
38  using edge_t = typename graph_t::constraint_t;
39  using edge_poses_type = typename edge_t::type_value;
40  using SE_TYPE =
42  using matrix_VxV_t = typename SE_TYPE::matrix_VxV_t;
43  using Array_O = typename SE_TYPE::array_t; // An array of the correct size
44  // for an "observation" (i.e. a
45  // relative pose in an edge)
46  using TPairJacobs = std::pair<matrix_VxV_t, matrix_VxV_t>;
49 
50  /** Auxiliary struct used in graph-slam implementation: It holds the
51  * relevant information for each of the constraints being taking into
52  * account. */
54  {
56  // Data:
57  const typename gst::edge_map_entry_t* edge{ nullptr };
58  const typename gst::graph_t::constraint_t::type_value* edge_mean;
59  typename gst::graph_t::constraint_t::type_value *P1, *P2;
60  };
61 
62  using TFunctorFeedback = std::function<void(
63  const GRAPH_T& graph, const size_t iter, const size_t max_iter,
64  const double cur_sq_error)>;
65 };
66 
67 /** Output information for mrpt::graphslam::optimize_graph_spa_levmarq() */
69 {
70  /** The number of LM iterations executed. */
71  size_t num_iters;
72  /** The sum of all the squared errors for every constraint involved in the
73  * problem. */
75 };
76 
77 /** @} */ // end of grouping
78 
79 } // End of namespace
80 } // End of namespace
std::pair< matrix_VxV_t, matrix_VxV_t > TPairJacobs
size_t num_iters
The number of LM iterations executed.
typename graph_t::edges_map_t::value_type edge_map_entry_t
typename graph_t::edges_map_t::const_iterator edge_const_iterator
std::multimap< KEY, VALUE, std::less< KEY >, mrpt::aligned_allocator_cpp11< std::pair< const KEY, VALUE > >> aligned_std_multimap
Auxiliary struct used in graph-slam implementation: It holds the relevant information for each of the...
mrpt::aligned_std_multimap< mrpt::graphs::TPairNodeIDs, TPairJacobs > map_pairIDs_pairJacobs_t
Auxiliary traits template for use among graph-slam problems to make life easier with these complicate...
This is the global namespace for all Mobile Robot Programming Toolkit (MRPT) libraries.
std::function< void(const GRAPH_T &graph, const size_t iter, const size_t max_iter, const double cur_sq_error)> TFunctorFeedback
A helper class for SE(2) and SE(3) geometry-related transformations, on-manifold optimization Jacobia...
Definition: SE_traits.h:27
Output information for mrpt::graphslam::optimize_graph_spa_levmarq()
typedef void(APIENTRYP PFNGLBLENDCOLORPROC)(GLclampf red
const Scalar * const_iterator
Definition: eigen_plugins.h:27
double final_total_sq_error
The sum of all the squared errors for every constraint involved in the problem.
GRAPH_T graph_t
Typ: mrpt::graphs::CNetworkOfPoses<...>



Page generated by Doxygen 1.8.14 for MRPT 1.9.9 Git: 7d5e6d718 Fri Aug 24 01:51:28 2018 +0200 at lun nov 2 08:35:50 CET 2020