aGrUM 2.3.2
a C++ library for (probabilistic) graphical models
IBayesNetGenerator.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
41
48#ifndef GUM_I_BAYES_NET_GENERATOR_H
49#define GUM_I_BAYES_NET_GENERATOR_H
50
51#include <climits>
52#include <cstdio>
53#include <cstdlib>
54#include <iostream>
55#include <vector>
56
57#include <agrum/agrum.h>
58
61#include <agrum/BN/BayesNet.h>
63
64namespace gum {
65
80 template < typename GUM_SCALAR, template < typename > class ICPTGenerator >
81 class IBayesNetGenerator: public ICPTGenerator< GUM_SCALAR > {
82 public:
83 // ############################################################################
85 // ############################################################################
87
101
105
106 virtual ~IBayesNetGenerator();
108
109 // ############################################################################
111 // ############################################################################
113
119
120 virtual void generateBN(BayesNet< GUM_SCALAR >& bayesNet) = 0;
121
122 void fromDAG(BayesNet< GUM_SCALAR >& bayesNet);
129
130 void fillCPT(BayesNet< GUM_SCALAR >& bn) const;
131
133 // ===========================================================================
135 // ===========================================================================
137
140
145 Size nbrNodes() const;
146
151 Size maxArcs() const;
152
157 Size maxModality() const;
158
162
163 // void setcptGenerator(CPTGenerator * cptGenerator);
168
172 void setMaxArcs(Size maxArcs);
173
178
180
181 protected:
182 // The Conditional Probability Table generator
183 // CPTGenerator * cptGenerator_;
188 };
189
190} /* namespace gum */
191
193
194#endif /* GUM_I_BAYES_NET_GENERATOR_H */
algorithm for KL divergence between BNs
Class representing Bayesian networks.
Source implementation of IBayesNetGenerator.
Base class for dag.
Definition DAG.h:121
void setMaxArcs(Size maxArcs)
Modifies the value of the number of nodes imposed on the BayesGenerator.
void setNbrNodes(Size nbrNodes)
Modifies the value of the number of nodes imposed on the BayesGenerator.
void fromDAG(BayesNet< GUM_SCALAR > &bayesNet)
Virtual function that Generates a Bayesian networks.
Size maxModality() const
Return a constant reference to the maximum modality imposed on the IBayesNetGenerator.
void setMaxModality(Size maxModality)
Modifies the value of the number of nodes imposed on the BayesGenerator.
Size nbrNodes() const
Return a constant reference to the number of nodes imposed on the IBayesNetGenerator.
void fillCPT(BayesNet< GUM_SCALAR > &bn) const
function that insert random values in the CPT of each nodes according to the CPTGenerator.
virtual ~IBayesNetGenerator()
Destructor.
Size maxArcs() const
Return a constant reference to the maximum number of arcs imposed on the IBayesNetGenerator.
IBayesNetGenerator(Size nbrNodes, Size maxArcs, Size maxModality)
constructor.
virtual void generateBN(BayesNet< GUM_SCALAR > &bayesNet)=0
Virtual function that Generates a Bayesian networks.
std::size_t Size
In aGrUM, hashed values are unsigned long int.
Definition types.h:74
Base class for labelized discrete random variables.
gum is the global namespace for all aGrUM entities
Definition agrum.h:46
Abstract class for generating Conditional Probability Tables.