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