aGrUM  0.20.2
a C++ library for (probabilistic) graphical models
edgeGrowth_tpl.h
Go to the documentation of this file.
1 /**
2  *
3  * Copyright 2005-2020 Pierre-Henri WUILLEMIN(@LIP6) & Christophe GONZALES(@AMU)
4  * info_at_agrum_dot_org
5  *
6  * This library is free software: you can redistribute it and/or modify
7  * it under the terms of the GNU Lesser General Public License as published by
8  * the Free Software Foundation, either version 3 of the License, or
9  * (at your option) any later version.
10  *
11  * This library is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14  * GNU Lesser General Public License for more details.
15  *
16  * You should have received a copy of the GNU Lesser General Public License
17  * along with this library. If not, see <http://www.gnu.org/licenses/>.
18  *
19  */
20 
21 
22 /**
23  * @file
24  * @brief Inline implementation of the DFSTree class.
25  *
26  * @author Lionel TORTI and Pierre-Henri WUILLEMIN(@LIP6)
27  */
28 
29 #include <agrum/PRM/gspan/edgeGrowth.h>
30 
31 namespace gum {
32  namespace prm {
33  namespace gspan {
34 
35  template < typename GUM_SCALAR >
36  INLINE EdgeGrowth< GUM_SCALAR >::EdgeGrowth(NodeId a_u,
39  NodeId a_v) :
40  u(a_u),
41  edge(an_edge), l_v(a_l_v), v(a_v),
42  degree_list(new std::vector< NodeId >()) {
44  }
45 
46  template < typename GUM_SCALAR >
48  const EdgeGrowth< GUM_SCALAR >& from) :
49  u(from.u),
54 
55  if (from.degree_list != 0) {
57  }
58  }
59 
60  template < typename GUM_SCALAR >
63 
64  if (degree_list != 0) { delete degree_list; }
65  }
66 
67  template < typename GUM_SCALAR >
70  str << u << "-" << edge << "-" << l_v << "-" << v;
71  return str.str();
72  }
73 
74  template < typename GUM_SCALAR >
76  PRMInstance< GUM_SCALAR >* v) {
79 
80  for (const auto& elt: matches) {
81  if ((elt.second.first == u) || (elt.second.second == u)
82  || (elt.second.first == v) || (elt.second.second == v)) {
84  }
85  }
86 
87  // The order between u and v is important ! DO NOT INVERSE IT !
89  }
90 
91  } /* namespace gspan */
92  } /* namespace prm */
93 } /* namespace gum */
INLINE void emplace(Args &&... args)
Definition: set_tpl.h:669
ParamScopeData(const std::string &s, const PRMReferenceSlot< GUM_SCALAR > &ref, Idx d)
INLINE std::ostream & operator<<(std::ostream &out, const EdgeData< GUM_SCALAR > &data)
Print a EdgeData<GUM_SCALAR> in out.