aGrUM  0.20.3
a C++ library for (probabilistic) graphical models
statesCounter.cpp
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 #include <agrum/FMDP/simulation/statesCounter.h>
23 
24 
25 namespace gum {
26 
27 
28  // =================================================================================================
29  //
30  // =================================================================================================
33  }
34 
35 
36  // =================================================================================================
37  //
38  // =================================================================================================
40  delete _counter_;
42  }
43 
44 
45  // =================================================================================================
46  //
47  // =================================================================================================
49  _counter_->clear();
53  ++varIter)
54  _counter_->add(**varIter);
55 
57 
58  _incState_(initialState, 0, 0, 0);
59  }
60 
61 
62  // =================================================================================================
63  //
64  // =================================================================================================
67 
73  }
75  }
76 
77 
78  // =================================================================================================
79  //
80  // =================================================================================================
84  Size nbVisits) {
85  Idx varIter = 0;
87 
88 
89  for (; varIter < state.variablesSequence().size(); ++varIter) {
92  if (parentId)
94  else
96  for (Idx moda = 0; moda < curVar->domainSize(); ++moda) {
97  if (moda == state.valFromPtr(curVar))
98  parentModa = moda;
99  else
101  }
102  parentId = varId;
103  }
105  parentModa,
107  }
108 } // End of namespace gum
INLINE void emplace(Args &&... args)
Definition: set_tpl.h:643