aGrUM 2.3.2
a C++ library for (probabilistic) graphical models
gibbsOperator.h
Go to the documentation of this file.
1/****************************************************************************
2 * This file is part of the aGrUM/pyAgrum library. *
3 * *
4 * Copyright (c) 2005-2025 by *
5 * - Pierre-Henri WUILLEMIN(_at_LIP6) *
6 * - Christophe GONZALES(_at_AMU) *
7 * *
8 * The aGrUM/pyAgrum library is free software; you can redistribute it *
9 * and/or modify it under the terms of either : *
10 * *
11 * - the GNU Lesser General Public License as published by *
12 * the Free Software Foundation, either version 3 of the License, *
13 * or (at your option) any later version, *
14 * - the MIT license (MIT), *
15 * - or both in dual license, as here. *
16 * *
17 * (see https://agrum.gitlab.io/articles/dual-licenses-lgplv3mit.html) *
18 * *
19 * This aGrUM/pyAgrum library is distributed in the hope that it will be *
20 * useful, but WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, *
21 * INCLUDING BUT NOT LIMITED TO THE WARRANTIES MERCHANTABILITY or FITNESS *
22 * FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE *
23 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER *
24 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, *
25 * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR *
26 * OTHER DEALINGS IN THE SOFTWARE. *
27 * *
28 * See LICENCES for more details. *
29 * *
30 * SPDX-FileCopyrightText: Copyright 2005-2025 *
31 * - Pierre-Henri WUILLEMIN(_at_LIP6) *
32 * - Christophe GONZALES(_at_AMU) *
33 * SPDX-License-Identifier: LGPL-3.0-or-later OR MIT *
34 * *
35 * Contact : info_at_agrum_dot_org *
36 * homepage : http://agrum.gitlab.io *
37 * gitlab : https://gitlab.com/agrumery/agrum *
38 * *
39 ****************************************************************************/
40
41
48
49
50#ifndef GUM_GIBBS_OPERATOR_H
51#define GUM_GIBBS_OPERATOR_H
52
53#include <agrum/BN/IBayesNet.h>
54
55namespace gum {
56
65
66 template < typename GUM_SCALAR >
68 public:
73 const NodeProperty< Idx >* hardEv,
74 Size nbr = 1,
75 bool atRandom = false);
76
80 virtual ~GibbsOperator();
81
83 Size nbrDrawnVar() const { return nbr_; }
84
85 void setNbrDrawnVar(Size nbr) { nbr_ = nbr; }
86
87 bool isDrawnAtRandom() const { return atRandom_; }
88
89 void setDrawnAtRandom(bool atRandom) { atRandom_ = atRandom; }
90
93
96
97 protected:
102
105
107
108 private:
109 // adds a node to current instantiation
111
113 };
114
115
116#ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
117
118 extern template class GibbsOperator< double >;
119
120#endif
121
122} // namespace gum
123
125
126#endif
Class representing the minimal interface for Bayesian network with no numerical data.
class containing all variables and methods required for Gibbssampling
void setDrawnAtRandom(bool atRandom)
Size nbrDrawnVar() const
Getters and setters.
void _drawVarMonteCarlo_(NodeId nod, Instantiation *I)
void setNbrDrawnVar(Size nbr)
const IBayesNet< GUM_SCALAR > & samplingBn_
void _GibbsSample_(NodeId id, Instantiation *I)
change in Instantiation I a new drawn value for id
Instantiation nextSample(Instantiation prev)
draws next sample of Gibbs sampling
Sequence< NodeId > samplingNodes_
Instantiation monteCarloSample()
draws a Monte Carlo sample
const NodeProperty< Idx > * hardEv_
bool isDrawnAtRandom() const
GibbsOperator(const IBayesNet< GUM_SCALAR > &BN, const NodeProperty< Idx > *hardEv, Size nbr=1, bool atRandom=false)
constructor
virtual ~GibbsOperator()
Destructor.
Class representing the minimal interface for Bayesian network with no numerical data.
Definition IBayesNet.h:75
Class for assigning/browsing values to tuples of discrete variables.
Implementation of Gibbs inference methods in Bayesian networks.
std::size_t Size
In aGrUM, hashed values are unsigned long int.
Definition types.h:74
Size NodeId
Type for node ids.
HashTable< NodeId, VAL > NodeProperty
Property on graph elements.
gum is the global namespace for all aGrUM entities
Definition agrum.h:46