aGrUM
2.3.2
a C++ library for (probabilistic) graphical models
AVLTree.cpp
Go to the documentation of this file.
1
/****************************************************************************
2
* This file is part of the aGrUM/pyAgrum library. *
3
* *
4
* Copyright (c) 2005-2025 by *
5
* - Pierre-Henri WUILLEMIN(_at_LIP6) *
6
* - Christophe GONZALES(_at_AMU) *
7
* *
8
* The aGrUM/pyAgrum library is free software; you can redistribute it *
9
* and/or modify it under the terms of either : *
10
* *
11
* - the GNU Lesser General Public License as published by *
12
* the Free Software Foundation, either version 3 of the License, *
13
* or (at your option) any later version, *
14
* - the MIT license (MIT), *
15
* - or both in dual license, as here. *
16
* *
17
* (see https://agrum.gitlab.io/articles/dual-licenses-lgplv3mit.html) *
18
* *
19
* This aGrUM/pyAgrum library is distributed in the hope that it will be *
20
* useful, but WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, *
21
* INCLUDING BUT NOT LIMITED TO THE WARRANTIES MERCHANTABILITY or FITNESS *
22
* FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE *
23
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER *
24
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, *
25
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR *
26
* OTHER DEALINGS IN THE SOFTWARE. *
27
* *
28
* See LICENCES for more details. *
29
* *
30
* SPDX-FileCopyrightText: Copyright 2005-2025 *
31
* - Pierre-Henri WUILLEMIN(_at_LIP6) *
32
* - Christophe GONZALES(_at_AMU) *
33
* SPDX-License-Identifier: LGPL-3.0-or-later OR MIT *
34
* *
35
* Contact : info_at_agrum_dot_org *
36
* homepage : http://agrum.gitlab.io *
37
* gitlab : https://gitlab.com/agrumery/agrum *
38
* *
39
****************************************************************************/
40
41
48
49
#include <
agrum/base/core/AVLTree.h
>
50
51
#ifndef DOXYGEN_SHOULD_SKIP_THIS
52
53
namespace
gum
{
54
55
// The global static variable representing end and rend for all the AVL trees.
56
// The constinit ensures it is created at compile time. Here, we use the
57
// constinit keyword rather than constexpr because, in debugging mode, the
58
// iterators' destructors cannot be declared as constepxr.
59
constinit
const
AVLTreeIterator< int, std::less< int >
>
60
_static_AVLTree_end_(
StaticInitializer::CONSTINIT
);
61
constinit
const
AVLTreeReverseIterator< int, std::less< int >
>
62
_static_AVLTree_rend_(
StaticInitializer::CONSTINIT
);
63
constinit
const
AVLTreeIteratorSafe< int, std::less< int >
>
64
_static_AVLTree_end_safe_(
StaticInitializer::CONSTINIT
);
65
constinit
const
AVLTreeReverseIteratorSafe< int, std::less< int >
>
66
_static_AVLTree_rend_safe_(
StaticInitializer::CONSTINIT
);
67
68
}
// namespace gum
69
70
#endif
// DOXYGEN_SHOULD_SKIP_THIS
AVLTree.h
AVL binary search trees.
gum::AVLTreeIteratorSafe
AVL binary search tree safe (w.r.t.
Definition
AVLTree.h:594
gum::AVLTreeIterator
AVL binary search tree iterator.
Definition
AVLTree.h:457
gum::AVLTreeReverseIteratorSafe
AVL binary search tree safe (w.r.t.
Definition
AVLTree.h:813
gum::AVLTreeReverseIterator
AVL binary search tree reverse iterator.
Definition
AVLTree.h:702
gum
gum is the global namespace for all aGrUM entities
Definition
agrum.h:46
gum::StaticInitializer::CONSTINIT
@ CONSTINIT
Definition
staticInitializer.h:68