aGrUM
0.20.3
a C++ library for (probabilistic) graphical models
MonteCarloSampling_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 Implementation of Monte Carlo Sampling for inference in Bayesian
25
* Networks.
26
*
27
* @author Paul ALAM & Pierre-Henri WUILLEMIN(@LIP6)
28
*/
29
30
31
#
include
<
agrum
/
BN
/
inference
/
MonteCarloSampling
.
h
>
32
33
34
namespace
gum
{
35
36
/// Default constructor
37
template
<
typename
GUM_SCALAR >
38
MonteCarloSampling< GUM_SCALAR >::MonteCarloSampling(
const
IBayesNet< GUM_SCALAR >* bn) :
39
SamplingInference< GUM_SCALAR >(bn) {
40
GUM_CONSTRUCTOR(MonteCarloSampling);
41
}
42
43
/// Destructor
44
template
<
typename
GUM_SCALAR
>
45
MonteCarloSampling
<
GUM_SCALAR
>::~
MonteCarloSampling
() {
46
GUM_DESTRUCTOR
(
MonteCarloSampling
);
47
}
48
49
/// no burn in needed for Monte Carlo sampling
50
template
<
typename
GUM_SCALAR
>
51
Instantiation
MonteCarloSampling
<
GUM_SCALAR
>::
burnIn_
() {
52
gum
::
Instantiation
I
;
53
return
I
;
54
}
55
56
57
template
<
typename
GUM_SCALAR
>
58
Instantiation
MonteCarloSampling
<
GUM_SCALAR
>::
draw_
(
GUM_SCALAR
*
w
,
Instantiation
prev
) {
59
*
w
= 1.0f;
60
bool
wrong_value
=
false
;
61
do
{
62
wrong_value
=
false
;
63
prev
.
clear
();
64
for
(
const
auto
nod
:
this
->
BN
().
topologicalOrder
()) {
65
this
->
addVarSample_
(
nod
, &
prev
);
66
if
(
this
->
hardEvidenceNodes
().
contains
(
nod
)
67
&&
prev
.
val
(
this
->
BN
().
variable
(
nod
)) !=
this
->
hardEvidence
()[
nod
]) {
68
wrong_value
=
true
;
69
break
;
70
}
71
}
72
}
while
(
wrong_value
);
73
return
prev
;
74
}
75
}
// namespace gum
gum::Set::emplace
INLINE void emplace(Args &&... args)
Definition:
set_tpl.h:643