aGrUM  0.17.2
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 > 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...
 
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 > &v) const
 Automatically fills the potential with the values in v. More...
 
const Potential< GUM_SCALAR > & fillWith (const GUM_SCALAR &v) 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 > & normalize () const
 normalisation of this do nothing if sum is 0 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...
 
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
 normalisation of this as a CPT 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...
 
virtual const 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...
 
MultiDimAdressable 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 const 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 60 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 38 of file potential_tpl.h.

38  :
39  MultiDimDecorator< GUM_SCALAR >(new MultiDimArray< GUM_SCALAR >(),
40  GUM_SCALAR(1)) {
41  GUM_CONSTRUCTOR(Potential);
42  }
Potential()
Default constructor.
Definition: potential_tpl.h:38

◆ Potential() [2/5]

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

Creates an potential around aContent.

Parameters
aContentThe implementation of this Potential.

Definition at line 46 of file potential_tpl.h.

47  :
48  MultiDimDecorator< GUM_SCALAR >(aContent, GUM_SCALAR(1)) {
49  // for debugging purposes
50  GUM_CONSTRUCTOR(Potential);
51  }
Potential()
Default constructor.
Definition: potential_tpl.h:38

◆ 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 74 of file potential_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::add(), gum::MultiDimDecorator< GUM_SCALAR >::beginMultipleChanges(), gum::MultiDimDecorator< GUM_SCALAR >::content(), gum::MultiDimContainer< GUM_SCALAR >::content(), gum::MultiDimInterface::empty(), gum::MultiDimDecorator< GUM_SCALAR >::endMultipleChanges(), and gum::MultiDimInterface::variablesSequence().

76  :
77  MultiDimDecorator< GUM_SCALAR >(aContent) {
78  // for debugging purposes
79  GUM_CONSTRUCTOR(Potential);
80 
81  if (!src.empty()) {
82  this->beginMultipleChanges();
83 
84  for (Idx i = 0; i < src.variablesSequence().size(); i++) {
85  this->add(*(src.variablesSequence()[i]));
86  }
87 
88  this->endMultipleChanges();
89  this->content()->copyFrom(*src.content());
90  }
91  }
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:38
+ 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 54 of file potential_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_empty_value.

54  :
55  Potential< GUM_SCALAR >(static_cast< MultiDimImplementation< GUM_SCALAR >* >(
56  src.content()->newFactory()),
57  *(src.content())) {
58  this->_empty_value = src._empty_value;
59  // todo how to optimize copy of content ?
60  // GUM_CONS_CPY not here because in called Potential
61  // GUM_CONS_CPY( Potential );
62  }
GUM_SCALAR _empty_value
value of the MultiDimDecorator if no dimension.

◆ 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 66 of file potential_tpl.h.

66  :
67  MultiDimDecorator< GUM_SCALAR >(
68  std::forward< MultiDimDecorator< GUM_SCALAR > >(from)) {
69  GUM_CONS_MOV(Potential);
70  }
Potential()
Default constructor.
Definition: potential_tpl.h:38

◆ ~Potential()

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

Destructor.

Definition at line 117 of file potential_tpl.h.

117  {
118  // for debugging purposes
119  GUM_DESTRUCTOR(Potential);
120  }
Potential()
Default constructor.
Definition: potential_tpl.h:38

Member Function Documentation

◆ _complementVars()

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

Definition at line 518 of file potential_tpl.h.

References gum::Set< Key, Alloc >::contains(), gum::Set< Key, Alloc >::insert(), and gum::MultiDimDecorator< GUM_SCALAR >::variablesSequence().

Referenced by gum::Potential< GUM_SCALAR >::margMaxIn(), gum::Potential< GUM_SCALAR >::margMinIn(), gum::Potential< GUM_SCALAR >::margProdIn(), gum::Potential< GUM_SCALAR >::margSumIn(), and gum::Potential< GUM_SCALAR >::toString().

519  {
520  Set< const DiscreteVariable* > cplt;
521 
522  for (const auto x: this->variablesSequence())
523  if (!vars.contains(x)) cplt.insert(x);
524 
525  return cplt;
526  }
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:
+ Here is the caller 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 144 of file multiDimDecorator_tpl.h.

References GUM_ERROR.

144  {
145  GUM_ERROR(OperationNotAllowed, "_get in the implementation !");
146  }
#define GUM_ERROR(type, msg)
Definition: exceptions.h:55

◆ _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 423 of file multiDimDecorator_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::content().

424  {
425  this->content()->replace(*x, *y);
426  }
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:

◆ _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 400 of file multiDimDecorator_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content.

401  {
402  if (aContent != nullptr) {
403  // TODO : frees all slave instantiations
404  // TODO : control the dimensions ?
405  MultiDimImplementation< GUM_SCALAR >* tmp = _content;
406  _content = aContent;
407  // registers all instantiations
408  delete (tmp);
409  }
410  }
MultiDimImplementation< GUM_SCALAR > * _content
The true container.

◆ 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 349 of file potential_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::apply().

349  {
350  this->apply([](GUM_SCALAR x) {
351  if (x >= 0)
352  return x;
353  else
354  return -x;
355  });
356  return *this;
357  }
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 178 of file multiDimDecorator_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content, gum::DiscreteVariable::domainSize(), and GUM_ERROR.

Referenced by gum::prm::gspan::StrictSearch< GUM_SCALAR >::__elimination_cost(), gum::prm::PRMSystem< double >::__groundPotential(), gum::prm::GroundedInference< GUM_SCALAR >::_evidenceAdded(), gum::prm::PRMInference< double >::addEvidence(), gum::BayesNetInference< GUM_SCALAR >::addEvidence(), gum::BayesNetInference< GUM_SCALAR >::chgEvidence(), gum::prm::copyPotential(), gum::MarginalTargetedInference< GUM_SCALAR >::evidenceImpact(), gum::JointTargetedInference< GUM_SCALAR >::evidenceJointImpact(), gum::prm::PRMInference< double >::joint(), gum::prm::PRMInference< double >::marginal(), gum::operator<<(), gum::prm::PRMInference< double >::operator=(), gum::Potential< GUM_SCALAR >::Potential(), gum::prm::PRMInference< double >::PRMInference(), and gum::Potential< GUM_SCALAR >::reorganize().

178  {
179  if (v.domainSize() < 1) {
180  GUM_ERROR(InvalidArgument,
181  "Empty variable " << v << " cannot be added in a Potential");
182  }
183  static_cast< MultiDimContainer< GUM_SCALAR >* >(_content)->add(v);
184  }
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:55
+ Here is the call graph for this function:
+ Here is the caller 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 346 of file multiDimDecorator_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content, gum::MultiDimDecorator< GUM_SCALAR >::_empty_value, and gum::MultiDimDecorator< GUM_SCALAR >::empty().

Referenced by gum::Potential< GUM_SCALAR >::abs(), gum::Potential< GUM_SCALAR >::inverse(), gum::Potential< GUM_SCALAR >::isNonZeroMap(), gum::Potential< GUM_SCALAR >::log2(), gum::Potential< GUM_SCALAR >::normalize(), gum::Potential< GUM_SCALAR >::operator-(), gum::Potential< GUM_SCALAR >::operator/(), gum::Potential< GUM_SCALAR >::scale(), gum::Potential< GUM_SCALAR >::sq(), and gum::Potential< GUM_SCALAR >::translate().

347  {
348  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(_content)->empty()) {
350  } else {
351  _content->apply(f);
352  }
353  }
MultiDimImplementation< GUM_SCALAR > * _content
The true container.
GUM_SCALAR _empty_value
value of the MultiDimDecorator if no dimension.
virtual bool empty() const final
Returns true if no var is in *this.
+ Here is the call graph for this function:
+ Here is the caller 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 615 of file potential_tpl.h.

References gum::Potential< GUM_SCALAR >::findAll(), and gum::Potential< GUM_SCALAR >::max().

615  {
616  return findAll(max());
617  }
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 620 of file potential_tpl.h.

References gum::Potential< GUM_SCALAR >::findAll(), and gum::Potential< GUM_SCALAR >::min().

620  {
621  return findAll(min());
622  }
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 381 of file multiDimDecorator_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content.

Referenced by gum::BayesNet< double >::__copyPotentials(), gum::BayesNetInference< GUM_SCALAR >::__createHardEvidence(), gum::Potential< GUM_SCALAR >::Potential(), and gum::Potential< GUM_SCALAR >::reorganize().

381  {
382  static_cast< MultiDimContainer< GUM_SCALAR >* >(_content)
384  }
virtual void beginMultipleChanges() final
Default implementation of MultiDimContainer::set().
MultiDimImplementation< GUM_SCALAR > * _content
The true container.
+ Here is the caller 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 189 of file multiDimDecorator_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content.

193  {
194  static_cast< MultiDimContainer< GUM_SCALAR >* >(_content)->changeNotification(
195  i, var, oldval, newval);
196  }
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.

◆ 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 282 of file multiDimDecorator_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content.

Referenced by gum::prm::StructuredInference< GUM_SCALAR >::_marginal(), gum::prm::PRMInference< double >::addEvidence(), gum::Potential< GUM_SCALAR >::KL(), gum::Potential< GUM_SCALAR >::putFirst(), and gum::Potential< GUM_SCALAR >::reorganize().

282  {
283  return static_cast< MultiDimContainer< GUM_SCALAR >* >(_content)->contains(d);
284  }
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 caller 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 376 of file multiDimDecorator_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content.

