aGrUM
0.20.3
a C++ library for (probabilistic) graphical models
pow_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 Inline implementation of pow functions with integers, faster than stl
25
* implementation.
26
* @author Matthieu HOURBRACQ and Pierre-Henri WUILLEMIN(@LIP6)
27
*/
28
29
// To help IDE Parsers
30
#
include
<
agrum
/
tools
/
core
/
math
/
pow
.
h
>
31
32
namespace
gum
{
33
//@beforeMerging is this really faster ?
34
// Specialized pow function with integers (faster implementation).
35
INLINE
unsigned
long
intPow
(
unsigned
long
base
,
unsigned
long
exponent
) {
36
if
(
exponent
== 0) {
return
1UL; }
37
38
unsigned
long
out
=
base
;
39
40
for
(
unsigned
long
i
= 1;
i
<
exponent
;
i
++)
41
out
*=
base
;
42
43
return
out
;
44
}
45
46
//@beforeMerging is this really faster ?
47
// Specialized base 2 pow function with integer.
48
INLINE
unsigned
long
int2Pow
(
unsigned
long
exponent
) {
return
1UL <<
exponent
; }
49
50
//@beforeMerging is this really faster ?
51
// Given an integer, compute it's - superior - and closest power of two, i.e.
52
// the number of bits necessary to represent this integer as well as the
53
// maximum integer that can be represented by those bits.
54
INLINE
void
superiorPow
(
unsigned
long
card
,
unsigned
long
&
num_bits
,
unsigned
long
&
new_card
) {
55
if
(
card
== 0) {
56
num_bits
= 0;
57
new_card
= 1;
58
return
;
59
}
60
61
num_bits
= 1;
62
new_card
= 2;
63
64
while
(
new_card
<
card
) {
65
new_card
*= 2;
66
num_bits
++;
67
}
68
}
69
70
}
// namespace gum
gum::Set::emplace
INLINE void emplace(Args &&... args)
Definition:
set_tpl.h:643