aGrUM  0.14.2
loopySamplingInference.h
Go to the documentation of this file.
1 /***************************************************************************
2  * Copyright (C) 2005 by Pierre-Henri WUILLEMIN et Christophe GONZALES *
3  * {prenom.nom}_at_lip6.fr *
4  * *
5  * This program is free software; you can redistribute it and/or modify *
6  * it under the terms of the GNU General Public License as published by *
7  * the Free Software Foundation; either version 2 of the License, or *
8  * (at your option) any later version. *
9  * *
10  * This program is distributed in the hope that it will be useful, *
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of *
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
13  * GNU General Public License for more details. *
14  * *
15  * You should have received a copy of the GNU General Public License *
16  * along with this program; if not, write to the *
17  * Free Software Foundation, Inc., *
18  * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
19  ***************************************************************************/
29 #ifndef GUM_LOOPY_INFERENCE_H
30 #define GUM_LOOPY_INFERENCE_H
37 
38 namespace gum {
39 
55  template < typename GUM_SCALAR, template < typename > class APPROX >
56  class LoopySamplingInference : public APPROX< GUM_SCALAR > {
57  public:
62 
66  virtual ~LoopySamplingInference();
67 
70  virtual void _makeInference();
71 
72  void setVirtualLBPSize(GUM_SCALAR vlbpsize) {
73  if (vlbpsize > 0) _virtualLBPSize = vlbpsize;
74  };
75 
76  protected:
77  GUM_SCALAR _virtualLBPSize;
78  };
79 
80 #ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
81 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
82 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
83 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
84 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
85 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
86 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
87 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
89 # endif
90 # endif
91 # endif
92 # endif
93 # endif
94 # endif
95 # endif
96 #endif
97 #ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
98 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
99 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
100 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
101 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
102 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
103 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
104 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
106 # endif
107 # endif
108 # endif
109 # endif
110 # endif
111 # endif
112 # endif
113 #endif
114 
115 #ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
116 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
117 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
118 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
119 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
120 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
121 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
122 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
124 # endif
125 # endif
126 # endif
127 # endif
128 # endif
129 # endif
130 # endif
131 #endif
132 #ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
133 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
134 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
135 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
136 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
137 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
138 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
139 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
141 # endif
142 # endif
143 # endif
144 # endif
145 # endif
146 # endif
147 # endif
148 #endif
149 
150 #ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
151 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
152 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
153 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
154 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
155 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
156 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
157 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
159 # endif
160 # endif
161 # endif
162 # endif
163 # endif
164 # endif
165 # endif
166 #endif
167 #ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
168 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
169 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
170 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
171 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
172 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
173 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
174 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
176 # endif
177 # endif
178 # endif
179 # endif
180 # endif
181 # endif
182 # endif
183 #endif
184 
185 #ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
186 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
187 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
188 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
189 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
190 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
191 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
192 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
194 # endif
195 # endif
196 # endif
197 # endif
198 # endif
199 # endif
200 # endif
201 #endif
202 #ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
203 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
204 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
205 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
206 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
207 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
208 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
209 # ifndef GUM_NO_EXTERN_TEMPLATE_CLASS
211 # endif
212 # endif
213 # endif
214 # endif
215 # endif
216 # endif
217 # endif
218 #endif
219 
220  template < typename GUM_SCALAR >
223  template < typename GUM_SCALAR >
224  using HybridWeightedSampling =
226  template < typename GUM_SCALAR >
229  template < typename GUM_SCALAR >
231 } // namespace gum
232 
234 #endif
This file contains general methods for approximate inference.
This file contains Monte Carlo sampling class definition.
Class representing the minimal interface for Bayesian Network.
Definition: IBayesNet.h:59
gum is the global namespace for all aGrUM entities
Definition: agrum.h:25
This file contains the abstract inference class definition for computing (incrementally) marginal pos...
This file contains Weighted sampling class definition.
virtual ~LoopySamplingInference()
destructor
This file contains Importance sampling class definition.
This file contains Gibbs sampling class definition.
virtual void _makeInference()
makes the inference by generating samples w.r.t the mother class&#39; sampling method after initalizing e...
LoopySamplingInference(const IBayesNet< GUM_SCALAR > *bn)
Default constructor.
<agrum/BN/inference/loopySamplingInference.h>
void setVirtualLBPSize(GUM_SCALAR vlbpsize)
Implements approximate inference algorithms from Loopy Belief Propagation.