aGrUM  0.20.3
a C++ library for (probabilistic) graphical models
evidenceMNInference.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  * @brief This file contains the abstract class definition for computing
25  * the probability of evidence entered in Markov networks
26  *
27  * @author Christophe GONZALES(@AMU) and Pierre-Henri WUILLEMIN(@LIP6)
28  */
29 
30 #ifndef GUM_MARKOV_NET_EVIDENCE_INFERENCE_H
31 #define GUM_MARKOV_NET_EVIDENCE_INFERENCE_H
32 
33 #include <agrum/MN/inference/tools/MarkovNetInference.h>
34 #include <agrum/agrum.h>
35 
36 
37 namespace gum {
38 
39 
40  /**
41  * @class EvidenceMNInference evidenceMNInference.h
42  * <agrum/MN/inference/evidenceMNInference.h>
43  * @brief A generic class for the computation of the probability of
44  * evidence entered in Markov networks
45  * @ingroup mn_group
46  *
47  * The goal of this class is to provide an interface for the computation
48  * of the probability of evidence entered in Markov networks
49  */
50  template < typename GUM_SCALAR >
52  public:
53  // ############################################################################
54  /// @name Constructors / Destructors
55  // ############################################################################
56  /// @{
57 
58  /// default constructor
59  /** @warning note that, by aGrUM's rule, the MN is not copied but only
60  * referenced by the inference algorithm. */
61  explicit EvidenceMNInference(const IMarkovNet< GUM_SCALAR >* mn);
62 
63  /// destructor
64  virtual ~EvidenceMNInference();
65 
66  /// @}
67 
68 
69  // ############################################################################
70  /// @name Probability computations
71  // ############################################################################
72  /// @{
73 
74  /// returns the probability P(e) of the evidence entered into the MN
75  virtual GUM_SCALAR evidenceProbability() = 0;
76 
77  /// @}
78  };
79 
80 
81 } // namespace gum
82 
83 
84 #include <agrum/MN/inference/tools/evidenceMNInference_tpl.h>
85 
86 
87 #endif // GUM_MARKOV_NET_EVIDENCE_INFERENCE_H
virtual ~EvidenceMNInference()
destructor
EvidenceMNInference(const IMarkovNet< GUM_SCALAR > *mn)
default constructor
INLINE void emplace(Args &&... args)
Definition: set_tpl.h:643
<agrum/MN/inference/evidenceMNInference.h>
virtual GUM_SCALAR evidenceProbability()=0
returns the probability P(e) of the evidence entered into the MN