aGrUM  0.20.3
a C++ library for (probabilistic) graphical models
gum::Potential< GUM_SCALAR > Class Template Reference

aGrUM's Potential is a multi-dimensional array with tensor operators. More...

#include <agrum/tools/multidim/potential.h>

+ Inheritance diagram for gum::Potential< GUM_SCALAR >:
+ Collaboration diagram for gum::Potential< GUM_SCALAR >:

Public Member Functions

Constructors, Destructors and Copy
 Potential ()
 Default constructor. More...
 
 Potential (MultiDimImplementation< GUM_SCALAR > *aContent)
 Creates an potential around aContent. More...
 
 Potential (MultiDimImplementation< GUM_SCALAR > *aContent, const MultiDimContainer< GUM_SCALAR > &src)
 Copy constructor. More...
 
 Potential (const Potential< GUM_SCALAR > &src)
 Copy constructor & assignment. More...
 
Potential< GUM_SCALAR > & operator= (const Potential< GUM_SCALAR > &src)
 Default constructor. More...
 
 Potential (Potential< GUM_SCALAR > &&from)
 move constructor & assignement More...
 
Potential< GUM_SCALAR > & operator= (Potential< GUM_SCALAR > &&src)
 Default constructor. More...
 
 ~Potential ()
 Destructor. More...
 
MultiDimContainer implementation
virtual Potential< GUM_SCALAR > * newFactory () const
 Default implementation of MultiDimContainer::set(). More...
 
Class operation for Potential instances
const Potential< GUM_SCALAR > & random () const
 generate a random Potential with each parameter in [0,1] More...
 
const Potential< GUM_SCALAR > & randomDistribution () const
 generate a random Distribution in the Potential More...
 
const Potential< GUM_SCALAR > & randomCPT () const
 generate a random CPT in the Potential More...
 
const Potential< GUM_SCALAR > & noising (GUM_SCALAR alpha) const
 add a noise in a CPT by mixing (1-alpha)this+alpha.randomCPT() More...
 
Potential< GUM_SCALAR > margSumOut (const Set< const DiscreteVariable * > &del_vars) const
 Projection using sum as operation (and implementation-optimized operations) More...
 
Potential< GUM_SCALAR > margSumIn (const Set< const DiscreteVariable * > &kept_vars) const
 Projection using sum as operation (and implementation-optimized operations) More...
 
Potential< GUM_SCALAR > margProdOut (const Set< const DiscreteVariable * > &del_vars) const
 Projection using multiplication as operation (and implementation-optimized operations) More...
 
Potential< GUM_SCALAR > margProdIn (const Set< const DiscreteVariable * > &kept_vars) const
 Projection using multiplication as operation (and implementation-optimized operations) More...
 
Potential< GUM_SCALAR > margMinOut (const Set< const DiscreteVariable * > &del_vars) const
 Projection using min as operation (and implementation-optimized operations) More...
 
Potential< GUM_SCALAR > margMinIn (const Set< const DiscreteVariable * > &kept_vars) const
 Projection using min as operation (and implementation-optimized operations) More...
 
Potential< GUM_SCALAR > margMaxOut (const Set< const DiscreteVariable * > &del_vars) const
 Projection using max as operation (and implementation-optimized operations) More...
 
Potential< GUM_SCALAR > margMaxIn (const Set< const DiscreteVariable * > &kept_vars) const
 Projection using max as operation (and implementation-optimized operations) More...
 
Potential< GUM_SCALAR > isNonZeroMap () const
 create a boolean-like potential using the predicate isNonZero More...
 
GUM_SCALAR sum () const
 sum of all elements in the Potential More...
 
GUM_SCALAR product () const
 product of all elements in the Potential More...
 
GUM_SCALAR max () const
 max of all elements in the Potential More...
 
GUM_SCALAR min () const
 min of all elements in the Potential More...
 
GUM_SCALAR maxNonOne () const
 max of all non one elements in the Potential More...
 
GUM_SCALAR minNonZero () const
 min of all non zero elements in the Potential More...
 
Set< InstantiationfindAll (GUM_SCALAR v) const
 set of instantiation corresponding to the parameter v in the Potential More...
 
Set< Instantiationargmax () const
 set of instantiation corresponding to the max in the Potential More...
 
Set< Instantiationargmin () const
 set of instantiation corresponding to the min in the Potential More...
 
GUM_SCALAR entropy () const
 entropy of the Potential More...
 
Potential< GUM_SCALAR > reorganize (const std::vector< const DiscreteVariable * > &vars) const
 create a new Potential with another order More...
 
Potential< GUM_SCALAR > reorganize (const std::vector< std::string > &vars) const
 create a new Potential with another order More...
 
Potential< GUM_SCALAR > extract (const Instantiation &inst) const
 create a new Potential extracted from *this given a partial instantiation More...
 
Potential< GUM_SCALAR > putFirst (const DiscreteVariable *var) const
 create a new Potential with a certain variable in first More...
 
Potential< GUM_SCALAR > putFirst (const std::string &varname) const
 create a new Potential with a certain variable in first More...
 
const Potential< GUM_SCALAR > & fillWith (const Potential< GUM_SCALAR > &src) const
 copy a Potential data using name of variables and labels (not necessarily the same variables in the same orders) More...
 
const Potential< GUM_SCALAR > & fillWith (const Potential< GUM_SCALAR > &src, const std::vector< std::string > &mapSrc) const
 copy a Potential data using the sequence of names in mapSrc to find the corresponding variables. More...
 
const Potential< GUM_SCALAR > & fillWith (const std::vector< GUM_SCALAR > &data) const
 Automatically fills the potential with the values in v. More...
 
const Potential< GUM_SCALAR > & fillWith (const GUM_SCALAR &val) const
 Automatically fills this MultiDimContainer with the value v. More...
 
const Potential< GUM_SCALAR > & abs () const
 Apply abs on every element of the container. More...
 
const Potential< GUM_SCALAR > & sq () const
 apply $x^2$ on every element of the container More...
 
const Potential< GUM_SCALAR > & log2 () const
 apply $log_2(x)$ on every element of the container More...
 
const Potential< GUM_SCALAR > new_abs () const
 Create a new potential and apply abs on every element of the container. More...
 
const Potential< GUM_SCALAR > new_sq () const
 Create a new potential and apply $x^2$ on every element of the container. More...
 
const Potential< GUM_SCALAR > new_log2 () const
 Create a new potential and apply $log_2(x)$ on every element of the container. More...
 
const Potential< GUM_SCALAR > & normalize () const
 normalisation of this do nothing if sum is 0 More...
 
GUM_SCALAR KL (const Potential< GUM_SCALAR > &p) const
 compute KL divergence between this and p Checks the compatibility and then compute KL divergence More...
 
const Potential< GUM_SCALAR > & normalizeAsCPT (const Idx &varId=0) const
 normalisation of this as a CPT for the variable varId More...
 
const Potential< GUM_SCALAR > & scale (GUM_SCALAR v) const
 multiply (each value of) *this by v More...
 
const Potential< GUM_SCALAR > & translate (GUM_SCALAR v) const
 add v to (each value of) *this More...
 
const Potential< GUM_SCALAR > & inverse (void) const
 the function to inverse (each value of) *this More...
 
Idx draw () const
 get a value at random from a 1-D distribution More...
 
Potential algebra operators
Potential< GUM_SCALAR > operator+ (const Potential< GUM_SCALAR > &p2) const
 the function to be used to add two Potentials More...
 
Potential< GUM_SCALAR > operator+ (const GUM_SCALAR &v) const
 the function to be used to add a GUM_SCALAR to a Potential More...
 
Potential< GUM_SCALAR > operator- (const Potential< GUM_SCALAR > &p2) const
 the function to be used to subtract two Potentials More...
 
Potential< GUM_SCALAR > operator- (const GUM_SCALAR &v) const
 the function to be used to substract a GUM_SCALAR from a Potential More...
 
Potential< GUM_SCALAR > operator* (const Potential< GUM_SCALAR > &p2) const
 the function to be used to multiply two Potentials More...
 
Potential< GUM_SCALAR > operator* (const GUM_SCALAR &v) const
 the function to be used to multiply a Potential and a scalar More...
 
Potential< GUM_SCALAR > operator/ (const Potential< GUM_SCALAR > &p2) const
 the function to be used to divide two Potentials More...
 
Potential< GUM_SCALAR > operator/ (const GUM_SCALAR &v) const
 the function to be used to divide a Potential by a scalar More...
 
Potential< GUM_SCALAR > & operator+= (const Potential< GUM_SCALAR > &r)
 the function to be used to add two Potentials More...
 
Potential< GUM_SCALAR > & operator+= (const GUM_SCALAR &v)
 the function to be used to add two Potentials More...
 
Potential< GUM_SCALAR > & operator*= (const Potential< GUM_SCALAR > &r)
 the function to be used to add two Potentials More...
 
Potential< GUM_SCALAR > & operator*= (const GUM_SCALAR &v)
 the function to be used to add two Potentials More...
 
Potential< GUM_SCALAR > & operator-= (const Potential< GUM_SCALAR > &r)
 the function to be used to add two Potentials More...
 
Potential< GUM_SCALAR > & operator-= (const GUM_SCALAR &v)
 the function to be used to add two Potentials More...
 
Potential< GUM_SCALAR > & operator/= (const Potential< GUM_SCALAR > &r)
 the function to be used to add two Potentials More...
 
Potential< GUM_SCALAR > & operator/= (const GUM_SCALAR &v)
 the function to be used to add two Potentials More...
 
bool operator== (const Potential< GUM_SCALAR > &r) const
 the function to be used to add two Potentials More...
 
bool operator!= (const Potential< GUM_SCALAR > &r) const
 the function to be used to add two Potentials More...
 
Potential< GUM_SCALAR > & operator<< (const DiscreteVariable &v)
 the function to be used to add two Potentials More...
 
virtual std::string toString () const
 the function to be used to add two Potentials More...
 
MultiDimInterface implementation
virtual Idx nbrDim () const final
 Returns the number of vars in the multidimensional container. More...
 
virtual Size domainSize () const final
 Returns the product of the variables domain size. More...
 
virtual void add (const DiscreteVariable &v) final
 Adds a new var to the variables of the multidimensional matrix. More...
 
virtual void erase (const DiscreteVariable &var) final
 Removes a var from the variables of the multidimensional matrix. More...
 
virtual void erase (const std::string &name) final
 
virtual const Sequence< const DiscreteVariable *> & variablesSequence () const final
 Returns a const ref to the sequence of DiscreteVariable*. More...
 
virtual const DiscreteVariablevariable (Idx) const final
 Returns a const ref to the ith var. More...
 
virtual const DiscreteVariablevariable (const std::string &name) const final
 Returns the variable with the name. More...
 
virtual Idx pos (const DiscreteVariable &var) const final
 Returns the index of a variable. More...
 
virtual bool contains (const DiscreteVariable &var) const final
 Returns true if var is in *this. More...
 
virtual bool empty () const final
 Returns true if no var is in *this. More...
 
MultiDimAddressable implementation
virtual bool unregisterSlave (Instantiation &i) final
 Unregister i as a slave of this MultiDimAdressable. More...
 
virtual bool registerSlave (Instantiation &i) final
 Register i as a slave of this MultiDimAdressable. More...
 
virtual void changeNotification (const Instantiation &i, const DiscreteVariable *const var, Idx oldval, Idx newval) final
 Listen to changes in a given Instantiation. More...
 
virtual void setChangeNotification (const Instantiation &i) final
 Listen to an assignment of a value in a Instantiation. More...
 
virtual void setFirstNotification (const Instantiation &i) final
 Listen to setFirst in a given Instantiation. More...
 
virtual void setLastNotification (const Instantiation &i) final
 Listen to setLast in a given Instantiation. More...
 
virtual void setIncNotification (const Instantiation &i) final
 Listen to increment in a given Instantiation. More...
 
virtual void setDecNotification (const Instantiation &i) final
 Listen to increment in each recorded Instantiation. More...
 
virtual void notifyChange () const final
 
MultiDimContainer implementation
virtual void set (const Instantiation &i, const GUM_SCALAR &value) const final
 Default implementation of MultiDimContainer::set(). More...
 
virtual GUM_SCALAR get (const Instantiation &i) const final
 Default implementation of MultiDimContainer::get(). More...
 
virtual void fill (const GUM_SCALAR &d) const final
 Default implementation of MultiDimContainer::set(). More...
 
virtual void populate (const std::vector< GUM_SCALAR > &v) const final
 Automatically fills this MultiDimContainer with the values in v. More...
 
virtual void apply (std::function< GUM_SCALAR(GUM_SCALAR) > f) const final
 Apply a function on every element of the container. More...
 
virtual GUM_SCALAR reduce (std::function< GUM_SCALAR(GUM_SCALAR, GUM_SCALAR) > f, GUM_SCALAR base) const final
 compute lfold for this container More...
 
virtual void beginMultipleChanges () final
 Default implementation of MultiDimContainer::set(). More...
 
virtual void endMultipleChanges () final
 Default implementation of MultiDimContainer::set(). More...
 
virtual void endMultipleChanges (const GUM_SCALAR &) final
 Default implementation of MultiDimContainer::set(). More...
 
virtual std::string toString (const Instantiation *i) const
 Default implementation of MultiDimContainer::set(). More...
 
Accessors / Modifiers
virtual void populate (std::initializer_list< GUM_SCALAR > l) const
 Automatically fills this MultiDimContainer with the values in l. More...
 
GUM_SCALAR operator[] (const Instantiation &i) const
 An [] operator using a Instantiation as argument. More...
 
Various methods.
virtual const MultiDimImplementation< GUM_SCALAR > * content () const final
 Returns the implementation for this object (may be *this). More...
 
virtual MultiDimImplementation< GUM_SCALAR > * content () final
 Returns the implementation for this object (may be *this). More...
 
Copy methods.
virtual void copyFrom (const MultiDimContainer< GUM_SCALAR > &src) const
 Basic copy of a MultiDimContainer. More...
 
virtual void copyFrom (const MultiDimContainer< GUM_SCALAR > &src, Instantiation *p_i) const
 Basic copy of a MultiDimContainer. More...
 
virtual void extractFrom (const MultiDimContainer< GUM_SCALAR > &src, const Instantiation &mask)
 Basic extraction of a MultiDimContainer. More...
 
virtual MultiDimAdressablegetMasterRef ()
 In order to insure the dereference for decorators, we need to virtualize the access to master pointer. More...
 
virtual const MultiDimAdressablegetMasterRef () const
 In order to insure the dereference for decorators, we need to virtualize the access to master pointer. More...
 
virtual void copy (const MultiDimContainer< GUM_SCALAR > &src)
 Removes all variables in this MultiDimContainer and copy the content of src, variables included. More...
 
Various methods.
bool operator== (const MultiDimContainer< GUM_SCALAR > &p) const
 Test if this MultiDimContainer is equal to p. More...
 
bool operator!= (const MultiDimContainer< GUM_SCALAR > &p) const
 Test if this MultiDimContainer is different of p. More...
 
Accessors / Modifiers
void replace (const DiscreteVariable &x, const DiscreteVariable &y)
 Replace variables in this multidim. More...
 

Protected Attributes

MultiDimImplementation< GUM_SCALAR > * content_
 The true container. More...
 
GUM_SCALAR empty_value_
 value of the MultiDimDecorator if no dimension. More...
 

Protected Member Functions

Set< const DiscreteVariable *> complementVars_ (const Set< const DiscreteVariable * > &del_vars) const
 
