aGrUM
0.20.3
a C++ library for (probabilistic) graphical models
chi2_inl.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 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
Chi2
::
setConditioningNodes
(
const
std
::
vector
<
Idx
>&
db_conditioning_ids
) {
37
_conditioning_size_
= 1;
38
for
(
Idx
i
= 0;
i
<
db_conditioning_ids
.
size
(); ++
i
) {
39
_conditioning_size_
*=
_modalities_
[
db_conditioning_ids
[
i
]];
40
}
41
}
42
43
// returns the number of degrees of freedom
44
INLINE Size
Chi2
::
degreesOfFreedom
(
const
std
::
pair
<
Idx
,
Idx
>&
pair
) {
45
return
degreesOfFreedom
(
pair
.
first
,
pair
.
second
);
46
}
47
48
// returns the number of degrees of freedom
49
INLINE
Size
Chi2
::
degreesOfFreedom
(
Idx
var1
,
Idx
var2
) {
50
return
(
_conditioning_size_
* (
_modalities_
[
var1
] - 1) * (
_modalities_
[
var2
] - 1));
51
}
52
53
// computes the critical value according to the number of degrees of freedom
54
ALWAYS_INLINE
double
Chi2
::
criticalValue
(
const
std
::
pair
<
Idx
,
Idx
>&
pair
) {
55
return
criticalValue
(
pair
.
first
,
pair
.
second
);
56
}
57
58
// computes the critical value according to the number of degrees of freedom
59
ALWAYS_INLINE
double
Chi2
::
criticalValue
(
Idx
var1
,
Idx
var2
) {
60
Size
DF
=
degreesOfFreedom
(
var1
,
var2
);
61
62
// try to see if the threshold is not already in cache
63
try
{
64
return
_critical_values_
[
DF
];
65
}
catch
(
const
Exception
&) {
66
// here we have to compute the threshold of the chi2
67
// we use Gary Perlman's algorithm
68
double
value
=
_criticalValue_
(
_confidence_proba_
,
DF
);
69
_critical_values_
.
insert
(
DF
,
value
);
70
return
value
;
71
}
72
}
73
74
// modifies the confidence proba
75
INLINE
void
Chi2
::
setConfidenceProba
(
double
new_proba
) {
76
// if we did not change the confidence proba, do nothing
77
if
(
_confidence_proba_
==
new_proba
)
return
;
78
79
_confidence_proba_
=
new_proba
;
80
81
// remove the currently stored critical values
82
_critical_values_
.
clear
();
83
}
84
85
}
/* namespace gum */
gum::Set::emplace
INLINE void emplace(Args &&... args)
Definition:
set_tpl.h:643