Referenced by gum::MultiDimDecorator< GUM_SCALAR >::_replace(), gum::prm::copyPotential(), gum::Potential< GUM_SCALAR >::margMaxIn(), gum::Potential< GUM_SCALAR >::margMaxOut(), gum::Potential< GUM_SCALAR >::margMinIn(), gum::Potential< GUM_SCALAR >::margMinOut(), gum::Potential< GUM_SCALAR >::margProdIn(), gum::Potential< GUM_SCALAR >::margProdOut(), gum::Potential< GUM_SCALAR >::margSumIn(), gum::Potential< GUM_SCALAR >::margSumOut(), gum::Potential< GUM_SCALAR >::max(), gum::Potential< GUM_SCALAR >::min(), gum::MultiDimDecorator< GUM_SCALAR >::MultiDimDecorator(), gum::Potential< GUM_SCALAR >::newFactory(), gum::Potential< GUM_SCALAR >::operator*(), gum::Potential< GUM_SCALAR >::operator+(), gum::Potential< GUM_SCALAR >::operator-(), gum::Potential< GUM_SCALAR >::operator/(), gum::MultiDimDecorator< GUM_SCALAR >::operator=(), gum::Potential< GUM_SCALAR >::Potential(), gum::Potential< GUM_SCALAR >::product(), and gum::Potential< GUM_SCALAR >::sum().

376  {
377  return _content;
378  }
MultiDimImplementation< GUM_SCALAR > * _content
The true container.
+ Here is the caller 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 369 of file multiDimDecorator_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content.

369  {
370  return _content;
371  }
MultiDimImplementation< GUM_SCALAR > * _content
The true container.

◆ 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 284 of file multiDimContainer_tpl.h.

References gum::MultiDimInterface::add(), gum::MultiDimContainer< GUM_SCALAR >::beginMultipleChanges(), gum::MultiDimContainer< GUM_SCALAR >::copyFrom(), gum::MultiDimContainer< GUM_SCALAR >::endMultipleChanges(), gum::MultiDimInterface::erase(), gum::MultiDimInterface::nbrDim(), and gum::MultiDimInterface::variable().

Referenced by gum::MCBayesNetGenerator< GUM_SCALAR, ICPTGenerator, ICPTDisturber >::__eraseArc(), and gum::MCBayesNetGenerator< GUM_SCALAR, ICPTGenerator, ICPTDisturber >::disturbBN().

285  {
286  this->beginMultipleChanges();
287 
288  Size nbr = this->nbrDim();
289 
290  for (Idx i = 0; i < nbr; i++) {
291  this->erase(this->variable(0));
292  }
293 
294  for (Idx i = 0; i < src.nbrDim(); i++) {
295  this->add(src.variable(i));
296  }
297 
298  this->endMultipleChanges();
299  this->copyFrom(src);
300  }
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:48
+ Here is the call graph for this function:
+ Here is the caller 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 267 of file multiDimContainer_tpl.h.

References gum::MultiDimInterface::domainSize(), gum::Instantiation::end(), GUM_ERROR, and gum::Instantiation::setFirst().

Referenced by gum::BayesNet< double >::__copyPotentials(), gum::MultiDimContainer< GUM_SCALAR >::copy(), gum::MultiDimArray< GUM_SCALAR >::copyFrom(), gum::MultiDimICIModel< GUM_SCALAR >::copyFrom(), gum::aggregator::MultiDimAggregator< GUM_SCALAR >::copyFrom(), and gum::Potential< GUM_SCALAR >::reorganize().

268  {
269  if (src.domainSize() != domainSize()) {
270  GUM_ERROR(OperationNotAllowed, "Domain sizes do not fit");
271  }
272 
273  Instantiation i_dest(*this);
274  Instantiation i_src(src);
275 
276  for (i_dest.setFirst(), i_src.setFirst(); !i_dest.end(); ++i_dest, ++i_src) {
277  set(i_dest, src[i_src]);
278  }
279  }
virtual Size domainSize() const =0
Returns the product of the variables domain size.
#define GUM_ERROR(type, msg)
Definition: exceptions.h:55
+ Here is the call graph for this function:
+ Here is the caller 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 220 of file multiDimContainer_tpl.h.

References gum::MultiDimInterface::domainSize(), gum::Instantiation::end(), GUM_ERROR, gum::Instantiation::incIn(), and gum::Instantiation::setFirst().

221  {
222  if (src.domainSize() != domainSize()) {
223  GUM_ERROR(OperationNotAllowed, "Domain sizes do not fit");
224  }
225 
226  if (p_i == nullptr) { // if null, we just follow the same order
227  Instantiation i(src);
228  for (i.setFirst(); !i.end(); ++i) {
229  set(i, src[i]);
230  }
231  } else {
232  Instantiation i_dest(*this);
233  Instantiation i_src(src);
234  for (i_dest.setFirst(), i_src.setFirst(); !i_dest.end();
235  i_dest.incIn(*p_i), ++i_src) {
236  set(i_dest, src[i_src]);
237  }
238  }
239  }
virtual Size domainSize() const =0
Returns the product of the variables domain size.
#define GUM_ERROR(type, msg)
Definition: exceptions.h:55
+ 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 171 of file multiDimDecorator_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content.

Referenced by gum::prm::gspan::StrictSearch< GUM_SCALAR >::__elimination_cost(), gum::credal::CNMonteCarloSampling< GUM_SCALAR, BNInferenceEngine >::__verticesSampling(), gum::credal::CredalNet< GUM_SCALAR >::approximatedBinarization(), gum::credal::CredalNet< GUM_SCALAR >::fillConstraint(), gum::Potential< GUM_SCALAR >::fillWith(), gum::SimpleUTGenerator::generateUT(), gum::Potential< GUM_SCALAR >::random(), and gum::credal::CredalNet< GUM_SCALAR >::toString().

171  {
172  return static_cast< MultiDimContainer< GUM_SCALAR >* >(_content)->domainSize();
173  }
MultiDimImplementation< GUM_SCALAR > * _content
The true container.
virtual Size domainSize() const final
Returns the product of the variables domain size.
+ Here is the caller 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::DiscreteVariable::domainSize(), gum::Instantiation::end(), GUM_ERROR, gum::Instantiation::inc(), gum::MultiDimDecorator< GUM_SCALAR >::nbrDim(), gum::randomProba(), gum::Instantiation::setFirst(), gum::Instantiation::val(), and gum::MultiDimDecorator< GUM_SCALAR >::variable().

Referenced by gum::GibbsOperator< GUM_SCALAR >::__GibbsSample().

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:55
+ Here is the call graph for this function:
+ Here is the caller 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 287 of file multiDimDecorator_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content.

Referenced by gum::MultiDimDecorator< GUM_SCALAR >::apply(), gum::Potential< GUM_SCALAR >::entropy(), gum::MultiDimDecorator< GUM_SCALAR >::fill(), gum::Potential< GUM_SCALAR >::findAll(), gum::MultiDimDecorator< GUM_SCALAR >::get(), gum::Potential< GUM_SCALAR >::margMaxIn(), gum::Potential< GUM_SCALAR >::margMaxOut(), gum::Potential< GUM_SCALAR >::margMinIn(), gum::Potential< GUM_SCALAR >::margMinOut(), gum::Potential< GUM_SCALAR >::margProdIn(), gum::Potential< GUM_SCALAR >::margProdOut(), gum::Potential< GUM_SCALAR >::margSumIn(), gum::Potential< GUM_SCALAR >::margSumOut(), gum::Potential< GUM_SCALAR >::max(), gum::Potential< GUM_SCALAR >::maxNonOne(), gum::Potential< GUM_SCALAR >::min(), gum::Potential< GUM_SCALAR >::minNonZero(), gum::Potential< GUM_SCALAR >::normalize(), gum::Potential< GUM_SCALAR >::normalizeAsCPT(), gum::Potential< GUM_SCALAR >::operator*(), gum::Potential< GUM_SCALAR >::operator+(), gum::Potential< GUM_SCALAR >::operator-(), gum::Potential< GUM_SCALAR >::operator/(), gum::Potential< GUM_SCALAR >::operator==(), gum::MultiDimDecorator< GUM_SCALAR >::populate(), gum::Potential< GUM_SCALAR >::product(), gum::MultiDimDecorator< GUM_SCALAR >::reduce(), gum::Potential< GUM_SCALAR >::sum(), and gum::MultiDimDecorator< GUM_SCALAR >::toString().

287  {
288  if (_content == nullptr) return true;
289  return static_cast< MultiDimContainer< GUM_SCALAR >* >(_content)->empty();
290  }
MultiDimImplementation< GUM_SCALAR > * _content
The true container.
virtual bool empty() const final
Returns true if no var is in *this.
+ Here is the caller 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 387 of file multiDimDecorator_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content.

Referenced by gum::BayesNet< double >::__copyPotentials(), gum::MultiDimDecorator< GUM_SCALAR >::endMultipleChanges(), gum::Potential< GUM_SCALAR >::Potential(), and gum::Potential< GUM_SCALAR >::reorganize().

387  {
388  static_cast< MultiDimContainer< GUM_SCALAR >* >(_content)
389  ->endMultipleChanges();
390  }
MultiDimImplementation< GUM_SCALAR > * _content
The true container.
virtual void endMultipleChanges() final
Default implementation of MultiDimContainer::set().
+ Here is the caller 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 394 of file multiDimDecorator_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content, and gum::MultiDimDecorator< GUM_SCALAR >::endMultipleChanges().

394  {
395  static_cast< MultiDimContainer< GUM_SCALAR >* >(_content)->endMultipleChanges(
396  x);
397  }
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 210 of file potential_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content, gum::MultiDimDecorator< GUM_SCALAR >::empty(), and gum::MultiDimDecorator< GUM_SCALAR >::reduce().

210  {
211  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(this->_content)->empty()) {
212  return static_cast< GUM_SCALAR >(0);
213  }
214 
215  return this->reduce(
216  [](GUM_SCALAR z, GUM_SCALAR p) {
217  return (p == 0.0) ? z : (z - p * std::log2(p));
218  },
219  0.0);
220  }
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
+ 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 252 of file multiDimDecorator_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content.

Referenced by gum::prm::gspan::StrictSearch< GUM_SCALAR >::__elimination_cost(), gum::prm::StructuredInference< GUM_SCALAR >::__removeBarrenNodes(), gum::prm::GroundedInference< GUM_SCALAR >::_evidenceRemoved(), gum::prm::eliminateNode(), and gum::MultiDimDecorator< GUM_SCALAR >::erase().

