aGrUM 2.3.2
a C++ library for (probabilistic) graphical models
threads.h
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
47
48#ifndef GUM_THREADS_H
49#define GUM_THREADS_H
50
51#include <utility>
52#include <vector>
53
54#include <agrum/agrum.h>
55
58
59namespace gum {
60
61 // select the default threading model
62 // @TODO substitute the lines below by namespace threads = GUM_THREADS; when swig
63 // will support it
64#ifdef GUM_THREADS_USE_OMP
65 namespace threads = gum::threadsOMP;
66#else
67 namespace threads = gum::threadsSTL;
68#endif
69
70
84
98
105
115 void setNumberOfThreads(unsigned int number);
116
118 bool isOMP();
119
129 std::vector< std::pair< Idx, Idx > >
130 dispatchRangeToThreads(Idx beg, Idx end, unsigned int nb_threads);
131
132} /* namespace gum */
133
134
135#endif /* GUM_THREADS_H */
void setNumberOfThreads(unsigned int number)
Set the max number of threads to be used when entering the next parallel region.
Definition threads.cpp:55
unsigned int getNumberOfLogicalProcessors()
Get the number of logical processors.
unsigned int getMaxNumberOfThreads()
Returns the maximum number of threads you should use at any time.
Size Idx
Type for indexes.
Definition types.h:79
unsigned int getNumberOfThreads()
returns the max number of threads used by default when entering the next parallel region
gum is the global namespace for all aGrUM entities
Definition agrum.h:46
bool isOMP()
indicates whether aGrUM uses openMP or STL threads
Definition threads.cpp:66
std::vector< std::pair< Idx, Idx > > dispatchRangeToThreads(Idx beg, Idx end, unsigned int nb_threads)
returns a vector equally splitting elements of a range among threads
Definition threads.cpp:76
Wrappers for OpenMP.
C++17 STL threads convenience utilities for aGrUM.