aGrUM
0.20.2
a C++ library for (probabilistic) graphical models
MonteCarloSampling_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 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(
39
const
IBayesNet< GUM_SCALAR >* bn) :
40
SamplingInference< GUM_SCALAR >(bn) {
41
GUM_CONSTRUCTOR(MonteCarloSampling);
42
}
43
44
/// Destructor
45
template
<
typename
GUM_SCALAR
>
46
MonteCarloSampling
<
GUM_SCALAR
>::~
MonteCarloSampling
() {
47
GUM_DESTRUCTOR
(
MonteCarloSampling
);
48
}
49
50
/// no burn in needed for Monte Carlo sampling
51
template
<
typename
GUM_SCALAR
>
52
Instantiation
MonteCarloSampling
<
GUM_SCALAR
>::
burnIn_
() {
53
gum
::
Instantiation
I
;
54
return
I
;
55
}
56
57
58
template
<
typename
GUM_SCALAR
>
59
Instantiation
MonteCarloSampling
<
GUM_SCALAR
>::
draw_
(
GUM_SCALAR
*
w
,
60
Instantiation
prev
) {
61
*
w
= 1.0f;
62
bool
wrong_value
=
false
;
63
do
{
64
wrong_value
=
false
;
65
prev
.
clear
();
66
for
(
const
auto
nod
:
this
->
BN
().
topologicalOrder
()) {
67
this
->
addVarSample_
(
nod
, &
prev
);
68
if
(
this
->
hardEvidenceNodes
().
contains
(
nod
)
69
&&
prev
.
val
(
this
->
BN
().
variable
(
nod
)) !=
this
->
hardEvidence
()[
nod
]) {
70
wrong_value
=
true
;
71
break
;
72
}
73
}
74
}
while
(
wrong_value
);
75
return
prev
;
76
}
77
}
// namespace gum
gum::Set::emplace
INLINE void emplace(Args &&... args)
Definition:
set_tpl.h:669