aGrUM  0.21.0
a C++ library for (probabilistic) graphical models
projectionPattern4MultiDimImplementation.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  *
25  * @brief the pattern used by all the MultiDimImplementation projections
26  *
27  * @author Christophe GONZALES(@AMU) and Pierre-Henri WUILLEMIN(@LIP6)
28  */
29 
30 // check if we allowed these patterns to be used
31 #ifndef GUM_PROJECTION_PATTERN_ALLOWED
32 
33 // #warning To use projectionPattern4MultiDimImplementation.h, you must define
34 // GUM_PROJECTION_PATTERN_ALLOWED
35 
36 #else
37 
38 namespace gum {
39 
40 # ifdef GUM_MULTI_DIM_PROJECTION_NAME
41  template < typename GUM_SCALAR >
42  MultiDimImplementation< GUM_SCALAR >*
43  GUM_MULTI_DIM_PROJECTION_NAME(const MultiDimImplementation< GUM_SCALAR >& ttable,
44  const Set< const DiscreteVariable* >& del_vars) {
45 # endif
46 
47  typename ProjectionRegister4MultiDim< GUM_SCALAR >::ProjectionPtr func;
48 
49  // get the appropriate function to perform the operation
50  try {
51  // try to find func(ttable,del_vars) in the register
52  func = ProjectionRegister4MultiDim< GUM_SCALAR >::Register().get(
53  GUM_MULTI_DIM_PROJECTION_FUNC_NAME,
54  ttable.name());
55  } catch (NotFound&) {
56  func = ProjectionRegister4MultiDim< GUM_SCALAR >::Register().get(
57  GUM_MULTI_DIM_PROJECTION_FUNC_NAME,
58  ttable.basename());
59  }
60 
61  // perform the projection
62  return func(&ttable, del_vars);
63  }
64 } // namespace gum
65 #endif /* GUM_PROJECTION_PATTERN_ALLOWED */