252  {
253  static_cast< MultiDimContainer< GUM_SCALAR >* >(_content)->erase(d);
254  }
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 caller 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 257 of file multiDimDecorator_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::erase(), and gum::MultiDimDecorator< GUM_SCALAR >::variable().

257  {
258  erase(variable(name));
259  }
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::MultiDimContainer< GUM_SCALAR >::extractFrom().

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 values in this instantiation.

Definition at line 242 of file multiDimContainer_tpl.h.

References gum::MultiDimInterface::add(), gum::MultiDimContainer< GUM_SCALAR >::beginMultipleChanges(), gum::Instantiation::contains(), gum::Instantiation::end(), gum::MultiDimContainer< GUM_SCALAR >::endMultipleChanges(), gum::MultiDimInterface::erase(), GUM_ERROR, gum::Instantiation::incOut(), gum::MultiDimInterface::nbrDim(), gum::Instantiation::setFirstOut(), gum::Instantiation::setVals(), and gum::MultiDimInterface::variable().

Referenced by gum::Potential< GUM_SCALAR >::extract().

243  {
244  this->beginMultipleChanges();
245 
246  Size nbr = this->nbrDim();
247 
248  for (Idx i = 0; i < nbr; i++) {
249  this->erase(this->variable(0));
250  }
251 
252  for (Idx i = 0; i < src.nbrDim(); i++) {
253  if (!imask.contains(src.variable(i))) this->add(src.variable(i));
254  }
255 
256  if (this->nbrDim() == 0) { GUM_ERROR(FatalError, "Empty potential"); }
257 
258  this->endMultipleChanges();
259 
260  Instantiation inst(src);
261  inst.setVals(imask);
262  for (inst.setFirstOut(imask); !inst.end(); inst.incOut(imask))
263  set(inst, src[inst]);
264  }
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:48
#define GUM_ERROR(type, msg)
Definition: exceptions.h:55
+ Here is the call graph for this function:
+ Here is the caller 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 299 of file multiDimDecorator_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content, gum::MultiDimDecorator< GUM_SCALAR >::_empty_value, and gum::MultiDimDecorator< GUM_SCALAR >::empty().

Referenced by gum::Potential< GUM_SCALAR >::fillWith().

299  {
300  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(_content)->empty()) {
301  _empty_value = d;
302  } else {
303  static_cast< MultiDimContainer< GUM_SCALAR >* >(_content)->fill(d);
304  }
305  }
MultiDimImplementation< GUM_SCALAR > * _content
The true container.
GUM_SCALAR _empty_value
value of the MultiDimDecorator if no dimension.
virtual bool empty() const final
Returns true if no var is in *this.
virtual void fill(const GUM_SCALAR &d) const final
Default implementation of MultiDimContainer::set().
+ Here is the call graph for this function:
+ Here is the caller 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 238 of file potential_tpl.h.

References gum::Instantiation::chgVal(), gum::Set< Key, Alloc >::contains(), gum::MultiDimDecorator< GUM_SCALAR >::domainSize(), gum::MultiDimDecorator< GUM_SCALAR >::get(), GUM_ERROR, gum::Set< Key, Alloc >::insert(), gum::MultiDimDecorator< GUM_SCALAR >::nbrDim(), gum::Potential< GUM_SCALAR >::toString(), gum::MultiDimDecorator< GUM_SCALAR >::variable(), and gum::MultiDimDecorator< GUM_SCALAR >::variablesSequence().

Referenced by gum::credal::CNMonteCarloSampling< GUM_SCALAR, BNInferenceEngine >::__insertEvidence(), gum::credal::CNMonteCarloSampling< GUM_SCALAR, BNInferenceEngine >::__verticesSampling(), gum::Potential< GUM_SCALAR >::margMaxIn(), gum::Potential< GUM_SCALAR >::margMaxOut(), gum::Potential< GUM_SCALAR >::margMinIn(), gum::Potential< GUM_SCALAR >::margMinOut(), gum::Potential< GUM_SCALAR >::margProdIn(), gum::Potential< GUM_SCALAR >::margProdOut(), gum::Potential< GUM_SCALAR >::margSumIn(), gum::Potential< GUM_SCALAR >::margSumOut(), gum::Potential< GUM_SCALAR >::noising(), gum::Estimator< GUM_SCALAR >::posterior(), and gum::Potential< GUM_SCALAR >::random().

238  {
239  if (src.domainSize() != this->domainSize()) {
240  GUM_ERROR(InvalidArgument, "Potential to copy has not the same dimension.");
241  }
242  gum::Set< std::string > son; // set of names
243  for (const auto& v: src.variablesSequence()) {
244  son.insert(v->name());
245  }
246  for (const auto& v: this->variablesSequence()) {
247  if (!son.contains(v->name())) {
248  GUM_ERROR(InvalidArgument,
249  "Variable <" << v->name() << "> not present in src.");
250  }
251  // we check size, labels and order of labels in the same time
252  if (v->toString() != src.variable(v->name()).toString()) {
253  GUM_ERROR(InvalidArgument,
254  "Variables <" << v->name() << "> are not identical.");
255  }
256  }
257 
258  Instantiation Isrc(src);
259  Instantiation Idst(*this);
260  for (Isrc.setFirst(); !Isrc.end(); ++Isrc) {
261  for (Idx i = 0; i < this->nbrDim(); i++) {
262  Idst.chgVal(Isrc.variable(i).name(), Isrc.val(i));
263  }
264  this->set(Idst, src.get(Isrc));
265  }
266 
267  return *this;
268  }
bool contains(const Key &k) const
Indicates whether a given elements belong to the set.
Definition: set_tpl.h:583
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 const std::string toString() const
the function to be used to add two Potentials
Definition: potential.h:479
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:615
#define GUM_ERROR(type, msg)
Definition: exceptions.h:55
+ Here is the call graph for this function:
+ Here is the caller 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 271 of file potential_tpl.h.

References gum::Instantiation::add(), gum::DiscreteVariable::domainSize(), gum::Instantiation::end(), gum::MultiDimDecorator< GUM_SCALAR >::get(), GUM_ERROR, gum::MultiDimDecorator< GUM_SCALAR >::nbrDim(), gum::Instantiation::setFirst(), and gum::MultiDimDecorator< GUM_SCALAR >::variable().

273  {
274  if (src.nbrDim() != this->nbrDim()) {
275  GUM_ERROR(InvalidArgument, "Potential to copy has not the same dimension.");
276  }
277  if (src.nbrDim() != mapSrc.size()) {
278  GUM_ERROR(InvalidArgument,
279  "Potential and vector have not the same dimension.");
280  }
281  Instantiation Isrc;
282  for (Idx i = 0; i < src.nbrDim(); i++) {
283  if (src.variable(mapSrc[i]).domainSize() != this->variable(i).domainSize()) {
284  GUM_ERROR(InvalidArgument,
285  "Variables " << mapSrc[i] << " (in the argument) and "
286  << this->variable(i).name()
287  << " have not the same dimension.");
288  } else {
289  Isrc.add(src.variable(mapSrc[i]));
290  }
291  }
292  Instantiation Idst(*this);
293  for (Isrc.setFirst(); !Isrc.end(); ++Isrc, ++Idst) {
294  this->set(Idst, src.get(Isrc));
295  }
296 
297  return *this;
298  }
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:55
+ 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 > &  v) 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 224 of file potential_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::populate().

224  {
225  this->populate(v);
226  return *this;
227  }
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 &  v) const

Automatically fills this MultiDimContainer with the value v.

Parameters
vcontains the data.

Definition at line 231 of file potential_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::fill().

231  {
232  this->fill(v);
233  return *this;
234  }
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 601 of file potential_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content, gum::MultiDimDecorator< GUM_SCALAR >::empty(), gum::Instantiation::end(), gum::Set< Key, Alloc >::insert(), and gum::Instantiation::setFirst().

Referenced by gum::Potential< GUM_SCALAR >::argmax(), and gum::Potential< GUM_SCALAR >::argmin().

601  {
602  Instantiation I(*this);
603  Set< Instantiation > res;
604 
605  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(this->_content)->empty()) {
606  return res;
607  }
608  for (I.setFirst(); !I.end(); ++I) {
609  if (this->get(I) == v) res.insert(I);
610  }
611  return res;
612  }
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:
+ Here is the caller 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 150 of file multiDimDecorator_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content, gum::MultiDimDecorator< GUM_SCALAR >::_empty_value, and gum::MultiDimDecorator< GUM_SCALAR >::empty().

Referenced by gum::prm::StructuredBayesBall< GUM_SCALAR >::__isHardEvidence(), gum::prm::GroundedInference< GUM_SCALAR >::_evidenceAdded(), gum::prm::StructuredInference< GUM_SCALAR >::_marginal(), gum::prm::PRMInference< double >::addEvidence(), gum::credal::CredalNet< GUM_SCALAR >::bnToCredal(), gum::SimpleCPTDisturber< GUM_SCALAR >::disturbAugmCPT(), gum::SimpleCPTDisturber< GUM_SCALAR >::disturbReducCPT(), gum::Potential< GUM_SCALAR >::fillWith(), gum::Potential< GUM_SCALAR >::KL(), gum::prm::PRMInference< double >::marginal(), and gum::prm::o3prmr::O3prmrInterpreter::query().

150  {
151  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(_content)->empty()) {
152  return _empty_value;
153  } else {
154  return static_cast< MultiDimContainer< GUM_SCALAR >* >(_content)->get(i);
155  }
156  }
MultiDimImplementation< GUM_SCALAR > * _content
The true container.
GUM_SCALAR _empty_value
value of the MultiDimDecorator if no dimension.
virtual bool empty() const final
Returns true if no var is in *this.
+ Here is the call graph for this function:
+ Here is the caller 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 303 of file multiDimContainer_tpl.h.

References gum::MultiDimContainer< GUM_SCALAR >::content().

303  {
304  return static_cast< MultiDimAdressable& >(*content());
305  }
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 309 of file multiDimContainer_tpl.h.

