aGrUM 2.3.2
a C++ library for (probabilistic) graphical models
scheduledInference_inl.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#pragma once
41
42
44
45namespace gum {
46
47 // returns the current scheduler
53
54 // sets the number max of threads that can be used
59
60 // sets an upper bound on the memory consumption admissible
61 INLINE void ScheduledInference::setMaxMemory(double megabytes) {
62 if (megabytes < 0.0) megabytes = 0.0;
63 _scheduler_parallel_.setMaxMemory(megabytes);
64 _scheduler_sequential_.setMaxMemory(megabytes);
65 }
66
67 // returns the Max memory (in megabytes) available for executing schedules
68 INLINE double ScheduledInference::maxMemory() const { return _scheduler_parallel_.maxMemory(); }
69
70} /* namespace gum */
SchedulerParallel _scheduler_parallel_
void setMaxMemory(double megabytes)
sets an upper bound on the memory consumption admissible
Scheduler & scheduler() const
returns the current scheduler
SchedulerSequential _scheduler_sequential_
void setNumberOfThreads(Size nb) final
sets the number max of threads that can be used
virtual double maxMemory() const
returns the Max memory (in megabytes) available for executing schedules
A scheduler that executes available operators in parallel.
The common interface of all the schedulers.
Definition scheduler.h:71
virtual Size getNumberOfThreads() const
returns the current max number of threads used by the class containing this ThreadNumberManager
virtual void setNumberOfThreads(Size nb)
sets the number max of threads to be used by the class containing this ThreadNumberManager
std::size_t Size
In aGrUM, hashed values are unsigned long int.
Definition types.h:74
gum is the global namespace for all aGrUM entities
Definition agrum.h:46
The class enabling flexible inferences using schedules.