virtual void replace_ (const DiscreteVariable *x, const DiscreteVariable *y)
 This is called by MultiDimContainer::replace() to proceed with the replacing between x and y. More...
 
void swapContent_ (MultiDimImplementation< GUM_SCALAR > *aContent) const
 protecte method to swap the implementation behind the Potential More...
 
GUM_SCALAR & get_ (const Instantiation &i) const final
 Return a data, given a Insantiation - final method. More...
 

Detailed Description

template<typename GUM_SCALAR>
class gum::Potential< GUM_SCALAR >

aGrUM's Potential is a multi-dimensional array with tensor operators.

It is used to represent probabilities and utilities in aGrUMs' multidimensional (graphical) models.

Using the decorator pattern, this representation is independent from the implementation of the multidimensional matrix.

Template Parameters
GUM_SCALARThe type of the scalar stored in this multidimensional matrix.

Definition at line 59 of file potential.h.

Constructor & Destructor Documentation

◆ Potential() [1/5]

template<typename GUM_SCALAR >
INLINE gum::Potential< GUM_SCALAR >::Potential ( )

Default constructor.

Creates an empty null dimensional matrix with a MultiDimArray as its implementation.

Definition at line 37 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

37  :
38  MultiDimDecorator< GUM_SCALAR >(new MultiDimArray< GUM_SCALAR >(), GUM_SCALAR(1)) {
39  GUM_CONSTRUCTOR(Potential);
40  }
Potential()
Default constructor.
Definition: potential_tpl.h:37
+ Here is the call graph for this function:

◆ Potential() [2/5]

template<typename GUM_SCALAR >
INLINE gum::Potential< GUM_SCALAR >::Potential ( MultiDimImplementation< GUM_SCALAR > *  aContent)
explicit

Creates an potential around aContent.

Parameters
aContentThe implementation of this Potential.

Definition at line 44 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

44  :
45  MultiDimDecorator< GUM_SCALAR >(aContent, GUM_SCALAR(1)) {
46  // for debugging purposes
47  GUM_CONSTRUCTOR(Potential);
48  }
Potential()
Default constructor.
Definition: potential_tpl.h:37
+ Here is the call graph for this function:

◆ Potential() [3/5]

template<typename GUM_SCALAR >
gum::Potential< GUM_SCALAR >::Potential ( MultiDimImplementation< GUM_SCALAR > *  aContent,
const MultiDimContainer< GUM_SCALAR > &  src 
)

Copy constructor.

The newly created Potential share the variables and the values from src, but no instantiation is associated to it. It allows to force the chosen implementation and to copy the data from src.

Parameters
aContentThe implementation to use in this Potential.
srcThe MultiDimContainer to copy.

Definition at line 69 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

70  :
71  MultiDimDecorator< GUM_SCALAR >(aContent) {
72  // for debugging purposes
73  GUM_CONSTRUCTOR(Potential);
74 
75  if (!src.empty()) {
76  this->beginMultipleChanges();
77 
78  for (Idx i = 0; i < src.variablesSequence().size(); i++) {
79  this->add(*(src.variablesSequence()[i]));
80  }
81 
82  this->endMultipleChanges();
83  this->content()->copyFrom(*src.content());
84  }
85  }
virtual void beginMultipleChanges() final
Default implementation of MultiDimContainer::set().
virtual const MultiDimImplementation< GUM_SCALAR > * content() const final
Returns the implementation for this object (may be *this).
virtual void endMultipleChanges() final
Default implementation of MultiDimContainer::set().
virtual void add(const DiscreteVariable &v) final
Adds a new var to the variables of the multidimensional matrix.
Potential()
Default constructor.
Definition: potential_tpl.h:37
+ Here is the call graph for this function:

◆ Potential() [4/5]

template<typename GUM_SCALAR >
INLINE gum::Potential< GUM_SCALAR >::Potential ( const Potential< GUM_SCALAR > &  src)

Copy constructor & assignment.

Definition at line 51 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

51  :
52  Potential< GUM_SCALAR >(
53  static_cast< MultiDimImplementation< GUM_SCALAR >* >(src.content()->newFactory()),
54  *(src.content())) {
55  this->empty_value_ = src.empty_value_;
56  // GUM_CONS_CPY not here because in called Potential
57  // GUM_CONS_CPY( Potential );
58  }
GUM_SCALAR empty_value_
value of the MultiDimDecorator if no dimension.
+ Here is the call graph for this function:

◆ Potential() [5/5]

template<typename GUM_SCALAR >
INLINE gum::Potential< GUM_SCALAR >::Potential ( Potential< GUM_SCALAR > &&  from)

move constructor & assignement

move constructor

Definition at line 62 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

62  :
63  MultiDimDecorator< GUM_SCALAR >(std::forward< MultiDimDecorator< GUM_SCALAR > >(from)) {
64  GUM_CONS_MOV(Potential);
65  }
Potential()
Default constructor.
Definition: potential_tpl.h:37
+ Here is the call graph for this function:

◆ ~Potential()

template<typename GUM_SCALAR >
gum::Potential< GUM_SCALAR >::~Potential ( )

Destructor.

Definition at line 109 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

109  {
110  // for debugging purposes
111  GUM_DESTRUCTOR(Potential);
112  }
Potential()
Default constructor.
Definition: potential_tpl.h:37
+ Here is the call graph for this function:

Member Function Documentation

◆ abs()

template<typename GUM_SCALAR >
INLINE const Potential< GUM_SCALAR > & gum::Potential< GUM_SCALAR >::abs ( ) const

Apply abs on every element of the container.

Definition at line 325 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

325  {
326  this->apply([](GUM_SCALAR x) {
327  if (x >= 0)
328  return x;
329  else
330  return -x;
331  });
332  return *this;
333  }
virtual void apply(std::function< GUM_SCALAR(GUM_SCALAR) > f) const final
Apply a function on every element of the container.
+ Here is the call graph for this function:

◆ add()

template<typename GUM_SCALAR >
INLINE void gum::MultiDimDecorator< GUM_SCALAR >::add ( const DiscreteVariable v)
finalvirtualinherited

Adds a new var to the variables of the multidimensional matrix.

See also
operator<<(MultiDimInterface& c, const DiscreteVariable& v)
Warning
Note that the variable passed in argument is not duplicated, that is, only a pointer toward the variable is kept by the MultiDimInterface.
Parameters
vThe new var.
Exceptions
DuplicateElementRaised if the variable already belongs to the sequence of variables.
OperationNotAllowedRaised if this object is non mutable.

Implements gum::MultiDimInterface.

Definition at line 175 of file multiDimDecorator_tpl.h.

References gum::Set< Key, Alloc >::emplace().