References gum::MultiDimContainer< GUM_SCALAR >::content().

309  {
310  return static_cast< const MultiDimAdressable& >(*content());
311  }
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 424 of file potential_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::apply().

424  {
425  this->apply([](GUM_SCALAR x) { return 1 / x; });
426  return *this;
427  }
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 506 of file potential_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::apply().

506  {
507  auto p = Potential< GUM_SCALAR >(*this);
508  p.apply([](GUM_SCALAR x) {
509  if (x != static_cast< GUM_SCALAR >(0))
510  return static_cast< GUM_SCALAR >(1);
511  else
512  return static_cast< GUM_SCALAR >(0);
513  });
514  return p;
515  }
+ 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 314 of file potential_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::contains(), gum::Instantiation::end(), gum::MultiDimDecorator< GUM_SCALAR >::get(), GUM_ERROR, gum::Instantiation::inc(), gum::MultiDimDecorator< GUM_SCALAR >::nbrDim(), gum::Instantiation::setFirst(), and gum::MultiDimDecorator< GUM_SCALAR >::variablesSequence().

314  {
315  if (this->nbrDim() != p.nbrDim())
316  GUM_ERROR(
317  InvalidArgument,
318  "BNdistance between potentials with different numbers of dimensions");
319  for (const auto var: p.variablesSequence()) {
320  if (!this->contains(*var))
321  GUM_ERROR(InvalidArgument,
322  "A variable in the argument does not belong to the potential.");
323  }
324  for (const auto var: this->variablesSequence()) {
325  if (!p.contains(*var))
326  GUM_ERROR(InvalidArgument, "A variable does not belong to the argument.");
327  }
328 
329  Instantiation inst(*this);
330  GUM_SCALAR res = static_cast< GUM_SCALAR >(0);
331  for (inst.setFirst(); !inst.end(); inst.inc()) {
332  GUM_SCALAR x = this->get(inst);
333  GUM_SCALAR y = p.get(inst);
334  if (static_cast< GUM_SCALAR >(0) == x) // 0*log(0/y)=0
335  continue;
336 
337  if (static_cast< GUM_SCALAR >(0) == y)
338  // we know that x!=0;
339  GUM_ERROR(FatalError,
340  "The argument has a 0 at " << inst
341  << " while the potential has not.")
342 
343  res += x * std::log2(x / y);
344  }
345  return res;
346  }
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:55
+ 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 307 of file potential_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::apply().

307  {
308  this->apply([](GUM_SCALAR x) { return std::log2(x); });
309  return *this;
310  }
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:

◆ 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 496 of file potential_tpl.h.

References gum::Potential< GUM_SCALAR >::_complementVars(), gum::MultiDimDecorator< GUM_SCALAR >::_content, gum::MultiDimDecorator< GUM_SCALAR >::_empty_value, gum::MultiDimDecorator< GUM_SCALAR >::content(), gum::MultiDimDecorator< GUM_SCALAR >::empty(), gum::Potential< GUM_SCALAR >::fillWith(), and gum::projectMax().

497  {
498  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(this->_content)->empty()) {
499  return Potential< GUM_SCALAR >().fillWith(this->_empty_value);
500  }
501  return Potential< GUM_SCALAR >(
502  gum::projectMax(*this->content(), _complementVars(kept_vars)));
503  }
MultiDimImplementation< GUM_SCALAR > * _content
The true container.
GUM_SCALAR _empty_value
value of the MultiDimDecorator if no dimension.
virtual bool empty() const final
Returns true if no var is in *this.
Set< const DiscreteVariable *> _complementVars(const Set< const DiscreteVariable * > &del_vars) const
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 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 458 of file potential_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content, gum::MultiDimDecorator< GUM_SCALAR >::_empty_value, gum::MultiDimDecorator< GUM_SCALAR >::content(), gum::MultiDimDecorator< GUM_SCALAR >::empty(), gum::Potential< GUM_SCALAR >::fillWith(), and gum::projectMax().

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::projectMax(*this->content(), del_vars));
464  }
MultiDimImplementation< GUM_SCALAR > * _content
The true container.
GUM_SCALAR _empty_value
value of the MultiDimDecorator if no dimension.
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 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 486 of file potential_tpl.h.

References gum::Potential< GUM_SCALAR >::_complementVars(), gum::MultiDimDecorator< GUM_SCALAR >::_content, gum::MultiDimDecorator< GUM_SCALAR >::_empty_value, gum::MultiDimDecorator< GUM_SCALAR >::content(), gum::MultiDimDecorator< GUM_SCALAR >::empty(), gum::Potential< GUM_SCALAR >::fillWith(), and gum::projectMin().

487  {
488  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(this->_content)->empty()) {
489  return Potential< GUM_SCALAR >().fillWith(this->_empty_value);
490  }
491  return Potential< GUM_SCALAR >(
492  gum::projectMin(*this->content(), _complementVars(kept_vars)));
493  }
MultiDimImplementation< GUM_SCALAR > * _content
The true container.
GUM_SCALAR _empty_value
value of the MultiDimDecorator if no dimension.
virtual bool empty() const final
Returns true if no var is in *this.
Set< const DiscreteVariable *> _complementVars(const Set< const DiscreteVariable * > &del_vars) const
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 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 449 of file potential_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content, gum::MultiDimDecorator< GUM_SCALAR >::_empty_value, gum::MultiDimDecorator< GUM_SCALAR >::content(), gum::MultiDimDecorator< GUM_SCALAR >::empty(), gum::Potential< GUM_SCALAR >::fillWith(), and gum::projectMin().

450  {
451  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(this->_content)->empty()) {
452  return Potential< GUM_SCALAR >().fillWith(this->_empty_value);
453  }
454  return Potential< GUM_SCALAR >(gum::projectMin(*this->content(), del_vars));
455  }
MultiDimImplementation< GUM_SCALAR > * _content
The true container.
GUM_SCALAR _empty_value
value of the MultiDimDecorator if no dimension.
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 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 476 of file potential_tpl.h.

References gum::Potential< GUM_SCALAR >::_complementVars(), gum::MultiDimDecorator< GUM_SCALAR >::_content, gum::MultiDimDecorator< GUM_SCALAR >::_empty_value, gum::MultiDimDecorator< GUM_SCALAR >::content(), gum::MultiDimDecorator< GUM_SCALAR >::empty(), gum::Potential< GUM_SCALAR >::fillWith(), and gum::projectProduct().

477  {
478  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(this->_content)->empty()) {
479  return Potential< GUM_SCALAR >().fillWith(this->_empty_value);
480  }
481  return Potential< GUM_SCALAR >(
482  gum::projectProduct(*this->content(), _complementVars(kept_vars)));
483  }
MultiDimImplementation< GUM_SCALAR > * _content
The true container.
GUM_SCALAR projectProduct(const MultiDimImplementation< GUM_SCALAR > &table, Instantiation *instantiation=0)
the function to be used to project a MultiDimImplementation using a Product
GUM_SCALAR _empty_value
value of the MultiDimDecorator if no dimension.
virtual bool empty() const final
Returns true if no var is in *this.
Set< const DiscreteVariable *> _complementVars(const Set< const DiscreteVariable * > &del_vars) const
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...
+ 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 439 of file potential_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content, gum::MultiDimDecorator< GUM_SCALAR >::_empty_value, gum::MultiDimDecorator< GUM_SCALAR >::content(), gum::MultiDimDecorator< GUM_SCALAR >::empty(), gum::Potential< GUM_SCALAR >::fillWith(), and gum::projectProduct().

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 >(
445  gum::projectProduct(*this->content(), del_vars));
446  }
MultiDimImplementation< GUM_SCALAR > * _content
The true container.
GUM_SCALAR projectProduct(const MultiDimImplementation< GUM_SCALAR > &table, Instantiation *instantiation=0)
the function to be used to project a MultiDimImplementation using a Product
GUM_SCALAR _empty_value
value of the MultiDimDecorator if no dimension.
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...
+ 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 466 of file potential_tpl.h.

References gum::Potential< GUM_SCALAR >::_complementVars(), gum::MultiDimDecorator< GUM_SCALAR >::_content, gum::MultiDimDecorator< GUM_SCALAR >::_empty_value, gum::MultiDimDecorator< GUM_SCALAR >::content(), gum::MultiDimDecorator< GUM_SCALAR >::empty(), gum::Potential< GUM_SCALAR >::fillWith(), and gum::projectSum().

467  {
468  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(this->_content)->empty()) {
469  return Potential< GUM_SCALAR >().fillWith(this->_empty_value);
470  }
471  return Potential< GUM_SCALAR >(
472  gum::projectSum(*this->content(), _complementVars(kept_vars)));
473  }
MultiDimImplementation< GUM_SCALAR > * _content
The true container.
GUM_SCALAR _empty_value
value of the MultiDimDecorator if no dimension.
virtual bool empty() const final
Returns true if no var is in *this.
Set< const DiscreteVariable *> _complementVars(const Set< const DiscreteVariable * > &del_vars) const
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
+ 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 430 of file potential_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content, gum::MultiDimDecorator< GUM_SCALAR >::_empty_value, gum::MultiDimDecorator< GUM_SCALAR >::content(), gum::MultiDimDecorator< GUM_SCALAR >::empty(), gum::Potential< GUM_SCALAR >::fillWith(), and gum::projectSum().

Referenced by gum::prm::eliminateNode(), gum::JointTargetedInference< GUM_SCALAR >::I(), gum::LPNewprojPotential(), gum::BayesNet< double >::reverseArc(), gum::SSNewprojPotential(), and gum::VENewprojPotential().

431  {
432  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(this->_content)->empty()) {
433  return Potential< GUM_SCALAR >().fillWith(this->_empty_value);
434  }
435  return Potential< GUM_SCALAR >(gum::projectSum(*this->content(), del_vars));
436  }
MultiDimImplementation< GUM_SCALAR > * _content
The true container.
GUM_SCALAR _empty_value
value of the MultiDimDecorator if no dimension.
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
+ Here is the call graph for this function:
+ Here is the caller 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 147 of file potential_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content, gum::MultiDimDecorator< GUM_SCALAR >::_empty_value, gum::MultiDimDecorator< GUM_SCALAR >::content(), gum::MultiDimDecorator< GUM_SCALAR >::empty(), and gum::projectMax().

Referenced by gum::Potential< GUM_SCALAR >::argmax().

147  {
148  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(this->_content)->empty()) {
149  return this->_empty_value;
150  }
151  return gum::projectMax(*this->content());
152  }
MultiDimImplementation< GUM_SCALAR > * _content
The true container.
GUM_SCALAR _empty_value
value of the MultiDimDecorator if no dimension.
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 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:
+ Here is the caller 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

Exceptions
NotFoundif all value == 1.0

Definition at line 164 of file potential_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content, gum::MultiDimDecorator< GUM_SCALAR >::_empty_value, gum::MultiDimDecorator< GUM_SCALAR >::empty(), GUM_ERROR, and gum::MultiDimDecorator< GUM_SCALAR >::reduce().

164  {
165  GUM_SCALAR res;
166 
167  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(this->_content)->empty()) {
168  res = this->_empty_value;
169  } else {
170  res = this->reduce(
171  [](GUM_SCALAR z, GUM_SCALAR p) {
172  return (p == static_cast< GUM_SCALAR >(1))
173  ? z
174  : (z == static_cast< GUM_SCALAR >(1)) ? p : (p > z ? p : z);
175  },
176  static_cast< GUM_SCALAR >(1));
177  }
178 
179  if (res == static_cast< GUM_SCALAR >(1))
180  GUM_ERROR(NotFound, "No other value than 1");
181 
182  return res;
183  }
MultiDimImplementation< GUM_SCALAR > * _content
The true container.
GUM_SCALAR _empty_value
value of the MultiDimDecorator if no dimension.
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
#define GUM_ERROR(type, msg)
Definition: exceptions.h:55
+ 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 155 of file potential_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content, gum::MultiDimDecorator< GUM_SCALAR >::_empty_value, gum::MultiDimDecorator< GUM_SCALAR >::content(), gum::MultiDimDecorator< GUM_SCALAR >::empty(), and gum::projectMin().

Referenced by gum::Potential< GUM_SCALAR >::argmin().

155  {
156  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(this->_content)->empty()) {
157  return this->_empty_value;
158  }
159  return gum::projectMin(*this->content());
160  }
MultiDimImplementation< GUM_SCALAR > * _content
The true container.
GUM_SCALAR _empty_value
value of the MultiDimDecorator if no dimension.
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 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:
+ Here is the caller 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

Exceptions
NotFoundif all value == 0.0

Definition at line 187 of file potential_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content, gum::MultiDimDecorator< GUM_SCALAR >::_empty_value, gum::MultiDimDecorator< GUM_SCALAR >::empty(), GUM_ERROR, and gum::MultiDimDecorator< GUM_SCALAR >::reduce().

187  {
188  GUM_SCALAR res;
189 
190  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(this->_content)->empty()) {
191  res = this->_empty_value;
192  } else {
193  res = this->reduce(
194  [](GUM_SCALAR z, GUM_SCALAR p) {
195  return (p == static_cast< GUM_SCALAR >(0))
196  ? z
197  : (z == static_cast< GUM_SCALAR >(0)) ? p : (p < z ? p : z);
198  },
199  static_cast< GUM_SCALAR >(0));
200  }
201 
202  if (res == static_cast< GUM_SCALAR >(0))
203  GUM_ERROR(NotFound, "No other value than 1");
204 
205  return res;
206  }
MultiDimImplementation< GUM_SCALAR > * _content
The true container.
GUM_SCALAR _empty_value
value of the MultiDimDecorator if no dimension.
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
#define GUM_ERROR(type, msg)
Definition: exceptions.h:55
+ 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 327 of file multiDimDecorator_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content.

Referenced by gum::GibbsOperator< GUM_SCALAR >::__GibbsSample(), gum::BayesNetFragment< GUM_SCALAR >::_installCPT(), gum::prm::SVED< GUM_SCALAR >::_marginal(), gum::prm::PRMInference< double >::addEvidence(), gum::BayesNet< double >::changePotential(), gum::BayesNetInference< GUM_SCALAR >::chgEvidence(), gum::Potential< GUM_SCALAR >::draw(), gum::Potential< GUM_SCALAR >::fillWith(), gum::BayesNetFragment< GUM_SCALAR >::installCPT(), gum::BayesNetFragment< GUM_SCALAR >::installMarginal(), gum::prm::PRMInference< double >::joint(), gum::Potential< GUM_SCALAR >::KL(), gum::prm::PRMInference< double >::marginal(), gum::operator<<(), gum::Potential< GUM_SCALAR >::putFirst(), gum::Potential< GUM_SCALAR >::reorganize(), gum::MultiDimDecorator< GUM_SCALAR >::set(), and gum::BayesNetFragment< GUM_SCALAR >::uninstallCPT().

327  {
328  return static_cast< MultiDimContainer< GUM_SCALAR >* >(_content)->nbrDim();
329  }
virtual Idx nbrDim() const final
Returns the number of vars in the multidimensional container.
MultiDimImplementation< GUM_SCALAR > * _content
The true container.
+ Here is the caller 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 123 of file potential_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::content().

123  {
124  return new Potential< GUM_SCALAR >(
125  static_cast< MultiDimImplementation< GUM_SCALAR >* >(
126  this->content()->newFactory()));
127  }
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 657 of file potential_tpl.h.

References gum::Potential< GUM_SCALAR >::fillWith(), GUM_ERROR, gum::Potential< GUM_SCALAR >::normalizeAsCPT(), gum::Potential< GUM_SCALAR >::randomCPT(), and gum::Potential< GUM_SCALAR >::scale().

657  {
658  if ((alpha < GUM_SCALAR(0.0)) || (alpha > GUM_SCALAR(1.0))) {
659  GUM_ERROR(InvalidArgument, "alpha must be in [0,1]");
660  }
661  Potential< GUM_SCALAR > noise(*this);
662  return fillWith(scale(1 - alpha) + noise.randomCPT().scale(alpha))
663  .normalizeAsCPT();
664  }
const Potential< GUM_SCALAR > & scale(GUM_SCALAR v) const
multiply (each value of) *this by v
const Potential< GUM_SCALAR > & normalizeAsCPT() const
normalisation of this as a CPT
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:55
+ 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 363 of file potential_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content, gum::MultiDimDecorator< GUM_SCALAR >::_empty_value, gum::MultiDimDecorator< GUM_SCALAR >::apply(), gum::MultiDimDecorator< GUM_SCALAR >::empty(), and gum::Potential< GUM_SCALAR >::sum().

Referenced by gum::GibbsOperator< GUM_SCALAR >::__GibbsSample(), gum::prm::SVED< GUM_SCALAR >::_marginal(), gum::prm::SVE< GUM_SCALAR >::_marginal(), gum::prm::StructuredInference< GUM_SCALAR >::_marginal(), gum::JointTargetedInference< GUM_SCALAR >::I(), and gum::Estimator< GUM_SCALAR >::posterior().

363  {
364  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(this->_content)->empty()) {
365  if (this->_empty_value != static_cast< GUM_SCALAR >(0))
366  this->_empty_value = static_cast< GUM_SCALAR >(1.0);
367  } else {
368  GUM_SCALAR s = sum();
369 
370  if (s != (GUM_SCALAR)0) {
371  this->apply([s](GUM_SCALAR x) { return x / s; });
372  }
373  }
374  return *this;
375  }
MultiDimImplementation< GUM_SCALAR > * _content
The true container.
GUM_SCALAR _empty_value
value of the MultiDimDecorator if no dimension.
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
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ normalizeAsCPT()

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

normalisation of this as a CPT

Exceptions
FatalErrorit some distribution sums to 0

Definition at line 379 of file potential_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content, gum::MultiDimDecorator< GUM_SCALAR >::_empty_value, gum::MultiDimDecorator< GUM_SCALAR >::empty(), gum::Instantiation::end(), GUM_ERROR, gum::Instantiation::incNotVar(), gum::Instantiation::incVar(), gum::Instantiation::setFirst(), gum::Instantiation::setFirstVar(), and gum::MultiDimDecorator< GUM_SCALAR >::variable().

Referenced by gum::Potential< GUM_SCALAR >::noising().

379  {
380  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(this->_content)->empty()) {
381  if (this->_empty_value != static_cast< GUM_SCALAR >(0)) {
382  this->_empty_value = static_cast< GUM_SCALAR >(1.0);
383  } else {
384  GUM_ERROR(FatalError,
385  "Normalization for a potential that sum to 0 in " << *this);
386  }
387  } else {
388  Instantiation inst(*this);
389  const auto& v = this->variable(0);
390 
391  for (inst.setFirst(); !inst.end(); inst.incNotVar(v)) {
392  GUM_SCALAR s = (GUM_SCALAR)0.0;
393  for (inst.setFirstVar(v); !inst.end(); inst.incVar(v))
394  s += this->get(inst);
395  if (s == (GUM_SCALAR)0.0) {
396  GUM_ERROR(FatalError,
397  "Normalization for a potential that sum to 0 in " << *this);
398  }
399  if (s != (GUM_SCALAR)1.0) {
400  for (inst.setFirstVar(v); !inst.end(); inst.incVar(v))
401  this->set(inst, this->get(inst) / s);
402  }
403  inst.setFirstVar(v); // to remove inst.end()
404  }
405  }
406  return *this;
407  }
MultiDimImplementation< GUM_SCALAR > * _content
The true container.
GUM_SCALAR _empty_value
value of the MultiDimDecorator if no dimension.
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.
#define GUM_ERROR(type, msg)
Definition: exceptions.h:55
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ notifyChange()

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

Definition at line 310 of file multiDimDecorator_tpl.h.

References GUM_ERROR.

