aGrUM  0.20.3
a C++ library for (probabilistic) graphical models
IDReader.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 Definition of abstract classes for import of Influence Diagram from a
25  *file
26  *
27  * All classes used to import an influence diagram from a file must inherit from
28  *IDReader
29  *
30  * @author Pierre-Henri WUILLEMIN(@LIP6) and Jean-Christophe MAGNAN and Christophe
31  *GONZALES(@AMU)
32  */
33 #ifndef GUM_ID_READER_H
34 #define GUM_ID_READER_H
35 
36 #include <agrum/ID/influenceDiagram.h>
37 #include <agrum/agrum.h>
38 #include <iostream>
39 #include <string>
40 
41 namespace gum {
42 
43  /**
44  * @class IDReader
45  * @brief Pure virtual class for importing an ID from a file.
46  * @ingroup id_group
47  *
48  * All classes used to read an influence diagram from
49  * a file must inherit from this class
50  */
51  template < typename GUM_SCALAR >
52  class IDReader {
53  public:
54  /**
55  * Constructor
56  * A reader is created to reading a defined file.
57  * Note that an ID as to be created before and given in parameter.
58  */
59  IDReader(InfluenceDiagram< GUM_SCALAR >* infdiag, const std::string& filePath);
60 
61  /**
62  * Default destructor.
63  */
64  virtual ~IDReader();
65 
66  /**
67  * Reads the influence diagram from the file referenced by filePath given
68  * at the
69  * creation of class
70  * @return Returns the number of error during the parsing (0 if none).
71  */
72  virtual void proceed() = 0;
73  };
74 
75 } /* namespace gum */
76 
77 #include "IDReader_tpl.h"
78 
79 #endif // GUM_ID_READER_H