175  {
176  if (v.domainSize() < 1) {
177  GUM_ERROR(InvalidArgument, "Empty variable " << v << " cannot be added in a Potential")
178  }
179  static_cast< MultiDimContainer< GUM_SCALAR >* >(content_)->add(v);
180  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
virtual void add(const DiscreteVariable &v) final
Adds a new var to the variables of the multidimensional matrix.
#define GUM_ERROR(type, msg)
Definition: exceptions.h:51
+ Here is the call graph for this function:

◆ apply()

template<typename GUM_SCALAR >
void gum::MultiDimDecorator< GUM_SCALAR >::apply ( std::function< GUM_SCALAR(GUM_SCALAR) >  f) const
finalvirtualinherited

Apply a function on every element of the container.

Parameters
fthe function to apply

Reimplemented from gum::MultiDimContainer< GUM_SCALAR >.

Definition at line 325 of file multiDimDecorator_tpl.h.

References gum::Set< Key, Alloc >::emplace().

325  {
326  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(content_)->empty()) {
328  } else {
329  content_->apply(f);
330  }
331  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
virtual bool empty() const final
Returns true if no var is in *this.
GUM_SCALAR empty_value_
value of the MultiDimDecorator if no dimension.
+ Here is the call graph for this function:

◆ argmax()

template<typename GUM_SCALAR >
INLINE Set< Instantiation > gum::Potential< GUM_SCALAR >::argmax ( ) const

set of instantiation corresponding to the max in the Potential

Definition at line 612 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

612  {
613  return findAll(max());
614  }
Set< Instantiation > findAll(GUM_SCALAR v) const
set of instantiation corresponding to the parameter v in the Potential
GUM_SCALAR max() const
max of all elements in the Potential
+ Here is the call graph for this function:

◆ argmin()

template<typename GUM_SCALAR >
INLINE Set< Instantiation > gum::Potential< GUM_SCALAR >::argmin ( ) const

set of instantiation corresponding to the min in the Potential

Definition at line 617 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

617  {
618  return findAll(min());
619  }
GUM_SCALAR min() const
min of all elements in the Potential
Set< Instantiation > findAll(GUM_SCALAR v) const
set of instantiation corresponding to the parameter v in the Potential
+ Here is the call graph for this function:

◆ beginMultipleChanges()

template<typename GUM_SCALAR >
INLINE void gum::MultiDimDecorator< GUM_SCALAR >::beginMultipleChanges ( )
finalvirtualinherited

Default implementation of MultiDimContainer::set().

Calls get_ as a r-value.

Implements gum::MultiDimContainer< GUM_SCALAR >.

Definition at line 358 of file multiDimDecorator_tpl.h.

References gum::Set< Key, Alloc >::emplace().

358  {
359  static_cast< MultiDimContainer< GUM_SCALAR >* >(content_)->beginMultipleChanges();
360  }
virtual void beginMultipleChanges() final
Default implementation of MultiDimContainer::set().
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
+ Here is the call graph for this function:

◆ changeNotification()

template<typename GUM_SCALAR >
INLINE void gum::MultiDimDecorator< GUM_SCALAR >::changeNotification ( const Instantiation i,
const DiscreteVariable *const  var,
Idx  oldval,
Idx  newval 
)
finalvirtualinherited

Listen to changes in a given Instantiation.

Parameters
iThe Instantiation to listen.
varThe changed dim.
oldvalThe old value.
newvalThe changed value.

Implements gum::MultiDimAdressable.

Definition at line 185 of file multiDimDecorator_tpl.h.

References gum::Set< Key, Alloc >::emplace().

188  {
189  static_cast< MultiDimContainer< GUM_SCALAR >* >(content_)->changeNotification(i,
190  var,
191  oldval,
192  newval);
193  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
virtual void changeNotification(const Instantiation &i, const DiscreteVariable *const var, Idx oldval, Idx newval) final
Listen to changes in a given Instantiation.
+ Here is the call graph for this function:

◆ complementVars_()

template<typename GUM_SCALAR >
Set< const DiscreteVariable *> gum::Potential< GUM_SCALAR >::complementVars_ ( const Set< const DiscreteVariable * > &  del_vars) const
protected

Definition at line 489 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

489  {
490  Set< const DiscreteVariable* > cplt;
491 
492  for (const auto x: this->variablesSequence())
493  if (!vars.contains(x)) cplt.insert(x);
494 
495  return cplt;
496  }
virtual const Sequence< const DiscreteVariable *> & variablesSequence() const final
Returns a const ref to the sequence of DiscreteVariable*.
+ Here is the call graph for this function:

◆ contains()

template<typename GUM_SCALAR >
INLINE bool gum::MultiDimDecorator< GUM_SCALAR >::contains ( const DiscreteVariable v) const
finalvirtualinherited

Returns true if var is in *this.

Parameters
vA DiscreteVariable.
Returns
Returns true if var is in *this.

Implements gum::MultiDimInterface.

Definition at line 264 of file multiDimDecorator_tpl.h.

References gum::Set< Key, Alloc >::emplace().

264  {
265  return static_cast< MultiDimContainer< GUM_SCALAR >* >(content_)->contains(var);
266  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
virtual bool contains(const DiscreteVariable &var) const final
Returns true if var is in *this.
+ Here is the call graph for this function:

◆ content() [1/2]

template<typename GUM_SCALAR >
INLINE const MultiDimImplementation< GUM_SCALAR > * gum::MultiDimDecorator< GUM_SCALAR >::content ( ) const
finalvirtualinherited

Returns the implementation for this object (may be *this).

Implements gum::MultiDimContainer< GUM_SCALAR >.

Definition at line 353 of file multiDimDecorator_tpl.h.

References gum::Set< Key, Alloc >::emplace().

353  {
354  return content_;
355  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
+ Here is the call graph for this function:

◆ content() [2/2]

template<typename GUM_SCALAR >
INLINE MultiDimImplementation< GUM_SCALAR > * gum::MultiDimDecorator< GUM_SCALAR >::content ( )
finalvirtualinherited

Returns the implementation for this object (may be *this).

Implements gum::MultiDimContainer< GUM_SCALAR >.

Definition at line 346 of file multiDimDecorator_tpl.h.

References gum::Set< Key, Alloc >::emplace().

346  {
347  return content_;
348  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
+ Here is the call graph for this function:

◆ copy()

template<typename GUM_SCALAR >
void gum::MultiDimContainer< GUM_SCALAR >::copy ( const MultiDimContainer< GUM_SCALAR > &  src)
virtualinherited

Removes all variables in this MultiDimContainer and copy the content of src, variables included.

Parameters
srcThe MultiDimContainer to copy.

Reimplemented in gum::MultiDimFunctionGraph< GUM_SCALAR, TerminalNodePolicy >, gum::MultiDimFunctionGraph< GUM_SCALAR >, and gum::MultiDimFunctionGraph< GUM_SCALAR, ExactTerminalNodePolicy >.

Definition at line 272 of file multiDimContainer_tpl.h.

References gum::Set< Key, Alloc >::emplace().

272  {
273  this->beginMultipleChanges();
274 
275  Size nbr = this->nbrDim();
276 
277  for (Idx i = 0; i < nbr; i++) {
278  this->erase(this->variable(0));
279  }
280 
281  for (Idx i = 0; i < src.nbrDim(); i++) {
282  this->add(src.variable(i));
283  }
284 
285  this->endMultipleChanges();
286  this->copyFrom(src);
287  }
virtual void endMultipleChanges()=0
Call this method after doing important changes in this MultiDimContainer.
virtual void add(const DiscreteVariable &v)=0
Adds a new var to the variables of the multidimensional matrix.
virtual Idx nbrDim() const =0
Returns the number of vars in the multidimensional container.
virtual const DiscreteVariable & variable(Idx i) const =0
Returns a const ref to the ith var.
virtual void beginMultipleChanges()=0
Call this method before doing important changes in this MultiDimContainer.
virtual void copyFrom(const MultiDimContainer< GUM_SCALAR > &src) const
Basic copy of a MultiDimContainer.
virtual void erase(const DiscreteVariable &v)=0
Removes a var from the variables of the multidimensional matrix.
std::size_t Size
In aGrUM, hashed values are unsigned long int.
Definition: types.h:47
+ Here is the call graph for this function:

◆ copyFrom() [1/2]

template<typename GUM_SCALAR >
void gum::MultiDimContainer< GUM_SCALAR >::copyFrom ( const MultiDimContainer< GUM_SCALAR > &  src) const
virtualinherited

Basic copy of a MultiDimContainer.

This method is virtual because it should be optimized in certain MultiDimContainer.

Parameters
srcThe MultiDimContainer src which values are copied. This is a full copy with no verification of dimensions.
Exceptions
OperationNotAllowedRaised if src does not have the same domain size than this MultiDimContainer.

Reimplemented in gum::aggregator::MultiDimAggregator< GUM_SCALAR >, gum::MultiDimICIModel< GUM_SCALAR >, and gum::MultiDimArray< GUM_SCALAR >.

Definition at line 255 of file multiDimContainer_tpl.h.

References gum::Set< Key, Alloc >::emplace().

255  {
256  if (src.domainSize() != domainSize()) {
257  GUM_ERROR(OperationNotAllowed,
258  "Domain sizes do not fit : " << src.domainSize() << "!=" << domainSize());
259  }
260 
261  Instantiation i_dest(*this);
262  Instantiation i_src(src);
263 
264  for (i_dest.setFirst(), i_src.setFirst(); !i_dest.end(); ++i_dest, ++i_src) {
265  set(i_dest, src[i_src]);
266  }
267  }
virtual Size domainSize() const =0
Returns the product of the variables domain size.
#define GUM_ERROR(type, msg)
Definition: exceptions.h:51
+ Here is the call graph for this function:

◆ copyFrom() [2/2]

template<typename GUM_SCALAR >
void gum::MultiDimContainer< GUM_SCALAR >::copyFrom ( const MultiDimContainer< GUM_SCALAR > &  src,
Instantiation p_i 
) const
virtualinherited

Basic copy of a MultiDimContainer.

This method is virtual because it should be optimized in certain MultiDimContainer.

Parameters
srcThe MultiDimContainer src which values are copied.
p_iGive the order to iterate in this MultiDimContainer during the copy (nullptr will correctly copy if this is a reorganization of src).
Exceptions
OperationNotAllowedRaised if src does not have the same domain size than this MultiDimContainer.

Reimplemented in gum::MultiDimFunctionGraph< GUM_SCALAR, TerminalNodePolicy >, gum::MultiDimFunctionGraph< GUM_SCALAR >, and gum::MultiDimFunctionGraph< GUM_SCALAR, ExactTerminalNodePolicy >.

Definition at line 209 of file multiDimContainer_tpl.h.

References gum::Set< Key, Alloc >::emplace().

210  {
211  if (src.domainSize() != domainSize()) {
212  GUM_ERROR(OperationNotAllowed,
213  "Domain sizes do not fit : " << src.domainSize() << "!=" << domainSize());
214  }
215 
216  if (p_i == nullptr) { // if null, we just follow the same order
217  Instantiation i(src);
218  for (i.setFirst(); !i.end(); ++i) {
219  set(i, src[i]);
220  }
221  } else {
222  Instantiation i_dest(*this);
223  Instantiation i_src(src);
224  for (i_dest.setFirst(), i_src.setFirst(); !i_dest.end(); i_dest.incIn(*p_i), ++i_src) {
225  set(i_dest, src[i_src]);
226  }
227  }
228  }
virtual Size domainSize() const =0
Returns the product of the variables domain size.
#define GUM_ERROR(type, msg)
Definition: exceptions.h:51
+ Here is the call graph for this function:

◆ domainSize()

template<typename GUM_SCALAR >
INLINE Size gum::MultiDimDecorator< GUM_SCALAR >::domainSize ( ) const
finalvirtualinherited

Returns the product of the variables domain size.

Returns
Returns the product of the variables domain size.

Implements gum::MultiDimInterface.

Definition at line 168 of file multiDimDecorator_tpl.h.

References gum::Set< Key, Alloc >::emplace().

168  {
169  return static_cast< MultiDimContainer< GUM_SCALAR >* >(content_)->domainSize();
170  }
virtual Size domainSize() const final
Returns the product of the variables domain size.
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
+ Here is the call graph for this function:

◆ draw()

template<typename GUM_SCALAR >
Idx gum::Potential< GUM_SCALAR >::draw ( ) const

get a value at random from a 1-D distribution

Definition at line 578 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

578  {
579  if (this->nbrDim() != 1) {
580  GUM_ERROR(FatalError, "To draw from a potential, the dimension must be 1")
581  }
582 
583  GUM_SCALAR r = static_cast< GUM_SCALAR >(randomProba());
584  Instantiation Ip(*this);
585  for (Ip.setFirst(); !Ip.end(); Ip.inc()) {
586  r -= this->get(Ip);
587  if (r <= 0) return Ip.val(0);
588  }
589  return this->variable(0).domainSize() - 1;
590  }
virtual Idx nbrDim() const final
Returns the number of vars in the multidimensional container.
double randomProba()
Returns a random double between 0 and 1 included (i.e.
virtual Size domainSize() const =0
virtual const DiscreteVariable & variable(Idx) const final
Returns a const ref to the ith var.
#define GUM_ERROR(type, msg)
Definition: exceptions.h:51
+ Here is the call graph for this function:

◆ empty()

template<typename GUM_SCALAR >
INLINE bool gum::MultiDimDecorator< GUM_SCALAR >::empty ( ) const
finalvirtualinherited

Returns true if no var is in *this.

Returns
Returns true if no var is in *this.

Implements gum::MultiDimInterface.

Definition at line 269 of file multiDimDecorator_tpl.h.

References gum::Set< Key, Alloc >::emplace().

269  {
270  if (content_ == nullptr) return true;
271  return static_cast< MultiDimContainer< GUM_SCALAR >* >(content_)->empty();
272  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
virtual bool empty() const final
Returns true if no var is in *this.
+ Here is the call graph for this function:

◆ endMultipleChanges() [1/2]

template<typename GUM_SCALAR >
INLINE void gum::MultiDimDecorator< GUM_SCALAR >::endMultipleChanges ( )
finalvirtualinherited

Default implementation of MultiDimContainer::set().

Calls get_ as a r-value.

Implements gum::MultiDimContainer< GUM_SCALAR >.

Definition at line 363 of file multiDimDecorator_tpl.h.

References gum::Set< Key, Alloc >::emplace().

363  {
364  static_cast< MultiDimContainer< GUM_SCALAR >* >(content_)->endMultipleChanges();
365  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
virtual void endMultipleChanges() final
Default implementation of MultiDimContainer::set().
+ Here is the call graph for this function:

◆ endMultipleChanges() [2/2]

template<typename GUM_SCALAR >
INLINE void gum::MultiDimDecorator< GUM_SCALAR >::endMultipleChanges ( const GUM_SCALAR &  x)
finalvirtualinherited

Default implementation of MultiDimContainer::set().

Calls get_ as a r-value.

Implements gum::MultiDimContainer< GUM_SCALAR >.

Definition at line 368 of file multiDimDecorator_tpl.h.

References gum::Set< Key, Alloc >::emplace().

368  {
369  static_cast< MultiDimContainer< GUM_SCALAR >* >(content_)->endMultipleChanges(x);
370  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
virtual void endMultipleChanges() final
Default implementation of MultiDimContainer::set().
+ Here is the call graph for this function:

◆ entropy()

template<typename GUM_SCALAR >
INLINE GUM_SCALAR gum::Potential< GUM_SCALAR >::entropy ( ) const

entropy of the Potential

Definition at line 196 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

196  {
197  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(this->content_)->empty()) {
198  return static_cast< GUM_SCALAR >(0);
199  }
200 
201  return this->reduce(
202  [](GUM_SCALAR z, GUM_SCALAR p) { return (p == 0.0) ? z : (z - p * std::log2(p)); },
203  0.0);
204  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
virtual bool empty() const final
Returns true if no var is in *this.
virtual GUM_SCALAR reduce(std::function< GUM_SCALAR(GUM_SCALAR, GUM_SCALAR) > f, GUM_SCALAR base) const final
compute lfold for this container
Potential< GUM_SCALAR > log2(const Potential< GUM_SCALAR > &arg)
Definition: potential.h:590
+ Here is the call graph for this function:

◆ erase() [1/2]

template<typename GUM_SCALAR >
INLINE void gum::MultiDimDecorator< GUM_SCALAR >::erase ( const DiscreteVariable v)
finalvirtualinherited

Removes a var from the variables of the multidimensional matrix.

See also
operator>>(MultiDimInterface& c, const DiscreteVariable& v)
Exceptions
OperationNotAllowedRaised if this object is non mutable.
NotFoundRaised if v does not belong to this.

Implements gum::MultiDimInterface.

Definition at line 238 of file multiDimDecorator_tpl.h.

References gum::Set< Key, Alloc >::emplace().

238  {
239  static_cast< MultiDimContainer< GUM_SCALAR >* >(content_)->erase(var);
240  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
virtual void erase(const DiscreteVariable &var) final
Removes a var from the variables of the multidimensional matrix.
+ Here is the call graph for this function:

◆ erase() [2/2]

template<typename GUM_SCALAR >
INLINE void gum::MultiDimDecorator< GUM_SCALAR >::erase ( const std::string &  name)
finalvirtualinherited

Definition at line 243 of file multiDimDecorator_tpl.h.

References gum::Set< Key, Alloc >::emplace().

243  {
244  erase(variable(name));
245  }
virtual void erase(const DiscreteVariable &var) final
Removes a var from the variables of the multidimensional matrix.
virtual const DiscreteVariable & variable(Idx) const final
Returns a const ref to the ith var.
+ Here is the call graph for this function:

◆ extract()

template<typename GUM_SCALAR >
Potential< GUM_SCALAR > gum::Potential< GUM_SCALAR >::extract ( const Instantiation inst) const

create a new Potential extracted from *this given a partial instantiation

Definition at line 570 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

570  {
571  Potential< GUM_SCALAR > p;
572  p.extractFrom(*this, inst);
573 
574  return p;
575  }
+ Here is the call graph for this function:

◆ extractFrom()

template<typename GUM_SCALAR >
void gum::MultiDimContainer< GUM_SCALAR >::extractFrom ( const MultiDimContainer< GUM_SCALAR > &  src,
const Instantiation mask 
)
virtualinherited

Basic extraction of a MultiDimContainer.

This method is virtual because it should be optimized in certain MultiDimContainer.

Parameters
srcThe MultiDimContainer src which datas are copied.
maskpartial instantiation of variables of the Potential : the

extraction will concern every variable not in the instantiation and the copy of data will use the (relevant) values in this instantiation.

Definition at line 231 of file multiDimContainer_tpl.h.

References gum::Set< Key, Alloc >::emplace().

232  {
233  this->beginMultipleChanges();
234 
235  Size nbr = this->nbrDim();
236  for (Idx i = 0; i < nbr; i++) {
237  this->erase(this->variable(0));
238  }
239 
240  for (Idx i = 0; i < src.nbrDim(); i++) {
241  if (!imask.contains(src.variable(i))) this->add(src.variable(i));
242  }
243 
244  this->endMultipleChanges();
245 
246  if (this->nbrDim() == 0) { GUM_ERROR(FatalError, "Empty potential") }
247 
248  Instantiation inst(src);
249  inst.setVals(imask);
250  for (inst.setFirstOut(imask); !inst.end(); inst.incOut(imask))
251  set(inst, src[inst]);
252  }
virtual void endMultipleChanges()=0
Call this method after doing important changes in this MultiDimContainer.
virtual void add(const DiscreteVariable &v)=0
Adds a new var to the variables of the multidimensional matrix.
virtual Idx nbrDim() const =0
Returns the number of vars in the multidimensional container.
virtual const DiscreteVariable & variable(Idx i) const =0
Returns a const ref to the ith var.
virtual void beginMultipleChanges()=0
Call this method before doing important changes in this MultiDimContainer.
virtual void erase(const DiscreteVariable &v)=0
Removes a var from the variables of the multidimensional matrix.
std::size_t Size
In aGrUM, hashed values are unsigned long int.
Definition: types.h:47
#define GUM_ERROR(type, msg)
Definition: exceptions.h:51
+ Here is the call graph for this function:

◆ fill()

template<typename GUM_SCALAR >
INLINE void gum::MultiDimDecorator< GUM_SCALAR >::fill ( const GUM_SCALAR &  d) const
finalvirtualinherited

Default implementation of MultiDimContainer::set().

Calls get_ as a r-value.

Implements gum::MultiDimContainer< GUM_SCALAR >.

Definition at line 280 of file multiDimDecorator_tpl.h.

References gum::Set< Key, Alloc >::emplace().

280  {
281  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(content_)->empty()) {
282  empty_value_ = d;
283  } else {
284  static_cast< MultiDimContainer< GUM_SCALAR >* >(content_)->fill(d);
285  }
286  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
virtual bool empty() const final
Returns true if no var is in *this.
GUM_SCALAR empty_value_
value of the MultiDimDecorator if no dimension.
virtual void fill(const GUM_SCALAR &d) const final
Default implementation of MultiDimContainer::set().
+ Here is the call graph for this function:

◆ fillWith() [1/4]

template<typename GUM_SCALAR >
INLINE const Potential< GUM_SCALAR > & gum::Potential< GUM_SCALAR >::fillWith ( const Potential< GUM_SCALAR > &  src) const

copy a Potential data using name of variables and labels (not necessarily the same variables in the same orders)

Warning
a strict control on names of variables and labels are made
Exceptions
InvalidArgumentif the Potential is not compatible with this

Definition at line 222 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

222  {
223  if (src.domainSize() != this->domainSize()) {
224  GUM_ERROR(InvalidArgument, "Potential to copy has not the same dimension.")
225  }
226  gum::Set< std::string > son; // set of names
227  for (const auto& v: src.variablesSequence()) {
228  son.insert(v->name());
229  }
230  for (const auto& v: this->variablesSequence()) {
231  if (!son.contains(v->name())) {
232  GUM_ERROR(InvalidArgument,
233  "Variable <" << v->name() << "> not present in src (" << son << ").");
234  }
235  // we check size, labels and order of labels in the same time
236  if (v->toString() != src.variable(v->name()).toString()) {
237  GUM_ERROR(InvalidArgument, "Variables <" << v->name() << "> are not identical.")
238  }
239  }
240 
241  Instantiation Isrc(src);
242  Instantiation Idst(*this);
243  for (Isrc.setFirst(); !Isrc.end(); ++Isrc) {
244  for (Idx i = 0; i < this->nbrDim(); i++) {
245  Idst.chgVal(Isrc.variable(i).name(), Isrc.val(i));
246  }
247  this->set(Idst, src.get(Isrc));
248  }
249 
250  return *this;
251  }
bool contains(const Key &k) const
Indicates whether a given elements belong to the set.
Definition: set_tpl.h:558
virtual Idx nbrDim() const final
Returns the number of vars in the multidimensional container.
virtual Size domainSize() const final
Returns the product of the variables domain size.
virtual std::string toString() const
the function to be used to add two Potentials
Definition: potential.h:497
virtual const Sequence< const DiscreteVariable *> & variablesSequence() const final
Returns a const ref to the sequence of DiscreteVariable*.
void insert(const Key &k)
Inserts a new element into the set.
Definition: set_tpl.h:606
#define GUM_ERROR(type, msg)
Definition: exceptions.h:51
+ Here is the call graph for this function:

◆ fillWith() [2/4]

template<typename GUM_SCALAR >
INLINE const Potential< GUM_SCALAR > & gum::Potential< GUM_SCALAR >::fillWith ( const Potential< GUM_SCALAR > &  src,
const std::vector< std::string > &  mapSrc 
) const

copy a Potential data using the sequence of names in mapSrc to find the corresponding variables.

For instance, to copy the potential P(A,B,C) in Q(D,E,A) with the mapping P.A<->Q.E, P.B<->Q.A, P.C<->Q.D (assuming that the corresponding variables have the same domain size and the order of labels):

Q.fillWith(P,{"C","A","B"});
Warning
a strict control on names of variables and labels are made
Exceptions
InvalidArgumentif the Potential is not compatible with this

Definition at line 255 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

256  {
257  if (src.nbrDim() != this->nbrDim()) {
258  GUM_ERROR(InvalidArgument, "Potential to copy has not the same dimension.")
259  }
260  if (src.nbrDim() != mapSrc.size()) {
261  GUM_ERROR(InvalidArgument, "Potential and vector have not the same dimension.")
262  }
263  Instantiation Isrc;
264  for (Idx i = 0; i < src.nbrDim(); i++) {
265  if (src.variable(mapSrc[i]).domainSize() != this->variable(i).domainSize()) {
266  GUM_ERROR(InvalidArgument,
267  "Variables " << mapSrc[i] << " (in the argument) and " << this->variable(i).name()
268  << " have not the same dimension.");
269  } else {
270  Isrc.add(src.variable(mapSrc[i]));
271  }
272  }
273  Instantiation Idst(*this);
274  for (Isrc.setFirst(); !Isrc.end(); ++Isrc, ++Idst) {
275  this->set(Idst, src.get(Isrc));
276  }
277 
278  return *this;
279  }
virtual Idx nbrDim() const final
Returns the number of vars in the multidimensional container.
virtual Size domainSize() const =0
virtual const DiscreteVariable & variable(Idx) const final
Returns a const ref to the ith var.
#define GUM_ERROR(type, msg)
Definition: exceptions.h:51
+ Here is the call graph for this function:

◆ fillWith() [3/4]

template<typename GUM_SCALAR >
INLINE const Potential< GUM_SCALAR > & gum::Potential< GUM_SCALAR >::fillWith ( const std::vector< GUM_SCALAR > &  data) const

Automatically fills the potential with the values in v.

Parameters
vVector of values.
Exceptions
SizeErrorRaised if v size's does not matches this MultiDimContainer domain size.

Definition at line 208 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

208  {
209  this->populate(data);
210  return *this;
211  }
virtual void populate(const std::vector< GUM_SCALAR > &v) const final
Automatically fills this MultiDimContainer with the values in v.
+ Here is the call graph for this function:

◆ fillWith() [4/4]

template<typename GUM_SCALAR >
INLINE const Potential< GUM_SCALAR > & gum::Potential< GUM_SCALAR >::fillWith ( const GUM_SCALAR &  val) const

Automatically fills this MultiDimContainer with the value v.

Parameters
vcontains the data.

Definition at line 215 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

215  {
216  this->fill(val);
217  return *this;
218  }
virtual void fill(const GUM_SCALAR &d) const final
Default implementation of MultiDimContainer::set().
+ Here is the call graph for this function:

◆ findAll()

template<typename GUM_SCALAR >
Set< Instantiation > gum::Potential< GUM_SCALAR >::findAll ( GUM_SCALAR  v) const

set of instantiation corresponding to the parameter v in the Potential

Definition at line 600 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

600  {
601  Instantiation I(*this);
602  Set< Instantiation > res;
603 
604  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(this->content_)->empty()) { return res; }
605  for (I.setFirst(); !I.end(); ++I) {
606  if (this->get(I) == v) res.insert(I);
607  }
608  return res;
609  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
virtual bool empty() const final
Returns true if no var is in *this.
+ Here is the call graph for this function:

◆ get()

template<typename GUM_SCALAR >
INLINE GUM_SCALAR gum::MultiDimDecorator< GUM_SCALAR >::get ( const Instantiation i) const
finalvirtualinherited

Default implementation of MultiDimContainer::get().

Calls get_ as a l-value.

Reimplemented from gum::MultiDimContainer< GUM_SCALAR >.

Definition at line 147 of file multiDimDecorator_tpl.h.

References gum::Set< Key, Alloc >::emplace().

147  {
148  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(content_)->empty()) {
149  return empty_value_;
150  } else {
151  return static_cast< MultiDimContainer< GUM_SCALAR >* >(content_)->get(i);
152  }
153  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
virtual bool empty() const final
Returns true if no var is in *this.
GUM_SCALAR empty_value_
value of the MultiDimDecorator if no dimension.
+ Here is the call graph for this function:

◆ get_()

template<typename GUM_SCALAR >
INLINE GUM_SCALAR & gum::MultiDimDecorator< GUM_SCALAR >::get_ ( const Instantiation i) const
finalprotectedvirtualinherited

Return a data, given a Insantiation - final method.

Parameters
iThe instantiation.
Exceptions
NullElement
NotFound

Implements gum::MultiDimContainer< GUM_SCALAR >.

Definition at line 142 of file multiDimDecorator_tpl.h.

References gum::Set< Key, Alloc >::emplace().

142  {
143  GUM_ERROR(OperationNotAllowed, "_get in the implementation !")
144  }
#define GUM_ERROR(type, msg)
Definition: exceptions.h:51
+ Here is the call graph for this function:

◆ getMasterRef() [1/2]

template<typename GUM_SCALAR >
INLINE MultiDimAdressable & gum::MultiDimContainer< GUM_SCALAR >::getMasterRef ( )
virtualinherited

In order to insure the dereference for decorators, we need to virtualize the access to master pointer.

Returns
Returns the ref to content as MultiDimAdressable&

Implements gum::MultiDimAdressable.

Reimplemented in gum::MultiDimBucket< GUM_SCALAR >.

Definition at line 290 of file multiDimContainer_tpl.h.

References gum::Set< Key, Alloc >::emplace().

290  {
291  return static_cast< MultiDimAdressable& >(*content());
292  }
virtual const MultiDimImplementation< GUM_SCALAR > * content() const =0
Returns the implementation for this object (may be *this).
MultiDimAdressable()
Default constructor.
+ Here is the call graph for this function:

◆ getMasterRef() [2/2]

template<typename GUM_SCALAR >
INLINE const MultiDimAdressable & gum::MultiDimContainer< GUM_SCALAR >::getMasterRef ( ) const
virtualinherited

In order to insure the dereference for decorators, we need to virtualize the access to master pointer.

Returns
Returns the master of this MultiDimAdressable.

Implements gum::MultiDimAdressable.

Reimplemented in gum::MultiDimBucket< GUM_SCALAR >.

Definition at line 295 of file multiDimContainer_tpl.h.

References gum::Set< Key, Alloc >::emplace().

295  {
296  return static_cast< const MultiDimAdressable& >(*content());
297  }
virtual const MultiDimImplementation< GUM_SCALAR > * content() const =0
Returns the implementation for this object (may be *this).
MultiDimAdressable()
Default constructor.
+ Here is the call graph for this function:

◆ inverse()

template<typename GUM_SCALAR >
INLINE const Potential< GUM_SCALAR > & gum::Potential< GUM_SCALAR >::inverse ( void  ) const

the function to inverse (each value of) *this

Definition at line 398 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

398  {
399  this->apply([](GUM_SCALAR x) { return 1 / x; });
400  return *this;
401  }
virtual void apply(std::function< GUM_SCALAR(GUM_SCALAR) > f) const final
Apply a function on every element of the container.
+ Here is the call graph for this function:

◆ isNonZeroMap()

template<typename GUM_SCALAR >
INLINE Potential< GUM_SCALAR > gum::Potential< GUM_SCALAR >::isNonZeroMap ( ) const

create a boolean-like potential using the predicate isNonZero

Definition at line 476 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

476  {
477  auto p = Potential< GUM_SCALAR >(*this);
478  p.apply([](GUM_SCALAR x) {
479  if (x != static_cast< GUM_SCALAR >(0))
480  return static_cast< GUM_SCALAR >(1);
481  else
482  return static_cast< GUM_SCALAR >(0);
483  });
484  return p;
485  }
+ Here is the call graph for this function:

◆ KL()

template<typename GUM_SCALAR >
INLINE GUM_SCALAR gum::Potential< GUM_SCALAR >::KL ( const Potential< GUM_SCALAR > &  p) const

compute KL divergence between this and p Checks the compatibility and then compute KL divergence

Exceptions
gum::InvalidArgumentif p is not compatible with $this (dimension, variables)
gum::FatalErrorif a zero is found in p or this and not in the other.

Definition at line 294 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

294  {
295  if (this->nbrDim() != p.nbrDim())
296  GUM_ERROR(InvalidArgument,
297  "BNdistance between potentials with different numbers of dimensions");
298  for (const auto var: p.variablesSequence()) {
299  if (!this->contains(*var))
300  GUM_ERROR(InvalidArgument, "A variable in the argument does not belong to the potential.")
301  }
302  for (const auto var: this->variablesSequence()) {
303  if (!p.contains(*var))
304  GUM_ERROR(InvalidArgument, "A variable does not belong to the argument.")
305  }
306 
307  Instantiation inst(*this);
308  GUM_SCALAR res = static_cast< GUM_SCALAR >(0);
309  for (inst.setFirst(); !inst.end(); inst.inc()) {
310  GUM_SCALAR x = this->get(inst);
311  GUM_SCALAR y = p.get(inst);
312  if (static_cast< GUM_SCALAR >(0) == x) // 0*log(0/y)=0
313  continue;
314 
315  if (static_cast< GUM_SCALAR >(0) == y)
316  // we know that x!=0;
317  GUM_ERROR(FatalError, "The argument has a 0 at " << inst << " while the potential has not.")
318 
319  res += x * std::log2(x / y);
320  }
321  return res;
322  }
virtual Idx nbrDim() const final
Returns the number of vars in the multidimensional container.
STL namespace.
const Potential< GUM_SCALAR > & log2() const
apply $log_2(x)$ on every element of the container
virtual const Sequence< const DiscreteVariable *> & variablesSequence() const final
Returns a const ref to the sequence of DiscreteVariable*.
virtual bool contains(const DiscreteVariable &var) const final
Returns true if var is in *this.
#define GUM_ERROR(type, msg)
Definition: exceptions.h:51
+ Here is the call graph for this function:

◆ log2()

template<typename GUM_SCALAR >
INLINE const Potential< GUM_SCALAR > & gum::Potential< GUM_SCALAR >::log2 ( ) const

apply $log_2(x)$ on every element of the container

Definition at line 288 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

288  {
289  this->apply([](GUM_SCALAR x) { return std::log2(x); });
290  return *this;
291  }
virtual void apply(std::function< GUM_SCALAR(GUM_SCALAR) > f) const final
Apply a function on every element of the container.
Potential< GUM_SCALAR > log2(const Potential< GUM_SCALAR > &arg)
Definition: potential.h:590
+ Here is the call graph for this function:

◆ margMaxIn()

template<typename GUM_SCALAR >
INLINE Potential< GUM_SCALAR > gum::Potential< GUM_SCALAR >::margMaxIn ( const Set< const DiscreteVariable * > &  kept_vars) const

Projection using max as operation (and implementation-optimized operations)

Parameters
kept_varsis the set of vars to keep

Definition at line 468 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

468  {
469  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(this->content_)->empty()) {
470  return Potential< GUM_SCALAR >().fillWith(this->empty_value_);
471  }
472  return Potential< GUM_SCALAR >(gum::projectMax(*this->content(), complementVars_(kept_vars)));
473  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
Set< const DiscreteVariable *> complementVars_(const Set< const DiscreteVariable * > &del_vars) const
virtual bool empty() const final
Returns true if no var is in *this.
virtual const MultiDimImplementation< GUM_SCALAR > * content() const final
Returns the implementation for this object (may be *this).
const Potential< GUM_SCALAR > & fillWith(const Potential< GUM_SCALAR > &src) const
copy a Potential data using name of variables and labels (not necessarily the same variables in the s...
GUM_SCALAR empty_value_
value of the MultiDimDecorator if no dimension.
GUM_SCALAR projectMax(const MultiDimImplementation< GUM_SCALAR > &table, Instantiation *instantiation=0)
the function to be used to project a MultiDimImplementation using a Max
+ Here is the call graph for this function:

◆ margMaxOut()

template<typename GUM_SCALAR >
INLINE Potential< GUM_SCALAR > gum::Potential< GUM_SCALAR >::margMaxOut ( const Set< const DiscreteVariable * > &  del_vars) const

Projection using max as operation (and implementation-optimized operations)

Parameters
del_varsis the set of vars to eliminate

Definition at line 432 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

432  {
433  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(this->content_)->empty()) {
434  return Potential< GUM_SCALAR >().fillWith(this->empty_value_);
435  }
436  return Potential< GUM_SCALAR >(gum::projectMax(*this->content(), del_vars));
437  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
virtual bool empty() const final
Returns true if no var is in *this.
virtual const MultiDimImplementation< GUM_SCALAR > * content() const final
Returns the implementation for this object (may be *this).
const Potential< GUM_SCALAR > & fillWith(const Potential< GUM_SCALAR > &src) const
copy a Potential data using name of variables and labels (not necessarily the same variables in the s...
GUM_SCALAR empty_value_
value of the MultiDimDecorator if no dimension.
GUM_SCALAR projectMax(const MultiDimImplementation< GUM_SCALAR > &table, Instantiation *instantiation=0)
the function to be used to project a MultiDimImplementation using a Max
+ Here is the call graph for this function:

◆ margMinIn()

template<typename GUM_SCALAR >
INLINE Potential< GUM_SCALAR > gum::Potential< GUM_SCALAR >::margMinIn ( const Set< const DiscreteVariable * > &  kept_vars) const

Projection using min as operation (and implementation-optimized operations)

Parameters
kept_varsis the set of vars to keep

Definition at line 459 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

459  {
460  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(this->content_)->empty()) {
461  return Potential< GUM_SCALAR >().fillWith(this->empty_value_);
462  }
463  return Potential< GUM_SCALAR >(gum::projectMin(*this->content(), complementVars_(kept_vars)));
464  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
Set< const DiscreteVariable *> complementVars_(const Set< const DiscreteVariable * > &del_vars) const
virtual bool empty() const final
Returns true if no var is in *this.
virtual const MultiDimImplementation< GUM_SCALAR > * content() const final
Returns the implementation for this object (may be *this).
const Potential< GUM_SCALAR > & fillWith(const Potential< GUM_SCALAR > &src) const
copy a Potential data using name of variables and labels (not necessarily the same variables in the s...
GUM_SCALAR empty_value_
value of the MultiDimDecorator if no dimension.
GUM_SCALAR projectMin(const MultiDimImplementation< GUM_SCALAR > &table, Instantiation *instantiation=0)
the function to be used to project a MultiDimImplementation using a Min
+ Here is the call graph for this function:

◆ margMinOut()

template<typename GUM_SCALAR >
INLINE Potential< GUM_SCALAR > gum::Potential< GUM_SCALAR >::margMinOut ( const Set< const DiscreteVariable * > &  del_vars) const

Projection using min as operation (and implementation-optimized operations)

Parameters
del_varsis the set of vars to eliminate

Definition at line 423 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

423  {
424  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(this->content_)->empty()) {
425  return Potential< GUM_SCALAR >().fillWith(this->empty_value_);
426  }
427  return Potential< GUM_SCALAR >(gum::projectMin(*this->content(), del_vars));
428  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
virtual bool empty() const final
Returns true if no var is in *this.
virtual const MultiDimImplementation< GUM_SCALAR > * content() const final
Returns the implementation for this object (may be *this).
const Potential< GUM_SCALAR > & fillWith(const Potential< GUM_SCALAR > &src) const
copy a Potential data using name of variables and labels (not necessarily the same variables in the s...
GUM_SCALAR empty_value_
value of the MultiDimDecorator if no dimension.
GUM_SCALAR projectMin(const MultiDimImplementation< GUM_SCALAR > &table, Instantiation *instantiation=0)
the function to be used to project a MultiDimImplementation using a Min
+ Here is the call graph for this function:

◆ margProdIn()

template<typename GUM_SCALAR >
INLINE Potential< GUM_SCALAR > gum::Potential< GUM_SCALAR >::margProdIn ( const Set< const DiscreteVariable * > &  kept_vars) const

Projection using multiplication as operation (and implementation-optimized operations)

Parameters
kept_varsis the set of vars to keep

Definition at line 449 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

449  {
450  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(this->content_)->empty()) {
451  return Potential< GUM_SCALAR >().fillWith(this->empty_value_);
452  }
453  return Potential< GUM_SCALAR >(
454  gum::projectProduct(*this->content(), complementVars_(kept_vars)));
455  }
GUM_SCALAR projectProduct(const MultiDimImplementation< GUM_SCALAR > &table, Instantiation *instantiation=0)
the function to be used to project a MultiDimImplementation using a Product
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
Set< const DiscreteVariable *> complementVars_(const Set< const DiscreteVariable * > &del_vars) const
virtual bool empty() const final
Returns true if no var is in *this.
virtual const MultiDimImplementation< GUM_SCALAR > * content() const final
Returns the implementation for this object (may be *this).
const Potential< GUM_SCALAR > & fillWith(const Potential< GUM_SCALAR > &src) const
copy a Potential data using name of variables and labels (not necessarily the same variables in the s...
GUM_SCALAR empty_value_
value of the MultiDimDecorator if no dimension.
+ Here is the call graph for this function:

◆ margProdOut()

template<typename GUM_SCALAR >
INLINE Potential< GUM_SCALAR > gum::Potential< GUM_SCALAR >::margProdOut ( const Set< const DiscreteVariable * > &  del_vars) const

Projection using multiplication as operation (and implementation-optimized operations)

Parameters
del_varsis the set of vars to eliminate

Definition at line 414 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

414  {
415  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(this->content_)->empty()) {
416  return Potential< GUM_SCALAR >().fillWith(this->empty_value_);
417  }
418  return Potential< GUM_SCALAR >(gum::projectProduct(*this->content(), del_vars));
419  }
GUM_SCALAR projectProduct(const MultiDimImplementation< GUM_SCALAR > &table, Instantiation *instantiation=0)
the function to be used to project a MultiDimImplementation using a Product
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
virtual bool empty() const final
Returns true if no var is in *this.
virtual const MultiDimImplementation< GUM_SCALAR > * content() const final
Returns the implementation for this object (may be *this).
const Potential< GUM_SCALAR > & fillWith(const Potential< GUM_SCALAR > &src) const
copy a Potential data using name of variables and labels (not necessarily the same variables in the s...
GUM_SCALAR empty_value_
value of the MultiDimDecorator if no dimension.
+ Here is the call graph for this function:

◆ margSumIn()

template<typename GUM_SCALAR >
INLINE Potential< GUM_SCALAR > gum::Potential< GUM_SCALAR >::margSumIn ( const Set< const DiscreteVariable * > &  kept_vars) const

Projection using sum as operation (and implementation-optimized operations)

Parameters
kept_varsis the set of vars to keep

Definition at line 440 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

440  {
441  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(this->content_)->empty()) {
442  return Potential< GUM_SCALAR >().fillWith(this->empty_value_);
443  }
444  return Potential< GUM_SCALAR >(gum::projectSum(*this->content(), complementVars_(kept_vars)));
445  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
Set< const DiscreteVariable *> complementVars_(const Set< const DiscreteVariable * > &del_vars) const
virtual bool empty() const final
Returns true if no var is in *this.
virtual const MultiDimImplementation< GUM_SCALAR > * content() const final
Returns the implementation for this object (may be *this).
const Potential< GUM_SCALAR > & fillWith(const Potential< GUM_SCALAR > &src) const
copy a Potential data using name of variables and labels (not necessarily the same variables in the s...
GUM_SCALAR projectSum(const MultiDimImplementation< GUM_SCALAR > &table, Instantiation *instantiation=0)
the function to be used to project a MultiDimImplementation using a sum
GUM_SCALAR empty_value_
value of the MultiDimDecorator if no dimension.
+ Here is the call graph for this function:

◆ margSumOut()

template<typename GUM_SCALAR >
INLINE Potential< GUM_SCALAR > gum::Potential< GUM_SCALAR >::margSumOut ( const Set< const DiscreteVariable * > &  del_vars) const

Projection using sum as operation (and implementation-optimized operations)

Parameters
del_varsis the set of vars to eliminate

Definition at line 405 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

405  {
406  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(this->content_)->empty()) {
407  return Potential< GUM_SCALAR >().fillWith(this->empty_value_);
408  }
409  return Potential< GUM_SCALAR >(gum::projectSum(*this->content(), del_vars));
410  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
virtual bool empty() const final
Returns true if no var is in *this.
virtual const MultiDimImplementation< GUM_SCALAR > * content() const final
Returns the implementation for this object (may be *this).
const Potential< GUM_SCALAR > & fillWith(const Potential< GUM_SCALAR > &src) const
copy a Potential data using name of variables and labels (not necessarily the same variables in the s...
GUM_SCALAR projectSum(const MultiDimImplementation< GUM_SCALAR > &table, Instantiation *instantiation=0)
the function to be used to project a MultiDimImplementation using a sum
GUM_SCALAR empty_value_
value of the MultiDimDecorator if no dimension.
+ Here is the call graph for this function:

◆ max()

template<typename GUM_SCALAR >
INLINE GUM_SCALAR gum::Potential< GUM_SCALAR >::max ( ) const

max of all elements in the Potential

Definition at line 138 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

138  {
139  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(this->content_)->empty()) {
140  return this->empty_value_;
141  }
142  return gum::projectMax(*this->content());
143  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
virtual bool empty() const final
Returns true if no var is in *this.
virtual const MultiDimImplementation< GUM_SCALAR > * content() const final
Returns the implementation for this object (may be *this).
GUM_SCALAR empty_value_
value of the MultiDimDecorator if no dimension.
GUM_SCALAR projectMax(const MultiDimImplementation< GUM_SCALAR > &table, Instantiation *instantiation=0)
the function to be used to project a MultiDimImplementation using a Max
+ Here is the call graph for this function:

◆ maxNonOne()

template<typename GUM_SCALAR >
GUM_SCALAR gum::Potential< GUM_SCALAR >::maxNonOne ( ) const

max of all non one elements in the Potential

Warning
can return 1 if no other value than 1 ...

Definition at line 156 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

156  {
157  GUM_SCALAR res;
158 
159  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(this->content_)->empty()) {
160  res = this->empty_value_;
161  } else {
162  res = this->reduce(
163  [](GUM_SCALAR z, GUM_SCALAR p) {
164  return (p == static_cast< GUM_SCALAR >(1)) ? z
165  : (z == static_cast< GUM_SCALAR >(1)) ? p
166  : (p > z ? p : z);
167  },
168  static_cast< GUM_SCALAR >(1));
169  }
170 
171  return res;
172  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
virtual bool empty() const final
Returns true if no var is in *this.
virtual GUM_SCALAR reduce(std::function< GUM_SCALAR(GUM_SCALAR, GUM_SCALAR) > f, GUM_SCALAR base) const final
compute lfold for this container
GUM_SCALAR empty_value_
value of the MultiDimDecorator if no dimension.
+ Here is the call graph for this function:

◆ min()

template<typename GUM_SCALAR >
INLINE GUM_SCALAR gum::Potential< GUM_SCALAR >::min ( ) const

min of all elements in the Potential

Definition at line 146 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

146  {
147  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(this->content_)->empty()) {
148  return this->empty_value_;
149  }
150  return gum::projectMin(*this->content());
151  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
virtual bool empty() const final
Returns true if no var is in *this.
virtual const MultiDimImplementation< GUM_SCALAR > * content() const final
Returns the implementation for this object (may be *this).
GUM_SCALAR empty_value_
value of the MultiDimDecorator if no dimension.
GUM_SCALAR projectMin(const MultiDimImplementation< GUM_SCALAR > &table, Instantiation *instantiation=0)
the function to be used to project a MultiDimImplementation using a Min
+ Here is the call graph for this function:

◆ minNonZero()

template<typename GUM_SCALAR >
INLINE GUM_SCALAR gum::Potential< GUM_SCALAR >::minNonZero ( ) const

min of all non zero elements in the Potential

Warning
can return 0 if no other value than 0 ...

Definition at line 177 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

177  {
178  GUM_SCALAR res;
179 
180  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(this->content_)->empty()) {
181  res = this->empty_value_;
182  } else {
183  res = this->reduce(
184  [](GUM_SCALAR z, GUM_SCALAR p) {
185  return (p == static_cast< GUM_SCALAR >(0)) ? z
186  : (z == static_cast< GUM_SCALAR >(0)) ? p
187  : (p < z ? p : z);
188  },
189  static_cast< GUM_SCALAR >(0));
190  }
191  return res;
192  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
virtual bool empty() const final
Returns true if no var is in *this.
virtual GUM_SCALAR reduce(std::function< GUM_SCALAR(GUM_SCALAR, GUM_SCALAR) > f, GUM_SCALAR base) const final
compute lfold for this container
GUM_SCALAR empty_value_
value of the MultiDimDecorator if no dimension.
+ Here is the call graph for this function:

◆ nbrDim()

template<typename GUM_SCALAR >
INLINE Idx gum::MultiDimDecorator< GUM_SCALAR >::nbrDim ( ) const
finalvirtualinherited

Returns the number of vars in the multidimensional container.

Returns
Returns the number of vars in the multidimensional container.

Implements gum::MultiDimInterface.

Definition at line 307 of file multiDimDecorator_tpl.h.

References gum::Set< Key, Alloc >::emplace().

307  {
308  return static_cast< MultiDimContainer< GUM_SCALAR >* >(content_)->nbrDim();
309  }
virtual Idx nbrDim() const final
Returns the number of vars in the multidimensional container.
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
+ Here is the call graph for this function:

◆ new_abs()

template<typename GUM_SCALAR >
const Potential< GUM_SCALAR > gum::Potential< GUM_SCALAR >::new_abs ( ) const

Create a new potential and apply abs on every element of the container.

Definition at line 660 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

660  {
661  return Potential< GUM_SCALAR >(*this).abs();
662  }
+ Here is the call graph for this function:

◆ new_log2()

template<typename GUM_SCALAR >
const Potential< GUM_SCALAR > gum::Potential< GUM_SCALAR >::new_log2 ( ) const

Create a new potential and apply $log_2(x)$ on every element of the container.

Definition at line 670 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

670  {
671  return Potential< GUM_SCALAR >(*this).log2();
672  }
+ Here is the call graph for this function:

◆ new_sq()

template<typename GUM_SCALAR >
const Potential< GUM_SCALAR > gum::Potential< GUM_SCALAR >::new_sq ( ) const

Create a new potential and apply $x^2$ on every element of the container.

Definition at line 665 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

665  {
666  return Potential< GUM_SCALAR >(*this).sq();
667  }
+ Here is the call graph for this function:

◆ newFactory()

template<typename GUM_SCALAR >
INLINE Potential< GUM_SCALAR > * gum::Potential< GUM_SCALAR >::newFactory ( ) const
virtual

Default implementation of MultiDimContainer::set().

Calls get_ as a r-value.

Implements gum::MultiDimDecorator< GUM_SCALAR >.

Definition at line 115 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

115  {
116  return new Potential< GUM_SCALAR >(
117  static_cast< MultiDimImplementation< GUM_SCALAR >* >(this->content()->newFactory()));
118  }
virtual const MultiDimImplementation< GUM_SCALAR > * content() const final
Returns the implementation for this object (may be *this).
+ Here is the call graph for this function:

◆ noising()

template<typename GUM_SCALAR >
const Potential< GUM_SCALAR > & gum::Potential< GUM_SCALAR >::noising ( GUM_SCALAR  alpha) const

add a noise in a CPT by mixing (1-alpha)this+alpha.randomCPT()

Warning
alpha in [0,1]

Definition at line 651 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

651  {
652  if ((alpha < GUM_SCALAR(0.0)) || (alpha > GUM_SCALAR(1.0))) {
653  GUM_ERROR(InvalidArgument, "alpha must be in [0,1]")
654  }
655  Potential< GUM_SCALAR > noise(*this);
656  return fillWith(scale(1 - alpha) + noise.randomCPT().scale(alpha)).normalizeAsCPT();
657  }
const Potential< GUM_SCALAR > & scale(GUM_SCALAR v) const
multiply (each value of) *this by v
const Potential< GUM_SCALAR > & normalizeAsCPT(const Idx &varId=0) const
normalisation of this as a CPT for the variable varId
const Potential< GUM_SCALAR > & fillWith(const Potential< GUM_SCALAR > &src) const
copy a Potential data using name of variables and labels (not necessarily the same variables in the s...
#define GUM_ERROR(type, msg)
Definition: exceptions.h:51
+ Here is the call graph for this function:

◆ normalize()

template<typename GUM_SCALAR >
INLINE const Potential< GUM_SCALAR > & gum::Potential< GUM_SCALAR >::normalize ( ) const

normalisation of this do nothing if sum is 0

Definition at line 338 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

338  {
339  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(this->content_)->empty()) {
340  if (this->empty_value_ != static_cast< GUM_SCALAR >(0))
341  this->empty_value_ = static_cast< GUM_SCALAR >(1.0);
342  } else {
343  GUM_SCALAR s = sum();
344 
345  if (s != (GUM_SCALAR)0) {
346  this->apply([s](GUM_SCALAR x) { return x / s; });
347  }
348  }
349  return *this;
350  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
virtual bool empty() const final
Returns true if no var is in *this.
virtual void apply(std::function< GUM_SCALAR(GUM_SCALAR) > f) const final
Apply a function on every element of the container.
GUM_SCALAR sum() const
sum of all elements in the Potential
GUM_SCALAR empty_value_
value of the MultiDimDecorator if no dimension.
+ Here is the call graph for this function:

◆ normalizeAsCPT()

template<typename GUM_SCALAR >
INLINE const Potential< GUM_SCALAR > & gum::Potential< GUM_SCALAR >::normalizeAsCPT ( const Idx varId = 0) const

normalisation of this as a CPT for the variable varId

If the Potential is empty, the argument is not used.

Exceptions
FatalErrorit some distribution sums to 0, or if varId>=nbrDim()

Definition at line 354 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

354  {
355  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(this->content_)->empty()) {
356  if (this->empty_value_ != static_cast< GUM_SCALAR >(0)) {
357  this->empty_value_ = static_cast< GUM_SCALAR >(1.0);
358  } else {
359  GUM_ERROR(FatalError, "Normalization for a potential that sum to 0 in " << *this)
360  }
361  } else {
362  if (varId >= this->nbrDim()) {
363  GUM_ERROR(FatalError, varId << " is not a position for " << *this)
364  }
365  Instantiation inst(*this);
366  const auto& v = this->variable(varId);
367 
368  for (inst.setFirst(); !inst.end(); inst.incNotVar(v)) {
369  GUM_SCALAR s = (GUM_SCALAR)0.0;
370  for (inst.setFirstVar(v); !inst.end(); inst.incVar(v))
371  s += this->get(inst);
372  if (s == (GUM_SCALAR)0.0) {
373  GUM_ERROR(FatalError, "Normalization for a potential that sum to 0 in " << *this)
374  }
375  if (s != (GUM_SCALAR)1.0) {
376  for (inst.setFirstVar(v); !inst.end(); inst.incVar(v))
377  this->set(inst, this->get(inst) / s);
378  }
379  inst.setFirstVar(v); // to remove inst.end()
380  }
381  }
382  return *this;
383  }
virtual Idx nbrDim() const final
Returns the number of vars in the multidimensional container.
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
virtual bool empty() const final
Returns true if no var is in *this.
virtual const DiscreteVariable & variable(Idx) const final
Returns a const ref to the ith var.
GUM_SCALAR empty_value_
value of the MultiDimDecorator if no dimension.
#define GUM_ERROR(type, msg)
Definition: exceptions.h:51
+ Here is the call graph for this function:

◆ notifyChange()

template<typename GUM_SCALAR >
INLINE void gum::MultiDimDecorator< GUM_SCALAR >::notifyChange ( ) const
finalvirtualinherited

Definition at line 291 of file multiDimDecorator_tpl.h.

References gum::Set< Key, Alloc >::emplace().

291  {
292  /*( (MultiDimContainer<GUM_SCALAR> *) content_)->notifyChange();*/
293  GUM_ERROR(OperationNotAllowed, "Not implemented yet")
294  }
#define GUM_ERROR(type, msg)
Definition: exceptions.h:51
+ Here is the call graph for this function:

◆ operator!=() [1/2]

template<typename GUM_SCALAR >
INLINE bool gum::MultiDimContainer< GUM_SCALAR >::operator!= ( const MultiDimContainer< GUM_SCALAR > &  p) const
inherited

Test if this MultiDimContainer is different of p.

Parameters
pThe MultiDimContainer to test for inequality.
Returns
Returns true if this MultiDimContainer is different of p.

Definition at line 154 of file multiDimContainer_tpl.h.

References gum::Set< Key, Alloc >::emplace().

154  {
155  return !operator==(p);
156  }
bool operator==(const MultiDimContainer< GUM_SCALAR > &p) const
Test if this MultiDimContainer is equal to p.
+ Here is the call graph for this function:

◆ operator!=() [2/2]

template<typename GUM_SCALAR>
bool gum::Potential< GUM_SCALAR >::operator!= ( const Potential< GUM_SCALAR > &  r) const
inline

the function to be used to add two Potentials

Definition at line 490 of file potential.h.

References gum::Potential< GUM_SCALAR >::operator==().

490 { return !operator==(r); }
bool operator==(const Potential< GUM_SCALAR > &r) const
the function to be used to add two Potentials
Definition: potential.h:476
+ Here is the call graph for this function:

◆ operator*() [1/2]

template<typename GUM_SCALAR>
Potential< GUM_SCALAR > gum::Potential< GUM_SCALAR >::operator* ( const Potential< GUM_SCALAR > &  p2) const
inline

the function to be used to multiply two Potentials

Definition at line 413 of file potential.h.

413  {
414  if (p2.empty()) return Potential< GUM_SCALAR >(*this).scale(p2.empty_value_);
415  if (this->empty()) return Potential< GUM_SCALAR >(p2).scale(this->empty_value_);
416 
417  return Potential< GUM_SCALAR >(*this->content() * *p2.content());
418  }
const Potential< GUM_SCALAR > & scale(GUM_SCALAR v) const
multiply (each value of) *this by v
virtual bool empty() const final
Returns true if no var is in *this.
virtual const MultiDimImplementation< GUM_SCALAR > * content() const final
Returns the implementation for this object (may be *this).
GUM_SCALAR empty_value_
value of the MultiDimDecorator if no dimension.

◆ operator*() [2/2]

template<typename GUM_SCALAR>
Potential< GUM_SCALAR > gum::Potential< GUM_SCALAR >::operator* ( const GUM_SCALAR &  v) const
inline

the function to be used to multiply a Potential and a scalar

Definition at line 421 of file potential.h.

421  {
422  return Potential< GUM_SCALAR >(*this).scale(v);
423  }

◆ operator*=() [1/2]

template<typename GUM_SCALAR>
Potential< GUM_SCALAR >& gum::Potential< GUM_SCALAR >::operator*= ( const Potential< GUM_SCALAR > &  r)
inline

the function to be used to add two Potentials

Definition at line 449 of file potential.h.

449  {
450  *this = *this * r;
451  return *this;
452  }

◆ operator*=() [2/2]

template<typename GUM_SCALAR>
Potential< GUM_SCALAR >& gum::Potential< GUM_SCALAR >::operator*= ( const GUM_SCALAR &  v)
inline

the function to be used to add two Potentials

Definition at line 453 of file potential.h.

453  {
454  this->scale(v);
455  return *this;
456  }
const Potential< GUM_SCALAR > & scale(GUM_SCALAR v) const
multiply (each value of) *this by v

◆ operator+() [1/2]

template<typename GUM_SCALAR>
Potential< GUM_SCALAR > gum::Potential< GUM_SCALAR >::operator+ ( const Potential< GUM_SCALAR > &  p2) const
inline

the function to be used to add two Potentials

Definition at line 384 of file potential.h.

384  {
385  if (p2.empty()) return Potential< GUM_SCALAR >(*this).translate(p2.empty_value_);
386  if (this->empty()) return Potential< GUM_SCALAR >(p2).translate(this->empty_value_);
387 
388  return Potential< GUM_SCALAR >(*this->content() + *p2.content());
389  }
virtual bool empty() const final
Returns true if no var is in *this.
virtual const MultiDimImplementation< GUM_SCALAR > * content() const final
Returns the implementation for this object (may be *this).
GUM_SCALAR empty_value_
value of the MultiDimDecorator if no dimension.
const Potential< GUM_SCALAR > & translate(GUM_SCALAR v) const
add v to (each value of) *this

◆ operator+() [2/2]

template<typename GUM_SCALAR>
Potential< GUM_SCALAR > gum::Potential< GUM_SCALAR >::operator+ ( const GUM_SCALAR &  v) const
inline

the function to be used to add a GUM_SCALAR to a Potential

Definition at line 392 of file potential.h.

392  {
393  return Potential< GUM_SCALAR >(*this).translate(v);
394  }

◆ operator+=() [1/2]

template<typename GUM_SCALAR>
Potential< GUM_SCALAR >& gum::Potential< GUM_SCALAR >::operator+= ( const Potential< GUM_SCALAR > &  r)
inline

the function to be used to add two Potentials

Definition at line 440 of file potential.h.

440  {
441  *this = *this + r;
442  return *this;
443  }

◆ operator+=() [2/2]

template<typename GUM_SCALAR>
Potential< GUM_SCALAR >& gum::Potential< GUM_SCALAR >::operator+= ( const GUM_SCALAR &  v)
inline

the function to be used to add two Potentials

Definition at line 444 of file potential.h.

444  {
445  this->translate(v);
446  return *this;
447  }
const Potential< GUM_SCALAR > & translate(GUM_SCALAR v) const
add v to (each value of) *this

◆ operator-() [1/2]

template<typename GUM_SCALAR>
Potential< GUM_SCALAR > gum::Potential< GUM_SCALAR >::operator- ( const Potential< GUM_SCALAR > &  p2) const
inline

the function to be used to subtract two Potentials

Definition at line 397 of file potential.h.

397  {
398  if (p2.empty()) return Potential< GUM_SCALAR >(*this).translate(-p2.empty_value_);
399  if (this->empty()) {
400  auto p = Potential< GUM_SCALAR >(p2);
401  p.apply([this](GUM_SCALAR x) { return this->empty_value_ - x; });
402  return p;
403  }
404  return Potential< GUM_SCALAR >(*this->content() - *p2.content());
405  }
virtual bool empty() const final
Returns true if no var is in *this.
virtual const MultiDimImplementation< GUM_SCALAR > * content() const final
Returns the implementation for this object (may be *this).
GUM_SCALAR empty_value_
value of the MultiDimDecorator if no dimension.

◆ operator-() [2/2]

template<typename GUM_SCALAR>
Potential< GUM_SCALAR > gum::Potential< GUM_SCALAR >::operator- ( const GUM_SCALAR &  v) const
inline

the function to be used to substract a GUM_SCALAR from a Potential

Definition at line 408 of file potential.h.

408  {
409  return Potential< GUM_SCALAR >(*this).translate(-v);
410  }

◆ operator-=() [1/2]

template<typename GUM_SCALAR>
Potential< GUM_SCALAR >& gum::Potential< GUM_SCALAR >::operator-= ( const Potential< GUM_SCALAR > &  r)
inline

the function to be used to add two Potentials

Definition at line 458 of file potential.h.

458  {
459  *this = *this - r;
460  return *this;
461  }

◆ operator-=() [2/2]

template<typename GUM_SCALAR>
Potential< GUM_SCALAR >& gum::Potential< GUM_SCALAR >::operator-= ( const GUM_SCALAR &  v)
inline

the function to be used to add two Potentials

Definition at line 462 of file potential.h.

462  {
463  this->translate(-v);
464  return *this;
465  }
const Potential< GUM_SCALAR > & translate(GUM_SCALAR v) const
add v to (each value of) *this

◆ operator/() [1/2]

template<typename GUM_SCALAR>
Potential< GUM_SCALAR > gum::Potential< GUM_SCALAR >::operator/ ( const Potential< GUM_SCALAR > &  p2) const
inline

the function to be used to divide two Potentials

Definition at line 426 of file potential.h.

426  {
427  if (p2.empty()) return Potential< GUM_SCALAR >(*this).scale(1 / p2.empty_value_);
428  if (this->empty()) {
429  auto p = Potential< GUM_SCALAR >(p2);
430  p.apply([this](GUM_SCALAR x) { return this->empty_value_ / x; });
431  return p;
432  }
433  return Potential< GUM_SCALAR >(*this->content() / *p2.content());
434  }
virtual bool empty() const final
Returns true if no var is in *this.
virtual const MultiDimImplementation< GUM_SCALAR > * content() const final
Returns the implementation for this object (may be *this).
GUM_SCALAR empty_value_
value of the MultiDimDecorator if no dimension.

◆ operator/() [2/2]

template<typename GUM_SCALAR>
Potential< GUM_SCALAR > gum::Potential< GUM_SCALAR >::operator/ ( const GUM_SCALAR &  v) const
inline

the function to be used to divide a Potential by a scalar

Definition at line 436 of file potential.h.

436  {
437  return Potential< GUM_SCALAR >(*this).scale(1 / v);
438  }

◆ operator/=() [1/2]

template<typename GUM_SCALAR>
Potential< GUM_SCALAR >& gum::Potential< GUM_SCALAR >::operator/= ( const Potential< GUM_SCALAR > &  r)
inline

the function to be used to add two Potentials

Definition at line 467 of file potential.h.

467  {
468  *this = *this / r;
469  return *this;
470  }

◆ operator/=() [2/2]

template<typename GUM_SCALAR>
Potential< GUM_SCALAR >& gum::Potential< GUM_SCALAR >::operator/= ( const GUM_SCALAR &  v)
inline

the function to be used to add two Potentials

Definition at line 471 of file potential.h.

471  {
472  this->scale(1 / v);
473  return *this;
474  }
const Potential< GUM_SCALAR > & scale(GUM_SCALAR v) const
multiply (each value of) *this by v

◆ operator<<()

template<typename GUM_SCALAR>
Potential< GUM_SCALAR >& gum::Potential< GUM_SCALAR >::operator<< ( const DiscreteVariable v)
inline

the function to be used to add two Potentials

Definition at line 492 of file potential.h.

492  {
493  this->add(v);
494  return *this;
495  }
virtual void add(const DiscreteVariable &v) final
Adds a new var to the variables of the multidimensional matrix.

◆ operator=() [1/2]

template<typename GUM_SCALAR >
Potential< GUM_SCALAR > & gum::Potential< GUM_SCALAR >::operator= ( const Potential< GUM_SCALAR > &  src)

Default constructor.

Creates an empty null dimensional matrix with a MultiDimArray as its implementation.

Definition at line 89 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

89  {
90  GUM_OP_CPY(Potential);
91  if (&src == this) return *this;
93  return *this;
94  }
MultiDimDecorator< GUM_SCALAR > & operator=(const MultiDimDecorator &from) noexcept
copy operator
Potential()
Default constructor.
Definition: potential_tpl.h:37
+ Here is the call graph for this function:

◆ operator=() [2/2]

template<typename GUM_SCALAR >
Potential< GUM_SCALAR > & gum::Potential< GUM_SCALAR >::operator= ( Potential< GUM_SCALAR > &&  src)

Default constructor.

Creates an empty null dimensional matrix with a MultiDimArray as its implementation.

Definition at line 98 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

98  {
99  GUM_OP_MOV(Potential);
100  if (&src == this) return *this;
102  std::forward< MultiDimDecorator< GUM_SCALAR > >(src));
103  return *this;
104  }
MultiDimDecorator< GUM_SCALAR > & operator=(const MultiDimDecorator &from) noexcept
copy operator
Potential()
Default constructor.
Definition: potential_tpl.h:37
+ Here is the call graph for this function:

◆ operator==() [1/2]

template<typename GUM_SCALAR >
bool gum::MultiDimContainer< GUM_SCALAR >::operator== ( const MultiDimContainer< GUM_SCALAR > &  p) const
inherited

Test if this MultiDimContainer is equal to p.

Parameters
pThe MultiDimContainer to test for equality.
Returns
Returns true if this MultiDimContainer is equal to p.

Definition at line 124 of file multiDimContainer_tpl.h.

References gum::Set< Key, Alloc >::emplace().

124  {
125  if ((nbrDim() == p.nbrDim()) && (domainSize() == p.domainSize())) {
126  if (nbrDim() == 0) return true;
127 
129 
130  for (var_iterator iter = variablesSequence().beginSafe();
131  iter != variablesSequence().endSafe();
132  ++iter) {
133  if (!p.variablesSequence().exists(*iter)) { return false; }
134  }
135  } else {
136  return false;
137  }
138 
139  Instantiation i(*this);
140 
141  AlmostDifferent< GUM_SCALAR > cmp;
142 
143  for (i.setFirst(); !i.end(); ++i) {
144  if (cmp(get(i), p.get(i))) { return false; }
145  }
146 
147  return true;
148  }
virtual Idx nbrDim() const =0
Returns the number of vars in the multidimensional container.
virtual Size domainSize() const =0
Returns the product of the variables domain size.
virtual const Sequence< const DiscreteVariable *> & variablesSequence() const =0
Returns a const ref to the sequence of DiscreteVariable*.
SequenceIteratorSafe< Key > const_iterator_safe
Types for STL compliance.
Definition: sequence.h:1032
+ Here is the call graph for this function:

◆ operator==() [2/2]

template<typename GUM_SCALAR>
bool gum::Potential< GUM_SCALAR >::operator== ( const Potential< GUM_SCALAR > &  r) const
inline

the function to be used to add two Potentials

Definition at line 476 of file potential.h.

Referenced by gum::Potential< GUM_SCALAR >::operator!=().

476  {
477  if (this->empty()) {
478  if (r.empty())
479  return this->empty_value_ == r.empty_value_;
480  else
481  return false;
482  } else {
483  if (r.empty())
484  return false;
485  else
486  return (*this->content_) == (*r.content_);
487  }
488  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
virtual bool empty() const final
Returns true if no var is in *this.
GUM_SCALAR empty_value_
value of the MultiDimDecorator if no dimension.
+ Here is the caller graph for this function:

◆ operator[]()

template<typename GUM_SCALAR >
INLINE GUM_SCALAR gum::MultiDimContainer< GUM_SCALAR >::operator[] ( const Instantiation i) const
inherited

An [] operator using a Instantiation as argument.

Warning
If i variables set is disjoint with this MultiDimContainer then 0 is assumed for dimensions (i.e. variables) not prensent in the instantiation.
Parameters
iAn Instantiation.
Returns
Returns the adressed (GUM_SCALAR) value.

Definition at line 79 of file multiDimContainer_tpl.h.

References gum::Set< Key, Alloc >::emplace().

79  {
80  return get(i);
81  }
+ Here is the call graph for this function:

◆ populate() [1/2]

template<typename GUM_SCALAR >
void gum::MultiDimDecorator< GUM_SCALAR >::populate ( const std::vector< GUM_SCALAR > &  v) const
finalvirtualinherited

Automatically fills this MultiDimContainer with the values in v.

The order used to fill this MultiDimContainer is the same as with an instantiation over it.

Size cpt = 0;
Instantiation i( *this );
for (i.setFirst(); !i.end(); ++i, ++cpt) {
set(i, v[cpt]);
}
Parameters
vVector of values.
Exceptions
SizeErrorRaised if v size's does not matches this MultiDimContainer domain size.

Reimplemented from gum::MultiDimContainer< GUM_SCALAR >.

Definition at line 312 of file multiDimDecorator_tpl.h.

References gum::Set< Key, Alloc >::emplace().

312  {
313  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(content_)->empty()) {
314  if (v.size() == 1) {
315  empty_value_ = v[0];
316  } else {
317  GUM_ERROR(SizeError, "Size do not match in populate")
318  }
319  } else {
320  content_->populate(v);
321  }
322  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
virtual bool empty() const final
Returns true if no var is in *this.
GUM_SCALAR empty_value_
value of the MultiDimDecorator if no dimension.
#define GUM_ERROR(type, msg)
Definition: exceptions.h:51
+ Here is the call graph for this function:

◆ populate() [2/2]

template<typename GUM_SCALAR >
void gum::MultiDimContainer< GUM_SCALAR >::populate ( std::initializer_list< GUM_SCALAR >  l) const
virtualinherited

Automatically fills this MultiDimContainer with the values in l.

The order used to fill this MultiDimContainer is the same as with an instantiation over it.

Size cpt = 0;
Instantiation i( *this );
for (i.setFirst(); !i.end(); ++i, ++cpt) {
set(i, v[cpt]);
}
Parameters
lcontains the data.
Exceptions
SizeErrorRaised if l size's does not matches this MultiDimContainer domain size.

Reimplemented in gum::MultiDimBijArray< GUM_SCALAR >, gum::MultiDimFunctionGraph< GUM_SCALAR, TerminalNodePolicy >, gum::MultiDimFunctionGraph< GUM_SCALAR >, and gum::MultiDimFunctionGraph< GUM_SCALAR, ExactTerminalNodePolicy >.

Definition at line 174 of file multiDimContainer_tpl.h.

References gum::Set< Key, Alloc >::emplace().

174  {
175  if (domainSize() != l.size()) {
176  GUM_ERROR(SizeError, "Sizes do not match : " << domainSize() << "!=" << l.size())
177  }
178 
179  Instantiation i(*this);
180  // insert all the elements
181  for (const auto& elt: l) {
182  set(i, elt);
183  ++i;
184  }
185  }
virtual Size domainSize() const =0
Returns the product of the variables domain size.
#define GUM_ERROR(type, msg)
Definition: exceptions.h:51
+ Here is the call graph for this function:

◆ pos()

template<typename GUM_SCALAR >
INLINE Idx gum::MultiDimDecorator< GUM_SCALAR >::pos ( const DiscreteVariable v) const
finalvirtualinherited

Returns the index of a variable.

Parameters
vThe variable for which the index is returned.
Returns
Returns the index of a variable.
Exceptions
NotFoundRaised if v is not in this multidimensional matrix.

Implements gum::MultiDimInterface.

Definition at line 259 of file multiDimDecorator_tpl.h.

References gum::Set< Key, Alloc >::emplace().

259  {
260  return static_cast< MultiDimContainer< GUM_SCALAR >* >(content_)->pos(var);
261  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
virtual Idx pos(const DiscreteVariable &var) const final
Returns the index of a variable.
+ Here is the call graph for this function:

◆ product()

template<typename GUM_SCALAR >
INLINE GUM_SCALAR gum::Potential< GUM_SCALAR >::product ( ) const

product of all elements in the Potential

Definition at line 130 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

130  {
131  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(this->content_)->empty()) {
132  return this->empty_value_;
133  }
134  return gum::projectProduct(*this->content());
135  }
GUM_SCALAR projectProduct(const MultiDimImplementation< GUM_SCALAR > &table, Instantiation *instantiation=0)
the function to be used to project a MultiDimImplementation using a Product
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
virtual bool empty() const final
Returns true if no var is in *this.
virtual const MultiDimImplementation< GUM_SCALAR > * content() const final
Returns the implementation for this object (may be *this).
GUM_SCALAR empty_value_
value of the MultiDimDecorator if no dimension.
+ Here is the call graph for this function:

◆ putFirst() [1/2]

template<typename GUM_SCALAR >
Potential< GUM_SCALAR > gum::Potential< GUM_SCALAR >::putFirst ( const DiscreteVariable var) const

create a new Potential with a certain variable in first

Exceptions
InvalidArgumentif the var is not in the potential

Definition at line 540 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

540  {
541  if (!this->contains(*var)) {
542  GUM_ERROR(InvalidArgument, "The variable to put first does not belong to the potential")
543  }
544  if (&(this->variable(0)) == var) return Potential< GUM_SCALAR >(*this);
545 
546  std::vector< const DiscreteVariable* > vars;
547  vars.push_back(var);
548  for (Idx i = 0; i < this->nbrDim(); i++)
549  if (&(this->variable(i)) != var) vars.push_back(&(this->variable(i)));
550 
551  return this->reorganize(vars);
552  }
virtual Idx nbrDim() const final
Returns the number of vars in the multidimensional container.
virtual const DiscreteVariable & variable(Idx) const final
Returns a const ref to the ith var.
Potential< GUM_SCALAR > reorganize(const std::vector< const DiscreteVariable * > &vars) const
create a new Potential with another order
virtual bool contains(const DiscreteVariable &var) const final
Returns true if var is in *this.
#define GUM_ERROR(type, msg)
Definition: exceptions.h:51
+ Here is the call graph for this function:

◆ putFirst() [2/2]

template<typename GUM_SCALAR >
Potential< GUM_SCALAR > gum::Potential< GUM_SCALAR >::putFirst ( const std::string &  varname) const

create a new Potential with a certain variable in first

Exceptions
InvalidArgumentif the var is not in the potential

Definition at line 555 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

555  {
556  const DiscreteVariable* var = nullptr;
557 
558  for (gum::Idx i = 0; i < this->nbrDim(); i++)
559  if (this->variable(i).name() == varname) {
560  var = &(this->variable(i));
561  break;
562  }
563  if (var == nullptr)
564  GUM_ERROR(InvalidArgument,
565  "The variable '" << varname << "' to put first does not belong to the potential");
566  return this->putFirst(var);
567  }
virtual Idx nbrDim() const final
Returns the number of vars in the multidimensional container.
virtual const DiscreteVariable & variable(Idx) const final
Returns a const ref to the ith var.
Size Idx
Type for indexes.
Definition: types.h:52
const std::string & name() const
returns the name of the variable
Potential< GUM_SCALAR > putFirst(const DiscreteVariable *var) const
create a new Potential with a certain variable in first
#define GUM_ERROR(type, msg)
Definition: exceptions.h:51
+ Here is the call graph for this function:

◆ random()

template<typename GUM_SCALAR >
const Potential< GUM_SCALAR > & gum::Potential< GUM_SCALAR >::random ( ) const

generate a random Potential with each parameter in [0,1]

Definition at line 622 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

622  {
623  if (this->domainSize() == 0) return *this;
624 
625  std::vector< GUM_SCALAR > v;
626  GUM_SCALAR sum;
627  v.reserve(this->domainSize());
628  sum = 0.0;
629  for (Size i = 0; i < this->domainSize(); ++i) {
630  auto r = (GUM_SCALAR)randomProba();
631  v.push_back(r);
632  sum += r;
633  }
634  if (sum == 0.0) v[gum::randomValue(this->domainSize())] = 1.0; // a 1 somewhere
635 
636  this->fillWith(v);
637  return *this;
638  }
virtual Size domainSize() const final
Returns the product of the variables domain size.
Idx randomValue(const Size max=2)
Returns a random Idx between 0 and max-1 included.
double randomProba()
Returns a random double between 0 and 1 included (i.e.
const Potential< GUM_SCALAR > & fillWith(const Potential< GUM_SCALAR > &src) const
copy a Potential data using name of variables and labels (not necessarily the same variables in the s...
GUM_SCALAR sum() const
sum of all elements in the Potential
std::size_t Size
In aGrUM, hashed values are unsigned long int.
Definition: types.h:47
+ Here is the call graph for this function:

◆ randomCPT()

template<typename GUM_SCALAR >
INLINE const Potential< GUM_SCALAR > & gum::Potential< GUM_SCALAR >::randomCPT ( ) const

generate a random CPT in the Potential

Definition at line 646 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

646  {
647  return this->random().normalizeAsCPT();
648  }
const Potential< GUM_SCALAR > & random() const
generate a random Potential with each parameter in [0,1]
+ Here is the call graph for this function:

◆ randomDistribution()

template<typename GUM_SCALAR >
INLINE const Potential< GUM_SCALAR > & gum::Potential< GUM_SCALAR >::randomDistribution ( ) const

generate a random Distribution in the Potential

Definition at line 641 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

641  {
642  return this->random().normalize();
643  }
const Potential< GUM_SCALAR > & random() const
generate a random Potential with each parameter in [0,1]
+ Here is the call graph for this function:

◆ reduce()

template<typename GUM_SCALAR >
GUM_SCALAR gum::MultiDimDecorator< GUM_SCALAR >::reduce ( std::function< GUM_SCALAR(GUM_SCALAR, GUM_SCALAR) >  f,
GUM_SCALAR  base 
) const
finalvirtualinherited

compute lfold for this container

Parameters
fthe function to apply
basethe initial value

Reimplemented from gum::MultiDimContainer< GUM_SCALAR >.

Definition at line 335 of file multiDimDecorator_tpl.h.

References gum::Set< Key, Alloc >::emplace().

336  {
337  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(content_)->empty()) {
338  return base;
339  } else {
340  return content_->reduce(f, base);
341  }
342  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
virtual bool empty() const final
Returns true if no var is in *this.
+ Here is the call graph for this function:

◆ registerSlave()

template<typename GUM_SCALAR >
INLINE bool gum::MultiDimDecorator< GUM_SCALAR >::registerSlave ( Instantiation i)
finalvirtualinherited

Register i as a slave of this MultiDimAdressable.

Parameters
iThe Instantiation to enslave.
Returns
Returns true if i becomes a slave of this MultiDimAdressable.

Implements gum::MultiDimAdressable.

Definition at line 233 of file multiDimDecorator_tpl.h.

References gum::Set< Key, Alloc >::emplace().

233  {
234  return static_cast< MultiDimContainer< GUM_SCALAR >* >(content_)->registerSlave(i);
235  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
virtual bool registerSlave(Instantiation &i) final
Register i as a slave of this MultiDimAdressable.
+ Here is the call graph for this function:

◆ reorganize() [1/2]

template<typename GUM_SCALAR >
Potential< GUM_SCALAR > gum::Potential< GUM_SCALAR >::reorganize ( const std::vector< const DiscreteVariable * > &  vars) const

create a new Potential with another order

Exceptions
InvalidArgumentif not all and only the vars of the potential are in vars

Definition at line 500 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

500  {
501  if (vars.size() != this->nbrDim())
502  GUM_ERROR(InvalidArgument,
503  "The vector contains " << vars.size() << " variables instead of " << this->nbrDim()
504  << ".");
505  for (const auto var: vars) {
506  if (!this->contains(*var))
507  GUM_ERROR(InvalidArgument, "A variable in the vector does not belong to the potential.")
508  }
509 
510  Potential< GUM_SCALAR > p;
511  p.beginMultipleChanges();
512  for (const auto var: vars)
513  p.add(*var);
514  p.endMultipleChanges();
515  p.copyFrom(*this, nullptr); // copy *this in p using the same order
516 
517  return p;
518  }
virtual Idx nbrDim() const final
Returns the number of vars in the multidimensional container.
virtual bool contains(const DiscreteVariable &var) const final
Returns true if var is in *this.
#define GUM_ERROR(type, msg)
Definition: exceptions.h:51
+ Here is the call graph for this function:

◆ reorganize() [2/2]

template<typename GUM_SCALAR >
Potential< GUM_SCALAR > gum::Potential< GUM_SCALAR >::reorganize ( const std::vector< std::string > &  vars) const

create a new Potential with another order

Exceptions
InvalidArgumentif not all and only the vars of the potential are in vars

Definition at line 522 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

522  {
523  std::vector< const DiscreteVariable* > res;
524 
526  for (gum::Idx i = 0; i < this->nbrDim(); i++)
527  namesToVars.insert(this->variable(i).name(), &(this->variable(i)));
528 
529  for (const auto& name: vars) {
530  if (!namesToVars.exists(name)) {
532  "'" << name << "' is a not a name of a variable in this potential");
533  }
534  res.push_back(namesToVars[name]);
535  }
536  return reorganize(res);
537  }
virtual Idx nbrDim() const final
Returns the number of vars in the multidimensional container.
bool exists(const Key &key) const
Checks whether there exists an element with a given key in the hashtable.
virtual const DiscreteVariable & variable(Idx) const final
Returns a const ref to the ith var.
Potential< GUM_SCALAR > reorganize(const std::vector< const DiscreteVariable * > &vars) const
create a new Potential with another order
Size Idx
Type for indexes.
Definition: types.h:52
value_type & insert(const Key &key, const Val &val)
Adds a new element (actually a copy of this element) into the hash table.
#define GUM_ERROR(type, msg)
Definition: exceptions.h:51
+ Here is the call graph for this function:

◆ replace()

INLINE void gum::MultiDimInterface::replace ( const DiscreteVariable x,
const DiscreteVariable y 
)
inherited

Replace variables in this multidim.

If x is in this MultiDim and y has the same domain size, then x will be replace by y in this MultiDim.

Parameters
xThe variable in this which will be replaced.
yThe variable replacing y.
Exceptions
NotFoundRaised if x does not belong to this MultiDim.
OperationNotAllowedIf y and x are not interchangeable.
DuplicateElementIf y is already in this MultiDim.

Definition at line 35 of file multiDimInterface_inl.h.

References gum::Set< Key, Alloc >::emplace().

35  {
36  if (!contains(x)) { GUM_ERROR(NotFound, "could not find the variable") }
37 
38  if (contains(y)) { GUM_ERROR(DuplicateElement, "variable " << y << " already in MultiDim") }
39 
40  if (x.domainSize() != y.domainSize()) {
41  GUM_ERROR(OperationNotAllowed, "incompatible variables")
42  }
43 
44  replace_(&x, &y);
45  }
virtual bool contains(const DiscreteVariable &v) const =0
Returns true if var is in *this.
virtual void replace_(const DiscreteVariable *x, const DiscreteVariable *y)=0
This is called by MultiDimContainer::replace() to proceed with the replacing between x and y...
#define GUM_ERROR(type, msg)
Definition: exceptions.h:51
+ Here is the call graph for this function:

◆ replace_()

template<typename GUM_SCALAR >
INLINE void gum::MultiDimDecorator< GUM_SCALAR >::replace_ ( const DiscreteVariable x,
const DiscreteVariable y 
)
protectedvirtualinherited

This is called by MultiDimContainer::replace() to proceed with the replacing between x and y.

This is called only when everything have been checked.

Parameters
xThe variable to replace in
yThe second variable to swap.

Implements gum::MultiDimInterface.

Definition at line 394 of file multiDimDecorator_tpl.h.

References gum::Set< Key, Alloc >::emplace().

395  {
396  this->content()->replace(*x, *y);
397  }
virtual const MultiDimImplementation< GUM_SCALAR > * content() const final
Returns the implementation for this object (may be *this).
+ Here is the call graph for this function:

◆ scale()

template<typename GUM_SCALAR >
INLINE const Potential< GUM_SCALAR > & gum::Potential< GUM_SCALAR >::scale ( GUM_SCALAR  v) const

multiply (each value of) *this by v

Definition at line 386 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

386  {
387  this->apply([v](GUM_SCALAR x) { return x * v; });
388  return *this;
389  }
virtual void apply(std::function< GUM_SCALAR(GUM_SCALAR) > f) const final
Apply a function on every element of the container.
+ Here is the call graph for this function:

◆ set()

template<typename GUM_SCALAR >
INLINE void gum::MultiDimDecorator< GUM_SCALAR >::set ( const Instantiation i,
const GUM_SCALAR &  value 
) const
finalvirtualinherited

Default implementation of MultiDimContainer::set().

Calls get_ as a r-value.

Reimplemented from gum::MultiDimContainer< GUM_SCALAR >.

Definition at line 156 of file multiDimDecorator_tpl.h.

References gum::Set< Key, Alloc >::emplace().

157  {
158  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(content_)->nbrDim() == 0) {
159  empty_value_ = value;
160  } else {
161  static_cast< MultiDimContainer< GUM_SCALAR >* >(content_)->set(i, value);
162  }
163  }
virtual Idx nbrDim() const final
Returns the number of vars in the multidimensional container.
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
GUM_SCALAR empty_value_
value of the MultiDimDecorator if no dimension.
+ Here is the call graph for this function:

◆ setChangeNotification()

template<typename GUM_SCALAR >
INLINE void gum::MultiDimDecorator< GUM_SCALAR >::setChangeNotification ( const Instantiation i)
finalvirtualinherited

Listen to an assignment of a value in a Instantiation.

Parameters
iThe Instantiation to listen.

Implements gum::MultiDimAdressable.

Definition at line 198 of file multiDimDecorator_tpl.h.

References gum::Set< Key, Alloc >::emplace().

198  {
199  static_cast< MultiDimContainer< GUM_SCALAR >* >(content_)->setChangeNotification(i);
200  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
virtual void setChangeNotification(const Instantiation &i) final
Listen to an assignment of a value in a Instantiation.
+ Here is the call graph for this function:

◆ setDecNotification()

template<typename GUM_SCALAR >
INLINE void gum::MultiDimDecorator< GUM_SCALAR >::setDecNotification ( const Instantiation i)
finalvirtualinherited

Listen to increment in each recorded Instantiation.

Parameters
iThe Instantiation to listen.

Implements gum::MultiDimAdressable.

Definition at line 226 of file multiDimDecorator_tpl.h.

References gum::Set< Key, Alloc >::emplace().

226  {
227  static_cast< MultiDimContainer< GUM_SCALAR >* >(content_)->setDecNotification(i);
228  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
virtual void setDecNotification(const Instantiation &i) final
Listen to increment in each recorded Instantiation.
+ Here is the call graph for this function:

◆ setFirstNotification()

template<typename GUM_SCALAR >
INLINE void gum::MultiDimDecorator< GUM_SCALAR >::setFirstNotification ( const Instantiation i)
finalvirtualinherited

Listen to setFirst in a given Instantiation.

Parameters
iThe Instantiation to listen.

Implements gum::MultiDimAdressable.

Definition at line 205 of file multiDimDecorator_tpl.h.

References gum::Set< Key, Alloc >::emplace().

205  {
206  static_cast< MultiDimContainer< GUM_SCALAR >* >(content_)->setFirstNotification(i);
207  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
virtual void setFirstNotification(const Instantiation &i) final
Listen to setFirst in a given Instantiation.
+ Here is the call graph for this function:

◆ setIncNotification()

template<typename GUM_SCALAR >
INLINE void gum::MultiDimDecorator< GUM_SCALAR >::setIncNotification ( const Instantiation i)
finalvirtualinherited

Listen to increment in a given Instantiation.

Parameters
iThe Instantiation to listen.

Implements gum::MultiDimAdressable.

Definition at line 219 of file multiDimDecorator_tpl.h.

References gum::Set< Key, Alloc >::emplace().

219  {
220  static_cast< MultiDimContainer< GUM_SCALAR >* >(content_)->setIncNotification(i);
221  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
virtual void setIncNotification(const Instantiation &i) final
Listen to increment in a given Instantiation.
+ Here is the call graph for this function:

◆ setLastNotification()

template<typename GUM_SCALAR >
INLINE void gum::MultiDimDecorator< GUM_SCALAR >::setLastNotification ( const Instantiation i)
finalvirtualinherited

Listen to setLast in a given Instantiation.

Parameters
iThe Instantiation to listen.

Implements gum::MultiDimAdressable.

Definition at line 212 of file multiDimDecorator_tpl.h.

References gum::Set< Key, Alloc >::emplace().

212  {
213  static_cast< MultiDimContainer< GUM_SCALAR >* >(content_)->setLastNotification(i);
214  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
virtual void setLastNotification(const Instantiation &i) final
Listen to setLast in a given Instantiation.
+ Here is the call graph for this function:

◆ sq()

template<typename GUM_SCALAR >
INLINE const Potential< GUM_SCALAR > & gum::Potential< GUM_SCALAR >::sq ( ) const

apply $x^2$ on every element of the container

Definition at line 282 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

282  {
283  this->apply([](GUM_SCALAR x) { return x * x; });
284  return *this;
285  }
virtual void apply(std::function< GUM_SCALAR(GUM_SCALAR) > f) const final
Apply a function on every element of the container.
+ Here is the call graph for this function:

◆ sum()

template<typename GUM_SCALAR >
INLINE GUM_SCALAR gum::Potential< GUM_SCALAR >::sum ( ) const

sum of all elements in the Potential

Definition at line 122 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

122  {
123  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(this->content_)->empty()) {
124  return this->empty_value_;
125  }
126  return gum::projectSum(*this->content());
127  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
virtual bool empty() const final
Returns true if no var is in *this.
virtual const MultiDimImplementation< GUM_SCALAR > * content() const final
Returns the implementation for this object (may be *this).
GUM_SCALAR projectSum(const MultiDimImplementation< GUM_SCALAR > &table, Instantiation *instantiation=0)
the function to be used to project a MultiDimImplementation using a sum
GUM_SCALAR empty_value_
value of the MultiDimDecorator if no dimension.
+ Here is the call graph for this function:

◆ swapContent_()

template<typename GUM_SCALAR >
INLINE void gum::MultiDimDecorator< GUM_SCALAR >::swapContent_ ( MultiDimImplementation< GUM_SCALAR > *  aContent) const
protectedinherited

protecte method to swap the implementation behind the Potential

Warning
unsafe method for slave Instantiations !

Definition at line 373 of file multiDimDecorator_tpl.h.

References gum::Set< Key, Alloc >::emplace().

374  {
375  if (aContent != nullptr) {
376  // TODO : frees all slave instantiations
377  // TODO : control the dimensions ?
378  MultiDimImplementation< GUM_SCALAR >* tmp = content_;
379  content_ = aContent;
380  // registers all instantiations
381  delete (tmp);
382  }
383  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
+ Here is the call graph for this function:

◆ toString() [1/2]

template<typename GUM_SCALAR >
INLINE std::string gum::MultiDimDecorator< GUM_SCALAR >::toString ( const Instantiation i) const
virtualinherited

Default implementation of MultiDimContainer::set().

Calls get_ as a r-value.

Implements gum::MultiDimContainer< GUM_SCALAR >.

Definition at line 388 of file multiDimDecorator_tpl.h.

References gum::Set< Key, Alloc >::emplace().

388  {
389  return content_->toString(i);
390  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
+ Here is the call graph for this function:

◆ toString() [2/2]

template<typename GUM_SCALAR>
virtual std::string gum::Potential< GUM_SCALAR >::toString ( ) const
inlinevirtual

the function to be used to add two Potentials

Reimplemented from gum::MultiDimDecorator< GUM_SCALAR >.

Definition at line 497 of file potential.h.

497  {
498  auto table = this->content();
499  if (table->nbrDim() == 0) { return "[]"; }
500  const Size colwidth = 6;
501  const Size numberwidth = 9;
502  const Size nbrLigMax = 6;
503 
504  std::stringstream ss;
505  ss << std::left << std::fixed << std::endl;
506  ss.precision(numberwidth - 5);
507 
508  const auto& var = table->variable(0);
509 
510  const Size nbparents = table->nbrDim() - 1;
511  const Size nbcol = var.domainSize();
512  const std::string maskparent(colwidth, '-');
513  const std::string masknumber(numberwidth, '-');
514 
515  if (nbparents > 0)
516  ss << std::setw(nbparents * (colwidth + 1) - 1) << " "
517  << "||";
518  ss << " " << std::setw(nbcol * (numberwidth + 1) - 3)
519  << var.name().substr(0, nbcol * (numberwidth + 1) - 3) << "|";
520  ss << std::endl;
521 
522  if (nbparents > 0) {
523  for (Idx i = 1; i <= nbparents; i++)
524  ss << std::setw(colwidth) << table->variable(i).name().substr(0, colwidth) << "|";
525  ss << "|";
526  }
527  for (Idx i = 0; i < nbcol; i++)
528  ss << std::setw(numberwidth) << var.label(i).substr(0, numberwidth) << "|";
529  ss << std::endl;
530 
531 
532  if (nbparents > 0) {
533  for (Idx i = 1; i <= nbparents; i++)
534  ss << maskparent << "|";
535  ss << "|";
536  }
537  for (Idx i = 0; i < nbcol; i++)
538  ss << masknumber << "|";
539  ss << std::endl;
540  Instantiation I(*table);
541 
542  auto drawligne = [&]() {
543  if (nbparents > 0) {
544  for (Idx i = 1; i <= nbparents; i++)
545  ss << std::setw(colwidth) << table->variable(i).label(I.val(i)).substr(0, colwidth)
546  << "|";
547  ss << "|";
548  }
549  for (I.setFirstVar(var); !I.end(); I.incVar(var))
550  ss << " " << std::setw(numberwidth - 1) << table->get(I) << "|";
551  I.setFirstVar(var);
552  ss << std::endl;
553  };
554 
555  Size nbrLig = table->domainSize() / var.domainSize();
556  if (nbrLig < nbrLigMax * 2 + 1) {
557  for (I.setFirst(); !I.end(); I.incNotVar(var))
558  drawligne();
559  } else {
560  Size cpt = 0;
561  for (I.setFirst(); !I.end(); I.incNotVar(var)) {
562  cpt++;
563  if (cpt > nbrLigMax) break;
564  drawligne();
565  }
566  ss << "[..." << nbrLig - nbrLigMax * 2 << " more line(s) ...]" << std::endl;
567  I.setLast();
568  for (Idx revi = 1; revi < nbrLigMax; revi++)
569  I.decNotVar(var);
570  for (I.setFirstVar(var); !I.end(); I.incNotVar(var)) {
571  drawligne();
572  }
573  }
574 
575  return ss.str();
576  }
virtual const MultiDimImplementation< GUM_SCALAR > * content() const final
Returns the implementation for this object (may be *this).
std::size_t Size
In aGrUM, hashed values are unsigned long int.
Definition: types.h:47

◆ translate()

template<typename GUM_SCALAR >
INLINE const Potential< GUM_SCALAR > & gum::Potential< GUM_SCALAR >::translate ( GUM_SCALAR  v) const

add v to (each value of) *this

Definition at line 392 of file potential_tpl.h.

References gum::Set< Key, Alloc >::emplace().

392  {
393  this->apply([v](GUM_SCALAR x) { return x + v; });
394  return *this;
395  }
virtual void apply(std::function< GUM_SCALAR(GUM_SCALAR) > f) const final
Apply a function on every element of the container.
+ Here is the call graph for this function:

◆ unregisterSlave()

template<typename GUM_SCALAR >
INLINE bool gum::MultiDimDecorator< GUM_SCALAR >::unregisterSlave ( Instantiation i)
finalvirtualinherited

Unregister i as a slave of this MultiDimAdressable.

Parameters
iThe Instantiation to free.
Returns
Returns true, whatever happens.

Implements gum::MultiDimAdressable.

Definition at line 275 of file multiDimDecorator_tpl.h.

References gum::Set< Key, Alloc >::emplace().

275  {
276  return static_cast< MultiDimContainer< GUM_SCALAR >* >(content_)->unregisterSlave(i);
277  }
virtual bool unregisterSlave(Instantiation &i) final
Unregister i as a slave of this MultiDimAdressable.
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
+ Here is the call graph for this function:

◆ variable() [1/2]

template<typename GUM_SCALAR >
INLINE const DiscreteVariable & gum::MultiDimDecorator< GUM_SCALAR >::variable ( Idx  i) const
finalvirtualinherited

Returns a const ref to the ith var.

param i An index of this multidimensional matrix.

Returns
Returns a const ref to the ith var.
Exceptions
NotFoundRaised if i does not reference a variable in this multidimensional matrix.

Implements gum::MultiDimInterface.

Definition at line 248 of file multiDimDecorator_tpl.h.

References gum::Set< Key, Alloc >::emplace().

248  {
249  return static_cast< MultiDimContainer< GUM_SCALAR >* >(content_)->variable(i);
250  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
virtual const DiscreteVariable & variable(Idx) const final
Returns a const ref to the ith var.
+ Here is the call graph for this function:

◆ variable() [2/2]

template<typename GUM_SCALAR >
INLINE const DiscreteVariable & gum::MultiDimDecorator< GUM_SCALAR >::variable ( const std::string &  name) const
finalvirtualinherited

Returns the variable with the name.

Parameters
nameThe index of the variable
Returns
Returns the variable qith the name in the tuple. This function is not O(1)
Exceptions
NotFoundRaised if the element cannot be found.

Implements gum::MultiDimInterface.

Definition at line 254 of file multiDimDecorator_tpl.h.

References gum::Set< Key, Alloc >::emplace().

254  {
255  return static_cast< MultiDimContainer< GUM_SCALAR >* >(content_)->variable(name);
256  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
virtual const DiscreteVariable & variable(Idx) const final
Returns a const ref to the ith var.
+ Here is the call graph for this function:

◆ variablesSequence()

template<typename GUM_SCALAR >
INLINE const Sequence< const DiscreteVariable *> & gum::MultiDimDecorator< GUM_SCALAR >::variablesSequence ( ) const
finalvirtualinherited

Returns a const ref to the sequence of DiscreteVariable*.

Returns
Returns a const ref to the sequence of DiscreteVariable*.

Implements gum::MultiDimInterface.

Definition at line 300 of file multiDimDecorator_tpl.h.

References gum::Set< Key, Alloc >::emplace().

300  {
301  return static_cast< MultiDimContainer< GUM_SCALAR >* >(content_)->variablesSequence();
302  }
MultiDimImplementation< GUM_SCALAR > * content_
The true container.
virtual const Sequence< const DiscreteVariable *> & variablesSequence() const final
Returns a const ref to the sequence of DiscreteVariable*.
+ Here is the call graph for this function:

Member Data Documentation

◆ content_

template<typename GUM_SCALAR >
MultiDimImplementation< GUM_SCALAR >* gum::MultiDimDecorator< GUM_SCALAR >::content_
mutableprotectedinherited

The true container.

Definition at line 247 of file multiDimDecorator.h.

◆ empty_value_

template<typename GUM_SCALAR >
GUM_SCALAR gum::MultiDimDecorator< GUM_SCALAR >::empty_value_
mutableprotectedinherited

value of the MultiDimDecorator if no dimension.

Definition at line 261 of file multiDimDecorator.h.


The documentation for this class was generated from the following files: