aGrUM 2.3.2
a C++ library for (probabilistic) graphical models
multiDimCombination_tpl.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
49
50#ifndef DOXYGEN_SHOULD_SKIP_THIS
51
52# include <agrum/agrum.h>
53
54namespace gum {
55
56 // Constructor
57 template < class TABLE >
59 GUM_CONSTRUCTOR(MultiDimCombination);
60 }
61
62 // Copy constructor
63 template < class TABLE >
65 GUM_CONS_CPY(MultiDimCombination);
66 }
67
68 // Destructor
69 template < class TABLE >
71 GUM_DESTRUCTOR(MultiDimCombination);
72 }
73
74 // add to a given schedule the set of operations needed to perform the combination
75 template < class TABLE >
78 const std::vector< const IScheduleMultiDim* >& set,
79 const bool is_result_persistent) const {
80 // compute the set of operations and store it into the schedule
81 auto ops_plus_res = operations(set, false);
82 for (const auto op: ops_plus_res.first) {
83 schedule.insertOperation(*op);
84 }
85
86 // get the result of the schedule and, if required, make it persistent in the
87 // operation that created it
88 const IScheduleMultiDim* table = schedule.scheduleMultiDim(ops_plus_res.second->id());
89 if (is_result_persistent) {
90 const auto creating_op = schedule.scheduleMultiDimCreator(table);
91 if (creating_op != nullptr) {
92 const_cast< ScheduleOperator* >(creating_op)->makeResultsPersistent(true);
93 }
94 }
95
96 // free the operations: they are no more necessary since we already copied
97 // them into the schedule
98 for (auto op: ops_plus_res.first)
99 delete op;
100
101 return table;
102 }
103
104 // add to a given schedule the set of operations needed to perform the combination
105 template < class TABLE >
106 INLINE const IScheduleMultiDim*
109 const bool is_result_persistent) const {
110 std::vector< const IScheduleMultiDim* > vect;
111 vect.reserve(set.size());
112 for (const auto elt: set) {
113 vect.push_back(elt);
114 }
115 return this->schedule(schedule, vect, is_result_persistent);
116 }
117
118
119} /* namespace gum */
120
121#endif /* DOXYGEN_SHOULD_SKIP_THIS */
The Table-agnostic base class of scheduleMultiDim.
A generic interface to combine efficiently several MultiDim tables.
virtual ~MultiDimCombination()
destructor
MultiDimCombination()
default constructor
const IScheduleMultiDim * schedule(Schedule &schedule, const Set< const IScheduleMultiDim * > &set, const bool is_result_persistent=false) const
add to a given schedule the set of operations needed to perform the combination
the base class for "low-level" operators used to schedule inferences
Class containing a schedule of operations to perform on multidims.
Definition schedule.h:80
Representation of a set.
Definition set.h:131
gum is the global namespace for all aGrUM entities
Definition agrum.h:46