aGrUM
0.20.2
a C++ library for (probabilistic) graphical models
chi2_inl.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 The class that represents the chi2 distribution
25
*
26
* The Chi2 class allows to easily compute critical values for the Chi2
27
* distribution.
28
*
29
* @author Christophe GONZALES(@AMU) and Pierre-Henri WUILLEMIN(@LIP6)
30
*/
31
32
33
namespace
gum
{
34
35
// sets the conditioning nodes (useful for computing degrees of freedom)
36
INLINE
void
37
Chi2
::
setConditioningNodes
(
const
std
::
vector
<
Idx
>&
db_conditioning_ids
) {
38
conditioning_size__
= 1;
39
for
(
Idx
i
= 0;
i
<
db_conditioning_ids
.
size
(); ++
i
) {
40
conditioning_size__
*=
modalities__
[
db_conditioning_ids
[
i
]];
41
}
42
}
43
44
// returns the number of degrees of freedom
45
INLINE Size
Chi2
::
degreesOfFreedom
(
const
std
::
pair
<
Idx
,
Idx
>&
pair
) {
46
return
degreesOfFreedom
(
pair
.
first
,
pair
.
second
);
47
}
48
49
// returns the number of degrees of freedom
50
INLINE
Size
Chi2
::
degreesOfFreedom
(
Idx
var1
,
Idx
var2
) {
51
return
(
conditioning_size__
* (
modalities__
[
var1
] - 1)
52
* (
modalities__
[
var2
] - 1));
53
}
54
55
// computes the critical value according to the number of degrees of freedom
56
ALWAYS_INLINE
double
Chi2
::
criticalValue
(
const
std
::
pair
<
Idx
,
Idx
>&
pair
) {
57
return
criticalValue
(
pair
.
first
,
pair
.
second
);
58
}
59
60
// computes the critical value according to the number of degrees of freedom
61
ALWAYS_INLINE
double
Chi2
::
criticalValue
(
Idx
var1
,
Idx
var2
) {
62
Size
DF
=
degreesOfFreedom
(
var1
,
var2
);
63
64
// try to see if the threshold is not already in cache
65
try
{
66
return
critical_values__
[
DF
];
67
}
catch
(
const
Exception
&) {
68
// here we have to compute the threshold of the chi2
69
// we use Gary Perlman's algorithm
70
double
value
=
criticalValue__
(
confidence_proba__
,
DF
);
71
critical_values__
.
insert
(
DF
,
value
);
72
return
value
;
73
}
74
}
75
76
// modifies the confidence proba
77
INLINE
void
Chi2
::
setConfidenceProba
(
double
new_proba
) {
78
// if we did not change the confidence proba, do nothing
79
if
(
confidence_proba__
==
new_proba
)
return
;
80
81
confidence_proba__
=
new_proba
;
82
83
// remove the currently stored critical values
84
critical_values__
.
clear
();
85
}
86
87
}
/* namespace gum */
gum::Set::emplace
INLINE void emplace(Args &&... args)
Definition:
set_tpl.h:669