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