310  {
311  /*( (MultiDimContainer<GUM_SCALAR> *) _content)->notifyChange();*/
312  GUM_ERROR(OperationNotAllowed, "Not implemented yet");
313  }
#define GUM_ERROR(type, msg)
Definition: exceptions.h:55

◆ 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 161 of file multiDimContainer_tpl.h.

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

162  {
163  return !operator==(p);
164  }
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 475 of file potential.h.

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

475  {
476  return !operator==(r);
477  }
bool operator==(const Potential< GUM_SCALAR > &r) const
the function to be used to add two Potentials
Definition: potential.h:461
+ 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 396 of file potential.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_empty_value, gum::MultiDimDecorator< GUM_SCALAR >::content(), gum::MultiDimDecorator< GUM_SCALAR >::empty(), and gum::Potential< GUM_SCALAR >::scale().

396  {
397  if (p2.empty()) return Potential< GUM_SCALAR >(*this).scale(p2._empty_value);
398  if (this->empty())
399  return Potential< GUM_SCALAR >(p2).scale(this->_empty_value);
400 
401  return Potential< GUM_SCALAR >(*this->content() * *p2.content());
402  }
GUM_SCALAR _empty_value
value of the MultiDimDecorator if no dimension.
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).
+ Here is the call graph for this function:

◆ 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 405 of file potential.h.

References gum::Potential< GUM_SCALAR >::scale().

405  {
406  return Potential< GUM_SCALAR >(*this).scale(v);
407  }
+ 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 > &  r)
inline

the function to be used to add two Potentials

Definition at line 434 of file potential.h.

434  {
435  *this = *this * r;
436  return *this;
437  }

◆ 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 438 of file potential.h.

References gum::Potential< GUM_SCALAR >::scale().

438  {
439  this->scale(v);
440  return *this;
441  }
const Potential< GUM_SCALAR > & scale(GUM_SCALAR v) const
multiply (each value of) *this by v
+ 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 add two Potentials

Definition at line 364 of file potential.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_empty_value, gum::MultiDimDecorator< GUM_SCALAR >::content(), gum::MultiDimDecorator< GUM_SCALAR >::empty(), and gum::Potential< GUM_SCALAR >::translate().

364  {
365  if (p2.empty())
366  return Potential< GUM_SCALAR >(*this).translate(p2._empty_value);
367  if (this->empty())
368  return Potential< GUM_SCALAR >(p2).translate(this->_empty_value);
369 
370  return Potential< GUM_SCALAR >(*this->content() + *p2.content());
371  }
GUM_SCALAR _empty_value
value of the MultiDimDecorator if no dimension.
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 > & translate(GUM_SCALAR v) const
add v to (each value of) *this
+ Here is the call graph for this function:

◆ 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 374 of file potential.h.

References gum::Potential< GUM_SCALAR >::translate().

374  {
375  return Potential< GUM_SCALAR >(*this).translate(v);
376  }
+ 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 > &  r)
inline

the function to be used to add two Potentials

Definition at line 425 of file potential.h.

425  {
426  *this = *this + r;
427  return *this;
428  }

◆ 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 429 of file potential.h.

References gum::Potential< GUM_SCALAR >::translate().

429  {
430  this->translate(v);
431  return *this;
432  }
const Potential< GUM_SCALAR > & translate(GUM_SCALAR v) const
add v to (each value of) *this
+ 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 subtract two Potentials

Definition at line 379 of file potential.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_empty_value, gum::MultiDimDecorator< GUM_SCALAR >::apply(), gum::MultiDimDecorator< GUM_SCALAR >::content(), gum::MultiDimDecorator< GUM_SCALAR >::empty(), and gum::Potential< GUM_SCALAR >::translate().

379  {
380  if (p2.empty())
381  return Potential< GUM_SCALAR >(*this).translate(-p2._empty_value);
382  if (this->empty()) {
383  auto p = Potential< GUM_SCALAR >(p2);
384  p.apply([this](GUM_SCALAR x) { return this->_empty_value - x; });
385  return p;
386  }
387  return Potential< GUM_SCALAR >(*this->content() - *p2.content());
388  }
GUM_SCALAR _empty_value
value of the MultiDimDecorator if no dimension.
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).
+ Here is the call graph for this function:

◆ 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 391 of file potential.h.

References gum::Potential< GUM_SCALAR >::translate().

391  {
392  return Potential< GUM_SCALAR >(*this).translate(-v);
393  }
+ 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 > &  r)
inline

the function to be used to add two Potentials

Definition at line 443 of file potential.h.

443  {
444  *this = *this - r;
445  return *this;
446  }

◆ 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 447 of file potential.h.

References gum::Potential< GUM_SCALAR >::translate().

447  {
448  this->translate(-v);
449  return *this;
450  }
const Potential< GUM_SCALAR > & translate(GUM_SCALAR v) const
add v to (each value of) *this
+ 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 divide two Potentials

Definition at line 410 of file potential.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_empty_value, gum::MultiDimDecorator< GUM_SCALAR >::apply(), gum::MultiDimDecorator< GUM_SCALAR >::content(), gum::MultiDimDecorator< GUM_SCALAR >::empty(), and gum::Potential< GUM_SCALAR >::scale().

410  {
411  if (p2.empty())
412  return Potential< GUM_SCALAR >(*this).scale(1 / p2._empty_value);
413  if (this->empty()) {
414  auto p = Potential< GUM_SCALAR >(p2);
415  p.apply([this](GUM_SCALAR x) { return this->_empty_value / x; });
416  return p;
417  }
418  return Potential< GUM_SCALAR >(*this->content() / *p2.content());
419  }
GUM_SCALAR _empty_value
value of the MultiDimDecorator if no dimension.
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).
+ Here is the call graph for this function:

◆ 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 421 of file potential.h.

References gum::Potential< GUM_SCALAR >::scale().

421  {
422  return Potential< GUM_SCALAR >(*this).scale(1 / v);
423  }
+ 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 > &  r)
inline

the function to be used to add two Potentials

Definition at line 452 of file potential.h.

452  {
453  *this = *this / r;
454  return *this;
455  }

◆ 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 456 of file potential.h.

References gum::Potential< GUM_SCALAR >::scale().

456  {
457  this->scale(1 / v);
458  return *this;
459  }
const Potential< GUM_SCALAR > & scale(GUM_SCALAR v) const
multiply (each value of) *this by v
+ 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 > &  src)

Default constructor.

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

Definition at line 96 of file potential_tpl.h.

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

96  {
97  GUM_OP_CPY(Potential);
98  if (&src == this) return *this;
100  return *this;
101  }
MultiDimDecorator< GUM_SCALAR > & operator=(const MultiDimDecorator &from) noexcept
copy operator
Potential()
Default constructor.
Definition: potential_tpl.h:38
+ 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 106 of file potential_tpl.h.

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

106  {
107  GUM_OP_MOV(Potential);
108  if (&src == this) return *this;
110  std::forward< MultiDimDecorator< GUM_SCALAR > >(src));
111  return *this;
112  }
MultiDimDecorator< GUM_SCALAR > & operator=(const MultiDimDecorator &from) noexcept
copy operator
Potential()
Default constructor.
Definition: potential_tpl.h:38
+ 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 130 of file multiDimContainer_tpl.h.

References gum::MultiDimInterface::domainSize(), gum::Instantiation::end(), gum::MultiDimContainer< GUM_SCALAR >::get(), gum::MultiDimInterface::nbrDim(), gum::Instantiation::setFirst(), and gum::MultiDimInterface::variablesSequence().

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

131  {
132  if ((nbrDim() == p.nbrDim()) && (domainSize() == p.domainSize())) {
133  if (nbrDim() == 0) return true;
134 
136  var_iterator;
137 
138  for (var_iterator iter = variablesSequence().beginSafe();
139  iter != variablesSequence().endSafe();
140  ++iter) {
141  if (!p.variablesSequence().exists(*iter)) { return false; }
142  }
143  } else {
144  return false;
145  }
146 
147  Instantiation i(*this);
148 
149  AlmostDifferent< GUM_SCALAR > cmp;
150 
151  for (i.setFirst(); !i.end(); ++i) {
152  if (cmp(get(i), p.get(i))) { return false; }
153  }
154 
155  return true;
156  }
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:1038
+ Here is the call graph for this function:
+ Here is the caller 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 461 of file potential.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content, gum::MultiDimDecorator< GUM_SCALAR >::_empty_value, and gum::MultiDimDecorator< GUM_SCALAR >::empty().

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

461  {
462  if (this->empty()) {
463  if (r.empty())
464  return this->_empty_value == r._empty_value;
465  else
466  return false;
467  } else {
468  if (r.empty())
469  return false;
470  else
471  return (*this->_content) == (*r._content);
472  }
473  }
MultiDimImplementation< GUM_SCALAR > * _content
The true container.
GUM_SCALAR _empty_value
value of the MultiDimDecorator if no dimension.
virtual bool empty() const final
Returns true if no var is in *this.
+ Here is the call graph for this function:
+ 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 84 of file multiDimContainer_tpl.h.

84  {
85  return get(i);
86  }

◆ 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 332 of file multiDimDecorator_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content, gum::MultiDimDecorator< GUM_SCALAR >::_empty_value, gum::MultiDimDecorator< GUM_SCALAR >::empty(), and GUM_ERROR.

Referenced by gum::Potential< GUM_SCALAR >::fillWith(), and gum::SimpleUTGenerator::generateUT().

333  {
334  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(_content)->empty()) {
335  if (v.size() == 1) {
336  _empty_value = v[0];
337  } else {
338  GUM_ERROR(SizeError, "Size do not match in populate")
339  }
340  } else {
341  _content->populate(v);
342  }
343  }
MultiDimImplementation< GUM_SCALAR > * _content
The true container.
GUM_SCALAR _empty_value
value of the MultiDimDecorator if no dimension.
virtual bool empty() const final
Returns true if no var is in *this.
#define GUM_ERROR(type, msg)
Definition: exceptions.h:55
+ Here is the call graph for this function:
+ Here is the caller 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 183 of file multiDimContainer_tpl.h.

