aGrUM  0.16.0
multiDimContainer.h
Go to the documentation of this file.
1 
30 #ifndef GUM_MULTIDIM_CONTAINER_H
31 #define GUM_MULTIDIM_CONTAINER_H
32 
33 #include <functional>
34 #include <initializer_list>
35 #include <iostream>
36 #include <vector>
37 
38 #include <agrum/agrum.h>
39 #include <agrum/core/math/math.h>
40 
42 
43 namespace gum {
44  // needed for content()
45  template < typename GUM_SCALAR >
47 
48  // ==========================================================================
49  // === GUM_MULTI_DIM ===
50  // ==========================================================================
92  template < typename GUM_SCALAR >
94  public:
95  // =========================================================================
97  // =========================================================================
99 
104 
110 
112 
117 
119 
123  virtual ~MultiDimContainer();
124 
126  // =========================================================================
128  // =========================================================================
130 
140  virtual void set(const Instantiation& i, const GUM_SCALAR& value) const;
141 
152  virtual GUM_SCALAR get(const Instantiation& i) const;
153 
164  GUM_SCALAR operator[](const Instantiation& i) const;
165 
170  virtual void fill(const GUM_SCALAR& d) const = 0;
171 
190  virtual void populate(const std::vector< GUM_SCALAR >& v) const;
191 
210  virtual void populate(std::initializer_list< GUM_SCALAR > l) const;
211 
213  // =========================================================================
215  // =========================================================================
217 
230  virtual void copyFrom(const MultiDimContainer< GUM_SCALAR >& src) const;
231 
246  virtual void copyFrom(const MultiDimContainer< GUM_SCALAR >& src,
247  Instantiation* p_i) const;
248 
260  virtual void extractFrom(const MultiDimContainer< GUM_SCALAR >& src,
261  const Instantiation& mask);
262 
266  virtual const MultiDimImplementation< GUM_SCALAR >* content() const = 0;
267 
272 
278  virtual MultiDimAdressable& getMasterRef();
279 
285  virtual const MultiDimAdressable& getMasterRef() const;
286 
287 
294  virtual void copy(const MultiDimContainer< GUM_SCALAR >& src);
295 
314  virtual MultiDimContainer< GUM_SCALAR >* newFactory() const = 0;
315 
317  // =========================================================================
319  // =========================================================================
321 
326  virtual const std::string toString() const;
327 
332  virtual const std::string toString(const Instantiation* i) const = 0;
333 
339  bool operator==(const MultiDimContainer< GUM_SCALAR >& p) const;
340 
346  bool operator!=(const MultiDimContainer< GUM_SCALAR >& p) const;
347 
352  virtual void apply(std::function< GUM_SCALAR(GUM_SCALAR) > f) const;
353 
359  virtual GUM_SCALAR
360  reduce(std::function< GUM_SCALAR(GUM_SCALAR, GUM_SCALAR) > f,
361  GUM_SCALAR base) const;
362 
363 
365  // =========================================================================
367  // =========================================================================
369 
377  virtual void beginMultipleChanges() = 0;
378 
383  virtual void endMultipleChanges() = 0;
384 
389  virtual void endMultipleChanges(const GUM_SCALAR& v) = 0;
390 
392 
393  protected:
407  virtual GUM_SCALAR& _get(const Instantiation& i) const = 0;
408  };
409 } /* namespace gum */
410 
412 
413 #endif /* GUM_MULTIDIM_CONTAINER_H */
virtual void endMultipleChanges()=0
Call this method after doing important changes in this MultiDimContainer.
Copyright 2005-2019 Pierre-Henri WUILLEMIN et Christophe GONZALES (LIP6) {prenom.nom}_at_lip6.fr.
virtual ~MultiDimContainer()
Destructor.
virtual GUM_SCALAR & _get(const Instantiation &i) const =0
Return a data, given a Instantiation.
virtual const std::string toString() const
Returns a representation of this MultiDimContainer.
Copyright 2005-2019 Pierre-Henri WUILLEMIN et Christophe GONZALES (LIP6) {prenom.nom}_at_lip6.fr.
Definition: agrum.h:25
Abstract base class for all multi dimensionnal containers.
virtual void copy(const MultiDimContainer< GUM_SCALAR > &src)
Removes all variables in this MultiDimContainer and copy the content of src, variables included...
virtual void beginMultipleChanges()=0
Call this method before doing important changes in this MultiDimContainer.
virtual GUM_SCALAR reduce(std::function< GUM_SCALAR(GUM_SCALAR, GUM_SCALAR) > f, GUM_SCALAR base) const
compute lfold for this container
Copyright 2005-2019 Pierre-Henri WUILLEMIN et Christophe GONZALES (LIP6) {prenom.nom}_at_lip6.fr.
bool operator!=(const MultiDimContainer< GUM_SCALAR > &p) const
Test if this MultiDimContainer is different of p.
virtual MultiDimContainer< GUM_SCALAR > * newFactory() const =0
Creates an empty clone of this MultiDimContainer.
virtual void copyFrom(const MultiDimContainer< GUM_SCALAR > &src) const
Basic copy of a MultiDimContainer.
virtual const MultiDimImplementation< GUM_SCALAR > * content() const =0
Returns the implementation for this object (may be *this).
Abstract base class for all multi dimensionnal addressable.
Class for assigning/browsing values to tuples of discrete variables.
Definition: instantiation.h:83
GUM_SCALAR operator[](const Instantiation &i) const
An [] operator using a Instantiation as argument.
MultiDimContainer()
Default constructor.
<agrum/multidim/multiDimImplementation.h>
virtual void fill(const GUM_SCALAR &d) const =0
Fill the table with d.
virtual void apply(std::function< GUM_SCALAR(GUM_SCALAR) > f) const
Apply a function on every element of the container.
bool operator==(const MultiDimContainer< GUM_SCALAR > &p) const
Test if this MultiDimContainer is equal to p.
Copyright 2005-2019 Pierre-Henri WUILLEMIN et Christophe GONZALES (LIP6) {prenom.nom}_at_lip6.fr.
virtual MultiDimAdressable & getMasterRef()
In order to insure the dereference for decorators, we need to virtualize the access to master pointer...
virtual void populate(const std::vector< GUM_SCALAR > &v) const
Automatically fills this MultiDimContainer with the values in v.
virtual void extractFrom(const MultiDimContainer< GUM_SCALAR > &src, const Instantiation &mask)
Basic extraction of a MultiDimContainer.
MultiDimContainer & operator=(const MultiDimContainer< GUM_SCALAR > &src)
Default constructor.