aGrUM  0.20.3
a C++ library for (probabilistic) graphical models
edgeGrowth_tpl.h
Go to the documentation of this file.
1 /**
2  *
3  * Copyright (c) 2005-2021 by 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), degree_list(new std::vector< NodeId >()) {
43  }
44 
45  template < typename GUM_SCALAR >
50 
51  if (from.degree_list != 0) { degree_list = new std::vector< NodeId >(*(from.degree_list)); }
52  }
53 
54  template < typename GUM_SCALAR >
57 
58  if (degree_list != 0) { delete degree_list; }
59  }
60 
61  template < typename GUM_SCALAR >
64  str << u << "-" << edge << "-" << l_v << "-" << v;
65  return str.str();
66  }
67 
68  template < typename GUM_SCALAR >
70  PRMInstance< GUM_SCALAR >* v) {
73 
74  for (const auto& elt: matches) {
75  if ((elt.second.first == u) || (elt.second.second == u) || (elt.second.first == v)
76  || (elt.second.second == v)) {
78  }
79  }
80 
81  // The order between u and v is important ! DO NOT INVERSE IT !
83  }
84 
85  } /* namespace gspan */
86  } /* namespace prm */
87 } /* namespace gum */
INLINE void emplace(Args &&... args)
Definition: set_tpl.h:643
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.