References gum::MultiDimInterface::domainSize(), and GUM_ERROR.

184  {
185  if (domainSize() != l.size()) {
186  GUM_ERROR(SizeError, "Sizes do not match in populate");
187  }
188 
189  Instantiation i(*this);
190  // insert all the elements
191  for (const auto& elt: l) {
192  set(i, elt);
193  ++i;
194  }
195  }
virtual Size domainSize() const =0
Returns the product of the variables domain size.
#define GUM_ERROR(type, msg)
Definition: exceptions.h:55
+ 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 276 of file multiDimDecorator_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content.

Referenced by gum::credal::CredalNet< GUM_SCALAR >::approximatedBinarization().

276  {
277  return static_cast< MultiDimContainer< GUM_SCALAR >* >(_content)->pos(d);
278  }
MultiDimImplementation< GUM_SCALAR > * _content
The true container.
virtual Idx pos(const DiscreteVariable &var) const final
Returns the index of a variable.
+ Here is the caller 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 139 of file potential_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content, gum::MultiDimDecorator< GUM_SCALAR >::_empty_value, gum::MultiDimDecorator< GUM_SCALAR >::content(), gum::MultiDimDecorator< GUM_SCALAR >::empty(), and gum::projectProduct().

139  {
140  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(this->_content)->empty()) {
141  return this->_empty_value;
142  }
143  return gum::projectProduct(*this->content());
144  }
MultiDimImplementation< GUM_SCALAR > * _content
The true container.
GUM_SCALAR projectProduct(const MultiDimImplementation< GUM_SCALAR > &table, Instantiation *instantiation=0)
the function to be used to project a MultiDimImplementation using a Product
GUM_SCALAR _empty_value
value of the MultiDimDecorator if no dimension.
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).
+ Here is the call graph for this function:

◆ putFirst()

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 553 of file potential_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::contains(), GUM_ERROR, gum::MultiDimDecorator< GUM_SCALAR >::nbrDim(), gum::Potential< GUM_SCALAR >::reorganize(), and gum::MultiDimDecorator< GUM_SCALAR >::variable().

553  {
554  if (!this->contains(*var)) {
555  GUM_ERROR(InvalidArgument,
556  "The variable to put first does not belong to the potential");
557  }
558  if (&(this->variable(0)) == var) return Potential< GUM_SCALAR >(*this);
559 
560  std::vector< const DiscreteVariable* > vars;
561  vars.push_back(var);
562  for (Idx i = 0; i < this->nbrDim(); i++)
563  if (&(this->variable(i)) != var) vars.push_back(&(this->variable(i)));
564 
565  return this->reorganize(vars);
566  }
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:55
+ 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 625 of file potential_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::domainSize(), gum::Potential< GUM_SCALAR >::fillWith(), gum::randomProba(), and gum::Potential< GUM_SCALAR >::sum().

Referenced by gum::SimpleCPTGenerator< GUM_SCALAR >::generateCPT(), gum::Potential< GUM_SCALAR >::randomCPT(), and gum::Potential< GUM_SCALAR >::randomDistribution().

625  {
626  std::vector< GUM_SCALAR > v;
627 
628  GUM_SCALAR sum;
629  v.reserve(this->domainSize());
630  do {
631  sum = 0.0;
632  for (Size i = 0; i < this->domainSize(); ++i) {
633  auto r = (GUM_SCALAR)randomProba();
634  v.push_back(r);
635  sum += r;
636  }
637  } while (sum == 0.0);
638 
639  this->fillWith(v);
640  return *this;
641  }
virtual Size domainSize() const final
Returns the product of the variables domain size.
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:48
+ Here is the call graph for this function:
+ Here is the caller 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 651 of file potential_tpl.h.

References gum::Potential< GUM_SCALAR >::random().

Referenced by gum::Potential< GUM_SCALAR >::noising().

651  {
652  return this->random().normalizeAsCPT();
653  }
const Potential< GUM_SCALAR > & random() const
generate a random Potential with each parameter in [0,1]
+ Here is the call graph for this function:
+ Here is the caller 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 645 of file potential_tpl.h.

References gum::Potential< GUM_SCALAR >::random().

645  {
646  return this->random().normalize();
647  }
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 356 of file multiDimDecorator_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content, and gum::MultiDimDecorator< GUM_SCALAR >::empty().

Referenced by gum::Potential< GUM_SCALAR >::entropy(), gum::Potential< GUM_SCALAR >::maxNonOne(), and gum::Potential< GUM_SCALAR >::minNonZero().

358  {
359  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(_content)->empty()) {
360  return base;
361  } else {
362  return _content->reduce(f, base);
363  }
364  }
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:
+ Here is the caller 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 246 of file multiDimDecorator_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content.

246  {
247  return static_cast< MultiDimContainer< GUM_SCALAR >* >(_content)
248  ->registerSlave(i);
249  }
MultiDimImplementation< GUM_SCALAR > * _content
The true container.
virtual bool registerSlave(Instantiation &i) final
Register i as a slave of this MultiDimAdressable.

◆ reorganize()

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 529 of file potential_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::add(), gum::MultiDimDecorator< GUM_SCALAR >::beginMultipleChanges(), gum::MultiDimDecorator< GUM_SCALAR >::contains(), gum::MultiDimContainer< GUM_SCALAR >::copyFrom(), gum::MultiDimDecorator< GUM_SCALAR >::endMultipleChanges(), GUM_ERROR, and gum::MultiDimDecorator< GUM_SCALAR >::nbrDim().

Referenced by gum::Potential< GUM_SCALAR >::putFirst().

530  {
531  if (vars.size() != this->nbrDim())
532  GUM_ERROR(InvalidArgument,
533  "The vector contains " << vars.size() << " variables instead of "
534  << this->nbrDim() << ".");
535  for (const auto var: vars) {
536  if (!this->contains(*var))
537  GUM_ERROR(InvalidArgument,
538  "A variable in the vector does not belong to the potential.");
539  }
540 
541  Potential< GUM_SCALAR > p;
542  p.beginMultipleChanges();
543  for (const auto var: vars)
544  p.add(*var);
545  p.endMultipleChanges();
546  p.copyFrom(*this, nullptr); // copy *this in p using the same order
547 
548  return p;
549  }
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:55
+ Here is the call graph for this function:
+ Here is the caller 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 36 of file multiDimInterface_inl.h.

References gum::MultiDimInterface::_replace(), gum::MultiDimInterface::contains(), gum::DiscreteVariable::domainSize(), and GUM_ERROR.

Referenced by gum::MultiDimImplementation< std::string >::_replace(), gum::MultiDimBucket< GUM_SCALAR >::_replace(), and gum::MultiDimInterface::~MultiDimInterface().

37  {
38  if (!contains(x)) { GUM_ERROR(NotFound, "could not find the variable"); }
39 
40  if (contains(y)) {
41  GUM_ERROR(DuplicateElement, "variable " << y << " already in MultiDim");
42  }
43 
44  if (x.domainSize() != y.domainSize()) {
45  GUM_ERROR(OperationNotAllowed, "incompatible variables");
46  }
47 
48  _replace(&x, &y);
49  }
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:55
+ Here is the call graph for this function:
+ Here is the caller 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 411 of file potential_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::apply().

Referenced by gum::Potential< GUM_SCALAR >::noising(), gum::Potential< GUM_SCALAR >::operator*(), gum::Potential< GUM_SCALAR >::operator*=(), gum::Potential< GUM_SCALAR >::operator/(), and gum::Potential< GUM_SCALAR >::operator/=().

411  {
412  this->apply([v](GUM_SCALAR x) { return x * v; });
413  return *this;
414  }
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:
+ Here is the caller 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 159 of file multiDimDecorator_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content, gum::MultiDimDecorator< GUM_SCALAR >::_empty_value, and gum::MultiDimDecorator< GUM_SCALAR >::nbrDim().

Referenced by gum::BayesNetFactory< GUM_SCALAR >::__fillProbaWithValuesTable(), gum::prm::PRMSystem< double >::__groundPotential(), gum::prm::GroundedInference< GUM_SCALAR >::_evidenceAdded(), gum::prm::StructuredInference< GUM_SCALAR >::_marginal(), gum::prm::PRMInference< double >::addEvidence(), gum::credal::CredalNet< GUM_SCALAR >::bnToCredal(), gum::BayesNetInference< GUM_SCALAR >::chgEvidence(), gum::MarginalTargetedInference< GUM_SCALAR >::evidenceImpact(), gum::JointTargetedInference< GUM_SCALAR >::evidenceJointImpact(), gum::credal::CredalNet< GUM_SCALAR >::fillConstraint(), gum::SimpleCPTGenerator< GUM_SCALAR >::generateCPT(), gum::credal::CredalNet< GUM_SCALAR >::idmLearning(), gum::prm::PRMInference< double >::marginal(), gum::prm::PRMInference< double >::operator=(), gum::learning::DAG2BNLearner< ALLOC >::operator=(), and gum::prm::PRMInference< double >::PRMInference().

160  {
161  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(_content)->nbrDim() == 0) {
162  _empty_value = value;
163  } else {
164  static_cast< MultiDimContainer< GUM_SCALAR >* >(_content)->set(i, value);
165  }
166  }
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:
+ Here is the caller 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 201 of file multiDimDecorator_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content.

202  {
203  static_cast< MultiDimContainer< GUM_SCALAR >* >(_content)
205  }
MultiDimImplementation< GUM_SCALAR > * _content
The true container.
virtual void setChangeNotification(const Instantiation &i) final
Listen to an assignment of a value in a Instantiation.

◆ 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 238 of file multiDimDecorator_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content.

238  {
239  static_cast< MultiDimContainer< GUM_SCALAR >* >(_content)->setDecNotification(
240  i);
241  }
MultiDimImplementation< GUM_SCALAR > * _content
The true container.
virtual void setDecNotification(const Instantiation &i) final
Listen to increment in each recorded Instantiation.

