Solver_OLAE.cpp
Go to the documentation of this file.
1 /* -------------------------------------------------------------------------
2  * A repertory of multi primitive-to-primitive (MP2P) ICP algorithms in C++
3  * Copyright (C) 2018-2021 Jose Luis Blanco, University of Almeria
4  * See LICENSE for license information.
5  * ------------------------------------------------------------------------- */
13 #include <mp2p_icp/Solver_OLAE.h>
16 
17 #include <iostream>
18 
20 
21 using namespace mp2p_icp;
22 
23 void Solver_OLAE::initialize(const mrpt::containers::yaml& p)
24 {
26 
27  if (p.has("pairingsWeightParameters"))
28  pairingsWeightParameters.load_from(p["pairingsWeightParameters"]);
29 }
30 
31 /* Save params:
32  mrpt::containers::yaml pp = mrpt::containers::yaml::Map();
33  pairingsWeightParameters.save_to(pp);
34  p["pairingsWeightParameters"] = std::move(pp);
35 */
36 
38  const Pairings& pairings, OptimalTF_Result& out,
39  [[maybe_unused]] const SolverContext& sc) const
40 {
41  MRPT_START
42 
43  out = OptimalTF_Result();
44 
45  const Pairings* effectivePairings = &pairings;
46  std::optional<Pairings> altPairings;
47 
48  if (!pairings.paired_pt2ln.empty() || !pairings.paired_pt2pl.empty())
49  {
50  altPairings = pt2ln_pl_to_pt2pt(pairings, sc);
51  effectivePairings = &altPairings.value();
52  }
53 
54  // Compute the optimal pose, and return its validity:
55  return optimal_tf_olae(*effectivePairings, pairingsWeightParameters, out);
56 
57  MRPT_END
58 }
ICP registration for points and planes.
Converter of pairings.
OLAE algorithm to find the SE(3) optimal transformation.
WeightParameters pairingsWeightParameters
Definition: Solver_OLAE.h:29
void initialize(const mrpt::containers::yaml &params) override
Definition: Solver_OLAE.cpp:23
bool impl_optimal_pose(const Pairings &pairings, OptimalTF_Result &out, const SolverContext &sc) const override
Definition: Solver_OLAE.cpp:37
virtual void initialize(const mrpt::containers::yaml &params)
Definition: Solver.cpp:20
IMPLEMENTS_MRPT_OBJECT(metric_map_t, mrpt::serialization::CSerializable, mp2p_icp) using namespace mp2p_icp
void load_from(const mrpt::containers::yaml &p)
MatchedPointLineList paired_pt2ln
Definition: Pairings.h:102
Pairings pt2ln_pl_to_pt2pt(const Pairings &in, const SolverContext &sc)
bool optimal_tf_olae(const Pairings &in, const WeightParameters &wp, OptimalTF_Result &result)
MatchedPointPlaneList paired_pt2pl
Definition: Pairings.h:103


mrpt_local_obstacles
Author(s): Jose-Luis Blanco-Claraco
autogenerated on Thu Jun 1 2023 03:06:43