◆ 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 210 of file multiDimDecorator_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content.

211  {
212  static_cast< MultiDimContainer< GUM_SCALAR >* >(_content)
214  }
MultiDimImplementation< GUM_SCALAR > * _content
The true container.
virtual void setFirstNotification(const Instantiation &i) final
Listen to setFirst in a given Instantiation.

◆ 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 229 of file multiDimDecorator_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content.

229  {
230  static_cast< MultiDimContainer< GUM_SCALAR >* >(_content)->setIncNotification(
231  i);
232  }
MultiDimImplementation< GUM_SCALAR > * _content
The true container.
virtual void setIncNotification(const Instantiation &i) final
Listen to increment in a given Instantiation.

◆ 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 220 of file multiDimDecorator_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content.

220  {
221  static_cast< MultiDimContainer< GUM_SCALAR >* >(_content)->setLastNotification(
222  i);
223  }
MultiDimImplementation< GUM_SCALAR > * _content
The true container.
virtual void setLastNotification(const Instantiation &i) final
Listen to setLast in a given Instantiation.

◆ 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 301 of file potential_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::apply().

301  {
302  this->apply([](GUM_SCALAR x) { return x * x; });
303  return *this;
304  }
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 131 of file potential_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content, gum::MultiDimDecorator< GUM_SCALAR >::_empty_value, gum::MultiDimDecorator< GUM_SCALAR >::content(), gum::MultiDimDecorator< GUM_SCALAR >::empty(), and gum::projectSum().

Referenced by gum::GibbsOperator< GUM_SCALAR >::__GibbsSample(), gum::Potential< GUM_SCALAR >::normalize(), and gum::Potential< GUM_SCALAR >::random().

131  {
132  if (static_cast< MultiDimContainer< GUM_SCALAR >* >(this->_content)->empty()) {
133  return this->_empty_value;
134  }
135  return gum::projectSum(*this->content());
136  }
MultiDimImplementation< GUM_SCALAR > * _content
The true container.
GUM_SCALAR _empty_value
value of the MultiDimDecorator if no dimension.
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
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ toString() [1/2]

template<typename GUM_SCALAR >
INLINE const 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 416 of file multiDimDecorator_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content.

416  {
417  return _content->toString(i);
418  }
MultiDimImplementation< GUM_SCALAR > * _content
The true container.

◆ toString() [2/2]

template<typename GUM_SCALAR>
virtual const 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 479 of file potential.h.

References gum::Potential< GUM_SCALAR >::_complementVars(), and gum::MultiDimDecorator< GUM_SCALAR >::toString().

Referenced by gum::Potential< GUM_SCALAR >::fillWith(), and gum::operator<<().

479  {
481  }
virtual const std::string toString() const
Default implementation of MultiDimContainer::set().
+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ 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 418 of file potential_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::apply().

Referenced by gum::Potential< GUM_SCALAR >::operator+(), gum::Potential< GUM_SCALAR >::operator+=(), gum::Potential< GUM_SCALAR >::operator-(), and gum::Potential< GUM_SCALAR >::operator-=().

418  {
419  this->apply([v](GUM_SCALAR x) { return x + v; });
420  return *this;
421  }
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:
+ Here is the caller 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 293 of file multiDimDecorator_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content.

293  {
294  return static_cast< MultiDimContainer< GUM_SCALAR >* >(_content)
295  ->unregisterSlave(i);
296  }
MultiDimImplementation< GUM_SCALAR > * _content
The true container.
virtual bool unregisterSlave(Instantiation &i) final
Unregister i as a slave of this MultiDimAdressable.

◆ 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 263 of file multiDimDecorator_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content.

Referenced by gum::BayesNetFactory< GUM_SCALAR >::__fillProbaWithValuesTable(), gum::credal::CredalNet< GUM_SCALAR >::__intervalToCredal(), gum::BayesNetFragment< GUM_SCALAR >::_installCPT(), gum::BayesNet< double >::changePotential(), gum::BayesNetInference< GUM_SCALAR >::chgEvidence(), gum::Potential< GUM_SCALAR >::draw(), gum::MultiDimDecorator< GUM_SCALAR >::erase(), gum::Potential< GUM_SCALAR >::fillWith(), gum::SimpleCPTGenerator< GUM_SCALAR >::generateCPT(), gum::BayesNetFragment< GUM_SCALAR >::installCPT(), gum::BayesNetFragment< GUM_SCALAR >::installMarginal(), gum::credal::CredalNet< GUM_SCALAR >::intervalToCredal(), gum::credal::CredalNet< GUM_SCALAR >::intervalToCredalWithFiles(), gum::credal::CredalNet< GUM_SCALAR >::lagrangeNormalization(), gum::Potential< GUM_SCALAR >::normalizeAsCPT(), gum::operator<<(), gum::Potential< GUM_SCALAR >::putFirst(), gum::credal::CredalNet< GUM_SCALAR >::setCPT(), gum::credal::CredalNet< GUM_SCALAR >::setCPTs(), gum::BayesNetFragment< GUM_SCALAR >::uninstallCPT(), and gum::MultiDimDecorator< GUM_SCALAR >::variable().

263  {
264  return static_cast< MultiDimContainer< GUM_SCALAR >* >(_content)->variable(i);
265  }
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 caller 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 269 of file multiDimDecorator_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content, and gum::MultiDimDecorator< GUM_SCALAR >::variable().

269  {
270  return static_cast< MultiDimContainer< GUM_SCALAR >* >(_content)->variable(
271  name);
272  }
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 319 of file multiDimDecorator_tpl.h.

References gum::MultiDimDecorator< GUM_SCALAR >::_content.

Referenced by gum::prm::StructuredInference< GUM_SCALAR >::__buildPatternGraph(), gum::prm::__print_pot__(), gum::BayesNetFactory< GUM_SCALAR >::__setCPTAndParents(), gum::Potential< GUM_SCALAR >::_complementVars(), gum::prm::SVED< GUM_SCALAR >::_marginal(), gum::prm::StructuredInference< GUM_SCALAR >::_marginal(), gum::learning::DAG2BNLearner< ALLOC >::createBN(), gum::credal::CredalNet< GUM_SCALAR >::fillConstraint(), gum::Potential< GUM_SCALAR >::fillWith(), gum::Potential< GUM_SCALAR >::KL(), and gum::learning::DAG2BNLearner< ALLOC >::operator=().

319  {
320  return static_cast< MultiDimContainer< GUM_SCALAR >* >(_content)
321  ->variablesSequence();
322  }
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 caller 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 251 of file multiDimDecorator.h.

Referenced by gum::MultiDimDecorator< GUM_SCALAR >::_swapContent(), gum::MultiDimDecorator< GUM_SCALAR >::add(), gum::MultiDimDecorator< GUM_SCALAR >::apply(), gum::MultiDimDecorator< GUM_SCALAR >::beginMultipleChanges(), gum::MultiDimDecorator< GUM_SCALAR >::changeNotification(), gum::MultiDimDecorator< GUM_SCALAR >::contains(), gum::MultiDimDecorator< GUM_SCALAR >::content(), gum::MultiDimDecorator< GUM_SCALAR >::domainSize(), gum::MultiDimDecorator< GUM_SCALAR >::empty(), gum::MultiDimDecorator< GUM_SCALAR >::endMultipleChanges(), gum::Potential< GUM_SCALAR >::entropy(), gum::MultiDimDecorator< GUM_SCALAR >::erase(), gum::MultiDimDecorator< GUM_SCALAR >::fill(), gum::Potential< GUM_SCALAR >::findAll(), gum::MultiDimDecorator< GUM_SCALAR >::get(), gum::Potential< GUM_SCALAR >::margMaxIn(), gum::Potential< GUM_SCALAR >::margMaxOut(), gum::Potential< GUM_SCALAR >::margMinIn(), gum::Potential< GUM_SCALAR >::margMinOut(), gum::Potential< GUM_SCALAR >::margProdIn(), gum::Potential< GUM_SCALAR >::margProdOut(), gum::Potential< GUM_SCALAR >::margSumIn(), gum::Potential< GUM_SCALAR >::margSumOut(), gum::Potential< GUM_SCALAR >::max(), gum::Potential< GUM_SCALAR >::maxNonOne(), gum::Potential< GUM_SCALAR >::min(), gum::Potential< GUM_SCALAR >::minNonZero(), gum::MultiDimDecorator< GUM_SCALAR >::MultiDimDecorator(), gum::MultiDimDecorator< GUM_SCALAR >::nbrDim(), gum::Potential< GUM_SCALAR >::normalize(), gum::Potential< GUM_SCALAR >::normalizeAsCPT(), gum::MultiDimDecorator< GUM_SCALAR >::operator=(), gum::Potential< GUM_SCALAR >::operator==(), gum::MultiDimDecorator< GUM_SCALAR >::populate(), gum::MultiDimDecorator< GUM_SCALAR >::pos(), gum::Potential< GUM_SCALAR >::product(), gum::MultiDimDecorator< GUM_SCALAR >::reduce(), gum::MultiDimDecorator< GUM_SCALAR >::registerSlave(), gum::MultiDimDecorator< GUM_SCALAR >::set(), gum::MultiDimDecorator< GUM_SCALAR >::setChangeNotification(), gum::MultiDimDecorator< GUM_SCALAR >::setDecNotification(), gum::MultiDimDecorator< GUM_SCALAR >::setFirstNotification(), gum::MultiDimDecorator< GUM_SCALAR >::setIncNotification(), gum::MultiDimDecorator< GUM_SCALAR >::setLastNotification(), gum::Potential< GUM_SCALAR >::sum(), gum::MultiDimDecorator< GUM_SCALAR >::toString(), gum::MultiDimDecorator< GUM_SCALAR >::unregisterSlave(), gum::MultiDimDecorator< GUM_SCALAR >::variable(), gum::MultiDimDecorator< GUM_SCALAR >::variablesSequence(), and gum::MultiDimDecorator< GUM_SCALAR >::~MultiDimDecorator().

◆ _empty_value

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

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