aGrUM 2.3.2
a C++ library for (probabilistic) graphical models
gum::MultiDimBucket< GUM_SCALAR > Class Template Referencefinal

A multidim implementation for buckets. More...

#include <agrum/base/multidim/multiDimBucket.h>

Inheritance diagram for gum::MultiDimBucket< GUM_SCALAR >:
Collaboration diagram for gum::MultiDimBucket< GUM_SCALAR >:

Public Member Functions

const HashTable< const MultiDimContainer< GUM_SCALAR > *, Instantiation * > & multidims () const
 Returns the MultiDimContainer and their respective Instantiation.
Constructor & destructor.
 MultiDimBucket (Size bufferSize=INT_MAX)
 Default constructor.
 MultiDimBucket (const MultiDimBucket< GUM_SCALAR > &source)
 Copy constructor.
virtual ~MultiDimBucket ()
 Destructor.
Bucket methods
void add (const MultiDimContainer< GUM_SCALAR > &impl)
 Add a MultiDimContainer in the bucket.
void add (const MultiDimContainer< GUM_SCALAR > *impl)
 Add a MultiDimContainer in the bucket.
void erase (const MultiDimContainer< GUM_SCALAR > &impl)
 Remove a MultiDimContainer from this bucket.
void erase (const MultiDimContainer< GUM_SCALAR > *impl)
 Remove a MultiDimContainer from this bucket.
bool contains (const MultiDimContainer< GUM_SCALAR > &impl) const
 Returns true if the MultiDimContainer is in this bucket.
const gum::VariableSetallVariables () const
 Returns the sequence of all the variables contained in the bucket.
Size bucketSize () const
 Returns the number of MultiDimContainer in in this bukcet.
bool isBucketEmpty () const
 Returns true if this bucket is empty.
bool bucketChanged () const
 Returns true if the bucket need re-computation since the last computation.
const MultiDimArray< GUM_SCALAR > & bucket () const
 Returns the MultiDimArray used by this MultiDimBucket.
Size bufferSize () const
 Returns the amount of memory allowed for this bucket.
void setBufferSize (Size amount)
 Changes the amount of memory allowed for this bucket.
void compute (bool force=false) const
 This method computes the final table of this bucket.
Inherited methods
virtual MultiDimContainer< GUM_SCALAR > * newFactory () const override
 Default constructor.
const std::string & name () const override
 Returns the real name of the multiDim implementation.
virtual void add (const DiscreteVariable &v) override
 Adds a new var to the variables of the multidimensional matrix.
virtual void erase (const DiscreteVariable &v) override
 Removes a var from the variables of the multidimensional matrix.
virtual Size realSize () const override
 Returns the real number of parameters used for this table.
bool contains (const DiscreteVariable &v) const override
 Returns true if var is in *this.
virtual GUM_SCALAR get (const Instantiation &i) const override
 Returns the value pointed by i.
virtual void changeNotification (const Instantiation &i, const DiscreteVariable *const var, Idx oldval, Idx newval) override
 Listen to changes in a given Instantiation.
virtual void setFirstNotification (const Instantiation &i) override
 Listen to setFirst in a given Instantiation.
virtual void setLastNotification (const Instantiation &i) override
 Listen to setLast in a given Instantiation.
virtual void setIncNotification (const Instantiation &i) override
 Listen to increment in a given Instantiation.
virtual void setDecNotification (const Instantiation &i) override
 Listen to increment in each recorded Instantiation.
virtual void setChangeNotification (const Instantiation &i) override
 Listen to an assignment of a value in a Instantiation.
virtual bool registerSlave (Instantiation &i) override
 Register i as a slave of this MultiDimAdressable.
virtual bool unregisterSlave (Instantiation &i) override
 Unregister i as a slave of this MultiDimAdressable.
virtual MultiDimAdressablegetMasterRef () override
 In order to insure the dereference for decorators, we need to virtualize the access to master pointer.
virtual const MultiDimAdressablegetMasterRef () const override
 In order to insure the dereference for decorators, we need to virtualize the access to master pointer.
virtual std::string toString (const Instantiation *i) const override
 Display the internal representation of i.
Accessors / Modifiers
virtual void set (const Instantiation &i, const GUM_SCALAR &value) const
virtual void fill (const GUM_SCALAR &) const
Accessors / Modifiers
const std::string & basename () const
 Returns the base class name of this MultiDimImplementation.
float compressionRate () const
 The compression ratio of the table (depending on the type of implementation).
MultiDimInterface implementation
virtual Idx nbrDim () const override
 Returns the number of vars in the multidimensional container.
virtual Size domainSize () const override
 Returns the product of the variables domain size.
virtual const Sequence< const DiscreteVariable * > & variablesSequence () const override
 Returns a const ref to the sequence of DiscreteVariable*.
const DiscreteVariablevariable (Idx i) const override
 Returns a const ref to the ith var.
const DiscreteVariablevariable (const std::string &name) const override
 Returns the variable with the name.
virtual Idx pos (const DiscreteVariable &v) const override
 Returns the index of a variable.
virtual bool empty () const override
 Returns true if no var is in *this.
MultiDimContainer implementation
void beginMultipleChanges () override
 Call this method before doing important changes in this MultiDimContainer.
void endMultipleChanges () override
 Call this method after doing important changes in this MultiDimContainer.
void endMultipleChanges (const GUM_SCALAR &) override
 Call this method after doing important changes in this MultiDimContainer.
Accessors / Modifiers
GUM_SCALAR operator[] (const Instantiation &i) const
 An [] operator using a Instantiation as argument.
virtual void populate (const std::vector< GUM_SCALAR > &v) const
 Automatically fills this MultiDimContainer with the values in v.
virtual void populate (std::initializer_list< GUM_SCALAR > l) const
 Automatically fills this MultiDimContainer with the values in l.
Copy methods.
virtual void copyFrom (const MultiDimContainer< GUM_SCALAR > &src) const
 Basic copy of a MultiDimContainer.
virtual void copyFrom (const MultiDimContainer< GUM_SCALAR > &src, Instantiation *p_i) const
 Basic copy of a MultiDimContainer.
virtual void extractFrom (const MultiDimContainer< GUM_SCALAR > &src, const Instantiation &mask)
 Basic extraction of a MultiDimContainer.
virtual void copy (const MultiDimContainer< GUM_SCALAR > &src)
 Removes all variables in this MultiDimContainer and copy the content of src, variables included.
Various methods.
virtual std::string toString () const
 Returns a representation of this MultiDimContainer.
bool operator== (const MultiDimContainer< GUM_SCALAR > &p) const
 Test if this MultiDimContainer is equal to p.
bool operator!= (const MultiDimContainer< GUM_SCALAR > &p) const
 Test if this MultiDimContainer is different of p.
virtual void apply (std::function< GUM_SCALAR(GUM_SCALAR) > f) const
 Apply a function on every element of the container.
virtual GUM_SCALAR reduce (std::function< GUM_SCALAR(GUM_SCALAR, GUM_SCALAR) > f, GUM_SCALAR base) const
 compute lfold for this container
Accessors / Modifiers
void replace (const DiscreteVariable &x, const DiscreteVariable &y)
 Replace variables in this multidim.

Protected Member Functions

virtual void commitMultipleChanges_ () override
 Synchronize content after MultipleChanges.
virtual GUM_SCALAR & get_ (const Instantiation &i) const override
virtual void replace_ (const DiscreteVariable *x, const DiscreteVariable *y) override
 Replace variable x by y.
virtual const MultiDimImplementation< GUM_SCALAR > * content () const final
 Returns the implementation for this object (may be *this).
virtual MultiDimImplementation< GUM_SCALAR > * content () final
 Returns the implementation for this object (may be *this).
Fast large modifications in structures
virtual void commitMultipleChanges_ (const GUM_SCALAR &value)
 Synchronize content after MultipleChanges.
bool isInMultipleChangeMethod_ () const
 Get the actual change method of this MultiDimImplementation.
bool isCommitNeeded_ () const
 Get the actual state of *this.
const List< Instantiation * > & slaves_ () const
 Returns a constant reference over the list of slaved instantiations.
virtual void invert_ (Idx p1, Idx p2)
 Inverts variables at position p1 and p2.

Private Types

enum class  _InternalChangeMethod_ : char { DIRECT_CHANGE , MULTIPLE_CHANGE }
 Used to represent in which change method this MultiDimImplementation is. More...
enum class  _InternalChangeState_ : char { NO_CHANGE , NOT_COMMITTED_CHANGE }
 Used to represent in which change state this MultiDimImplementation is. More...

Private Member Functions

void _addVariable_ (const DiscreteVariable *var)
 Add a variable to allVariables, and do nothing if var is already in the set.
void _eraseVariable_ (const DiscreteVariable *var)
 Erase a variable from allVariables if no other multidimensional table uses it in this bucket.
void _initializeBuffer_ ()
 Initialize the internal buffer.
void _eraseBuffer_ ()
 Clean the buffer and switch it's instantiation to this bucket.
GUM_SCALAR _computeValue_ (const Instantiation &value) const
 Compute the value of the final table of this bucket given i.
void _setNotCommitedChange_ ()
 Change the internalChangeState to NOT_COMMITTED_CHANGE.

Private Attributes

Size _bufferSize_
 The number of element allowed in bucket.
Bijection< Instantiation *, Instantiation * > _instantiations_
 Bijection between instantiations registered on this and their equivalent on bucket.
MultiDimArray< GUM_SCALAR > * _bucket_
 The result table of this bucket.
HashTable< const MultiDimContainer< GUM_SCALAR > *, Instantiation * > _multiDims_
 The set of MultiDimContainer in this bucket.
gum::VariableSet _allVariables_
 The set of all variables of the multidims in this bucket.
Instantiation _allVarsInst_
 Instantiation over all variable in this.
bool _changed_
 Flag used to know if changes has occurred in the bucket since last computation.
HashTable< const Instantiation *, GUM_SCALAR > _slavesValue_
 This table is used to keep the last value computed for an instantiation when the value are computed on the fly.
std::string _name_
 The class name.
Sequence< const DiscreteVariable * > _vars_
 List of discrete variables (dimensions).
List< Instantiation * > _slaveInstantiations_
 List of instantiations of the tuples (sequences) of variables.
_InternalChangeMethod_ _internalChangeMethod_
 The current change method.
_InternalChangeState_ _internalChangeState_
 The current change state.
Size _domainSize_
 This MultiDimImplementation domain size.

Detailed Description

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

A multidim implementation for buckets.

This class behaves in two different ways, depending on the value of memory allowed and the size of the resulting multidimensional table. If the table is above the allowed amount of memory then value are computed when demanded, having a cache for each registered instantiation to not compute several times in a row the same value.

If the memory allowed is enough to contain the bucket's table, then the resulting table is computed when a value is demanded for the first time.

Since a MultiDimArray is used as a buffer, an instantiation real master will be the internal buffer of a MultiDimBucket. This is why you should always call the Instantiation::isMaster() method with the reference retuned by MultiDimBucket::getMasterRef().

TODO handle slave switch between buffer and hashtable.

Template Parameters
GUM_SCALARThe type of scalars stored in this multidimensional table.

Definition at line 90 of file multiDimBucket.h.

Member Enumeration Documentation

◆ _InternalChangeMethod_

template<typename GUM_SCALAR>
enum class gum::MultiDimImplementation::_InternalChangeMethod_ : char
strongprivateinherited

Used to represent in which change method this MultiDimImplementation is.

Enumerator
DIRECT_CHANGE 
MULTIPLE_CHANGE 

Definition at line 295 of file multiDimImplementation.h.

295: char { DIRECT_CHANGE, MULTIPLE_CHANGE };

◆ _InternalChangeState_

template<typename GUM_SCALAR>
enum class gum::MultiDimImplementation::_InternalChangeState_ : char
strongprivateinherited

Used to represent in which change state this MultiDimImplementation is.

Enumerator
NO_CHANGE 
NOT_COMMITTED_CHANGE 

Definition at line 298 of file multiDimImplementation.h.

298: char { NO_CHANGE, NOT_COMMITTED_CHANGE };

Constructor & Destructor Documentation

◆ MultiDimBucket() [1/2]

template<typename GUM_SCALAR>
gum::MultiDimBucket< GUM_SCALAR >::MultiDimBucket ( Size bufferSize = INT_MAX)
explicit

Default constructor.

The default amount of memory available for a bucket is 2^16 (65536) elements in the table.

Parameters
bufferSizeThe amount of memory allowed for this bucket.

Definition at line 56 of file multiDimBucket_tpl.h.

56 :
58 _name_("MultiDimBucket") {
60 }
A multidim implementation for buckets.
MultiDimArray< GUM_SCALAR > * _bucket_
The result table of this bucket.
Size _bufferSize_
The number of element allowed in bucket.
bool _changed_
Flag used to know if changes has occurred in the bucket since last computation.
std::string _name_
The class name.
Size bufferSize() const
Returns the amount of memory allowed for this bucket.
MultiDimBucket(Size bufferSize=INT_MAX)
Default constructor.
MultiDimReadOnly()
Default constructor.

References MultiDimBucket(), gum::MultiDimReadOnly< GUM_SCALAR >::MultiDimReadOnly(), _bucket_, _bufferSize_, _changed_, _name_, and bufferSize().

Referenced by MultiDimBucket(), MultiDimBucket(), ~MultiDimBucket(), and newFactory().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ MultiDimBucket() [2/2]

template<typename GUM_SCALAR>
gum::MultiDimBucket< GUM_SCALAR >::MultiDimBucket ( const MultiDimBucket< GUM_SCALAR > & source)

Copy constructor.

Parameters
sourceThe MultiDimBucket to copy.

Definition at line 63 of file multiDimBucket_tpl.h.

63 :
68 }
Instantiation _allVarsInst_
Instantiation over all variable in this.
HashTable< const MultiDimContainer< GUM_SCALAR > *, Instantiation * > _multiDims_
The set of MultiDimContainer in this bucket.
gum::VariableSet _allVariables_
The set of all variables of the multidims in this bucket.

References MultiDimBucket(), gum::MultiDimReadOnly< GUM_SCALAR >::MultiDimReadOnly(), _allVariables_, _allVarsInst_, _bucket_, _bufferSize_, _changed_, _multiDims_, and _name_.

Here is the call graph for this function:

◆ ~MultiDimBucket()

template<typename GUM_SCALAR>
gum::MultiDimBucket< GUM_SCALAR >::~MultiDimBucket ( )
virtual

Destructor.

Definition at line 71 of file multiDimBucket_tpl.h.

71 {
74
75 for (BiIter iter = _instantiations_.beginSafe(); iter != _instantiations_.endSafe(); ++iter) {
76 delete iter.second();
77 }
78
79 if (_bucket_) { delete _bucket_; }
80
82 = _multiDims_.beginSafe();
83 iter != _multiDims_.endSafe();
84 ++iter) {
85 delete iter.val();
86 }
87 }
Bijection< Instantiation *, Instantiation * > _instantiations_
Bijection between instantiations registered on this and their equivalent on bucket.
MultiDimContainer()
Default constructor.

References MultiDimBucket(), _bucket_, _instantiations_, and _multiDims_.

Here is the call graph for this function:

Member Function Documentation

◆ _addVariable_()

template<typename GUM_SCALAR>
INLINE void gum::MultiDimBucket< GUM_SCALAR >::_addVariable_ ( const DiscreteVariable * var)
private

Add a variable to allVariables, and do nothing if var is already in the set.

Parameters
varThe DiscreteVariable to add.

Definition at line 423 of file multiDimBucket_tpl.h.

423 {
424 try {
425 _allVariables_.insert(var);
426 _allVarsInst_.add(*var);
427 } catch (DuplicateElement const&) {
428 // Nothing to do then!
429 }
430 }

References _allVariables_, and _allVarsInst_.

Referenced by add(), and commitMultipleChanges_().

Here is the caller graph for this function:

◆ _computeValue_()

template<typename GUM_SCALAR>
GUM_SCALAR gum::MultiDimBucket< GUM_SCALAR >::_computeValue_ ( const Instantiation & value) const
private

Compute the value of the final table of this bucket given i.

If i variables are a subset of this bucket, then the missing values are supposed to be at 0.

Parameters
valueThe value to compute.
Exceptions
SizeErrorRaised if the bucket is empty.

Definition at line 497 of file multiDimBucket_tpl.h.

497 {
498 try {
501 _allVarsInst_.setVals(value);
502
503 for (_allVarsInst_.setFirstOut(value); !_allVarsInst_.end(); _allVarsInst_.incOut(value)) {
504 current = (GUM_SCALAR)1;
505
507 = _multiDims_.beginSafe();
508 iter != _multiDims_.endSafe();
509 ++iter) {
510 (iter.val())->setVals(_allVarsInst_);
511 current *= iter.key()->get(*(iter.val()));
512 }
513
514 sum += current;
515 }
516
517 return sum;
518 } catch (NotFound& e) {
519 std::cerr << std::endl << e.errorContent() << std::endl;
520 // This happens if the bucket is empty.
521 GUM_ERROR(SizeError, "This MultiDimBucket is empty.")
522 }
523 }
virtual GUM_SCALAR get(const Instantiation &i) const override
Returns the value pointed by i.
#define GUM_ERROR(type, msg)
Definition exceptions.h:72

References _allVarsInst_, _multiDims_, gum::Exception::errorContent(), and GUM_ERROR.

Referenced by compute(), and get().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ _eraseBuffer_()

template<typename GUM_SCALAR>
void gum::MultiDimBucket< GUM_SCALAR >::_eraseBuffer_ ( )
private

Clean the buffer and switch it's instantiation to this bucket.

Definition at line 484 of file multiDimBucket_tpl.h.

484 {
485 if (_bucket_) {
486 for (auto iter = _instantiations_.beginSafe(); iter != _instantiations_.endSafe(); ++iter) {
487 delete iter.second();
488 }
489
490 _instantiations_.clear();
491 delete _bucket_;
492 _bucket_ = 0;
493 }
494 }

References _bucket_, and _instantiations_.

Referenced by add(), commitMultipleChanges_(), and setBufferSize().

Here is the caller graph for this function:

◆ _eraseVariable_()

template<typename GUM_SCALAR>
void gum::MultiDimBucket< GUM_SCALAR >::_eraseVariable_ ( const DiscreteVariable * var)
private

Erase a variable from allVariables if no other multidimensional table uses it in this bucket.

Parameters
varThe DiscreteVariable to remove.

Definition at line 433 of file multiDimBucket_tpl.h.

433 {
434 bool found = false;
435
437 = _multiDims_.beginSafe();
438 iter != _multiDims_.endSafe();
439 ++iter) {
440 if (iter.key()->contains(*var)) {
441 found = true;
442 break;
443 }
444 }
445
446 // No one use it, we can safely remove it
447 if (!found) {
448 _allVariables_.erase(var);
449 _allVarsInst_.erase(*var);
450 }
451 }
bool contains(const MultiDimContainer< GUM_SCALAR > &impl) const
Returns true if the MultiDimContainer is in this bucket.

References _allVariables_, _allVarsInst_, and _multiDims_.

Referenced by erase().

Here is the caller graph for this function:

◆ _initializeBuffer_()

template<typename GUM_SCALAR>
void gum::MultiDimBucket< GUM_SCALAR >::_initializeBuffer_ ( )
private

Initialize the internal buffer.

This method delete bucket after saving it's slave instantiations.

Definition at line 454 of file multiDimBucket_tpl.h.

454 {
455 if (_bucket_) {
456 for (auto iter = _instantiations_.beginSafe(); iter != _instantiations_.endSafe(); ++iter) {
457 delete iter.second();
458 }
459
460 _instantiations_.clear();
461 delete _bucket_;
462 _bucket_ = 0;
463 }
464
465 // Creating the table.
467
468 for (auto var: this->variablesSequence()) {
469 _bucket_->add(*var);
470 }
471
472 if (!this->slaves_().empty()) {
474 iter != this->slaves_().cendSafe();
475 ++iter) {
477 }
478 }
479
480 _changed_ = true;
481 }
virtual bool empty() const override
Returns true if no var is in *this.
const List< Instantiation * > & slaves_() const
Returns a constant reference over the list of slaved instantiations.
virtual const Sequence< const DiscreteVariable * > & variablesSequence() const override
Returns a const ref to the sequence of DiscreteVariable*.

References _bucket_, _changed_, _instantiations_, gum::MultiDimImplementation< GUM_SCALAR >::empty(), gum::MultiDimImplementation< GUM_SCALAR >::slaves_(), and gum::MultiDimImplementation< GUM_SCALAR >::variablesSequence().

Referenced by add(), commitMultipleChanges_(), erase(), and setBufferSize().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ _setNotCommitedChange_()

template<typename GUM_SCALAR>
INLINE void gum::MultiDimImplementation< GUM_SCALAR >::_setNotCommitedChange_ ( )
privateinherited

Change the internalChangeState to NOT_COMMITTED_CHANGE.

Definition at line 282 of file multiDimImplementation_tpl.h.

References _internalChangeState_, and NOT_COMMITTED_CHANGE.

◆ add() [1/3]

template<typename GUM_SCALAR>
INLINE void gum::MultiDimBucket< GUM_SCALAR >::add ( const DiscreteVariable & v)
overridevirtual

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.

Reimplemented from gum::MultiDimImplementation< GUM_SCALAR >.

Definition at line 194 of file multiDimBucket_tpl.h.

194 {
196
198 if (this->domainSize() <= _bufferSize_) {
199 if (_bucket_) _bucket_->add(v);
200 else _initializeBuffer_();
201 } else if (_bucket_) {
203 }
204 }
205 }
void _initializeBuffer_()
Initialize the internal buffer.
void _eraseBuffer_()
Clean the buffer and switch it's instantiation to this bucket.
virtual void add(const DiscreteVariable &v) override
Adds a new var to the variables of the multidimensional matrix.
virtual Size domainSize() const override
Returns the product of the variables domain size.

References _bucket_, _bufferSize_, _eraseBuffer_(), _initializeBuffer_(), gum::MultiDimImplementation< GUM_SCALAR >::add(), gum::MultiDimImplementation< GUM_SCALAR >::domainSize(), and gum::MultiDimImplementation< GUM_SCALAR >::isInMultipleChangeMethod_().

Here is the call graph for this function:

◆ add() [2/3]

template<typename GUM_SCALAR>
INLINE void gum::MultiDimBucket< GUM_SCALAR >::add ( const MultiDimContainer< GUM_SCALAR > & impl)

Add a MultiDimContainer in the bucket.

Parameters
implThe MultiDimContainer to copy.
Exceptions
DuplicateElementRaised if impl is already in the bucket.

Definition at line 90 of file multiDimBucket_tpl.h.

90 {
91 this->add(&impl);
92 }
void add(const MultiDimContainer< GUM_SCALAR > &impl)
Add a MultiDimContainer in the bucket.

References add().

Referenced by gum::prm::SVE< GUM_SCALAR >::_eliminateDelayedVariables_(), and add().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ add() [3/3]

template<typename GUM_SCALAR>
void gum::MultiDimBucket< GUM_SCALAR >::add ( const MultiDimContainer< GUM_SCALAR > * impl)

Add a MultiDimContainer in the bucket.

Parameters
implThe MultiDimContainer to add.
Exceptions
DuplicateElementRaised if impl is already in the bucket.

Definition at line 95 of file multiDimBucket_tpl.h.

95 {
96 _multiDims_.insert(impl, new Instantiation(*impl));
97
99 for (const auto var: impl->variablesSequence()) {
101 }
102 }
103
104 _changed_ = true;
105 }
void _addVariable_(const DiscreteVariable *var)
Add a variable to allVariables, and do nothing if var is already in the set.

References _addVariable_(), _changed_, _multiDims_, gum::MultiDimImplementation< GUM_SCALAR >::isInMultipleChangeMethod_(), and gum::MultiDimInterface::variablesSequence().

Here is the call graph for this function:

◆ allVariables()

template<typename GUM_SCALAR>
INLINE const gum::VariableSet & gum::MultiDimBucket< GUM_SCALAR >::allVariables ( ) const

Returns the sequence of all the variables contained in the bucket.

Returns
Returns the sequence of all the variables contained in the bucket.

Definition at line 137 of file multiDimBucket_tpl.h.

137 {
138 return _allVariables_;
139 }

References _allVariables_.

Referenced by gum::prm::SVE< GUM_SCALAR >::_eliminateDelayedVariables_().

Here is the caller graph for this function:

◆ apply()

template<typename GUM_SCALAR>
void gum::MultiDimContainer< GUM_SCALAR >::apply ( std::function< GUM_SCALAR(GUM_SCALAR) > f) const
virtualinherited

Apply a function on every element of the container.

Parameters
fthe function to apply

Reimplemented in gum::MultiDimArray< GUM_SCALAR >, and gum::MultiDimDecorator< GUM_SCALAR >.

Definition at line 205 of file multiDimContainer_tpl.h.

205 {
206 Instantiation i(*this);
207 for (i.setFirst(); !i.end(); ++i) {
208 set(i, f(get(i)));
209 }
210 }
Abstract base class for all multi dimensionnal containers.
virtual void set(const Instantiation &i, const GUM_SCALAR &value) const
Changes the value pointed by i.
virtual GUM_SCALAR get(const Instantiation &i) const
Returns the value pointed by i.

References gum::Instantiation::end(), get(), set(), and gum::Instantiation::setFirst().

Here is the call graph for this function:

◆ basename()

template<typename GUM_SCALAR>
const std::string & gum::MultiDimImplementation< GUM_SCALAR >::basename ( ) const
inherited

Returns the base class name of this MultiDimImplementation.

This method is used for chosing a proposer operator when no specialized operator have been defined.

Definition at line 294 of file multiDimImplementation_tpl.h.

294 {
295 static const std::string str = "MultiDimImplementation";
296 return str;
297 }
<agrum/base/multidim/multiDimImplementation.h>

◆ beginMultipleChanges()

template<typename GUM_SCALAR>
INLINE void gum::MultiDimImplementation< GUM_SCALAR >::beginMultipleChanges ( )
overridevirtualinherited

Call this method before doing important changes in this MultiDimContainer.

Warning
Remember to call endMultipleChanges() when you finish your changes.

Implements gum::MultiDimContainer< GUM_SCALAR >.

Definition at line 228 of file multiDimImplementation_tpl.h.

References _internalChangeMethod_, and MULTIPLE_CHANGE.

◆ bucket()

template<typename GUM_SCALAR>
INLINE const MultiDimArray< GUM_SCALAR > & gum::MultiDimBucket< GUM_SCALAR >::bucket ( ) const

Returns the MultiDimArray used by this MultiDimBucket.

Returns
Returns the MultiDimArray used by this MultiDimBucket.
Exceptions
OperationNotAllowedRaised if the bucket has not been built.

Definition at line 531 of file multiDimBucket_tpl.h.

531 {
532 if (_bucket_) {
533 return *_bucket_;
534 } else {
535 GUM_ERROR(OperationNotAllowed, "bucket not used.")
536 }
537 }

References _bucket_, and GUM_ERROR.

◆ bucketChanged()

template<typename GUM_SCALAR>
INLINE bool gum::MultiDimBucket< GUM_SCALAR >::bucketChanged ( ) const

Returns true if the bucket need re-computation since the last computation.

Returns
Returns true if the bucket need re-computation since the last computation.

Definition at line 152 of file multiDimBucket_tpl.h.

152 {
153 return _changed_;
154 }

References _changed_.

◆ bucketSize()

template<typename GUM_SCALAR>
INLINE Size gum::MultiDimBucket< GUM_SCALAR >::bucketSize ( ) const

Returns the number of MultiDimContainer in in this bukcet.

Returns
Returns the number of MultiDimContainer in in this bukcet.

Definition at line 142 of file multiDimBucket_tpl.h.

142 {
143 return _multiDims_.size();
144 }

References _multiDims_.

◆ bufferSize()

template<typename GUM_SCALAR>
INLINE Size gum::MultiDimBucket< GUM_SCALAR >::bufferSize ( ) const

Returns the amount of memory allowed for this bucket.

Returns
Returns the amount of memory allowed for this bucket.

Definition at line 157 of file multiDimBucket_tpl.h.

157 {
158 return _bufferSize_;
159 }

References _bufferSize_.

Referenced by MultiDimBucket().

Here is the caller graph for this function:

◆ changeNotification()

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

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 249 of file multiDimBucket_tpl.h.

252 {
253 if (_bucket_) {
254 try {
255 _bucket_->changeNotification(*(_instantiations_).second(const_cast< Instantiation* >(&i)),
256 var,
257 oldval,
258 newval);
259 } catch (NotFound const&) {
260 // Then i is not a slave of this
261 }
262 } else {
263 _slavesValue_.erase(&i);
264 }
265 }
HashTable< const Instantiation *, GUM_SCALAR > _slavesValue_
This table is used to keep the last value computed for an instantiation when the value are computed o...

References _bucket_, _instantiations_, and _slavesValue_.

◆ commitMultipleChanges_() [1/2]

template<typename GUM_SCALAR>
void gum::MultiDimBucket< GUM_SCALAR >::commitMultipleChanges_ ( )
overrideprotectedvirtual

Synchronize content after MultipleChanges.

Reimplemented from gum::MultiDimImplementation< GUM_SCALAR >.

Definition at line 391 of file multiDimBucket_tpl.h.

391 {
393
394 if (this->domainSize() <= _bufferSize_) {
396 } else {
398 }
399
400 _allVariables_.clear();
401
402 while (!_allVarsInst_.empty()) {
403 _allVarsInst_.erase(**(_allVarsInst_.variablesSequence().beginSafe()));
404 }
405
406 for ( // HashTableIteratorSafe<const MultiDimContainer<GUM_SCALAR>*,
407 // Instantiation*>
408 auto iter = _multiDims_.beginSafe(); iter != _multiDims_.endSafe(); ++iter) {
409 for (auto var: iter.key()->variablesSequence()) {
411 }
412 }
413
414 _changed_ = true;
415 }
virtual void commitMultipleChanges_()
Synchronize content after MultipleChanges.

References _addVariable_(), _allVariables_, _allVarsInst_, _bufferSize_, _changed_, _eraseBuffer_(), _initializeBuffer_(), _multiDims_, gum::MultiDimImplementation< GUM_SCALAR >::commitMultipleChanges_(), and gum::MultiDimImplementation< GUM_SCALAR >::domainSize().

Here is the call graph for this function:

◆ commitMultipleChanges_() [2/2]

template<typename GUM_SCALAR>
INLINE void gum::MultiDimImplementation< GUM_SCALAR >::commitMultipleChanges_ ( const GUM_SCALAR & value)
protectedvirtualinherited

Synchronize content after MultipleChanges.

Parameters
valueDefault value for uninitialized values.

Reimplemented in gum::MultiDimArray< GUM_SCALAR >.

Definition at line 258 of file multiDimImplementation_tpl.h.

258 {
259 // empty!
260 }

◆ compressionRate()

template<typename GUM_SCALAR>
INLINE float gum::MultiDimImplementation< GUM_SCALAR >::compressionRate ( ) const
inherited

The compression ratio of the table (depending on the type of implementation).

This method uses domainSize() and realSize() to compute the ratio, both methods are virtual and should be surcharge if a subclass has a special policies about memory management.

Warning
This compression ratio is not exactly the memory compression ratio. It is computed in terms of number of parameters.
Returns
Returns the compression ration of the table.

Definition at line 288 of file multiDimImplementation_tpl.h.

288 {
289 return ((float)1) - (float)realSize() / (float)domainSize();
290 }
virtual Size realSize() const =0
Returns the real number of parameters used for this table.

References domainSize(), and realSize().

Here is the call graph for this function:

◆ compute()

template<typename GUM_SCALAR>
void gum::MultiDimBucket< GUM_SCALAR >::compute ( bool force = false) const

This method computes the final table of this bucket.

A flag is used to prevent unnecessary computation if the table has already been computed.

If the size of the final table is above the amount of authorized memory, an OperationNotAllowed is raised.

Remember that this method is constant because the content of a multidimensional table is mutable.

Parameters
forceIf true (default set at false) then the final table is re-computed.
Exceptions
OperationNotAllowedRaised if the size of the final table is above the authorized amount of memory.
SizeErrorRaised if the bucket is empty.

Definition at line 173 of file multiDimBucket_tpl.h.

173 {
174 if ((_bucket_) && (_changed_ || force)) {
176
177 for (values.setFirst(); !values.end(); values.inc()) {
179 }
180 } else if ((_bucket_ == 0) && _changed_) {
181 _slavesValue_.clear();
182 _changed_ = false;
183 }
184
185 _changed_ = false;
186 }
GUM_SCALAR _computeValue_(const Instantiation &value) const
Compute the value of the final table of this bucket given i.

References _bucket_, _changed_, _computeValue_(), _slavesValue_, gum::Instantiation::end(), gum::Instantiation::inc(), and gum::Instantiation::setFirst().

Referenced by get().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ contains() [1/2]

template<typename GUM_SCALAR>
INLINE bool gum::MultiDimBucket< GUM_SCALAR >::contains ( const DiscreteVariable & v) const
overridevirtual

Returns true if var is in *this.

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

Reimplemented from gum::MultiDimImplementation< GUM_SCALAR >.

Definition at line 227 of file multiDimBucket_tpl.h.

227 {
229 }
virtual bool contains(const DiscreteVariable &v) const override
Returns true if var is in *this.

References gum::MultiDimImplementation< GUM_SCALAR >::contains().

Here is the call graph for this function:

◆ contains() [2/2]

template<typename GUM_SCALAR>
INLINE bool gum::MultiDimBucket< GUM_SCALAR >::contains ( const MultiDimContainer< GUM_SCALAR > & impl) const

Returns true if the MultiDimContainer is in this bucket.

Parameters
implThe impl to test for existence.
Returns
Returns true if the MultiDimContainer is in this bucket.

Definition at line 132 of file multiDimBucket_tpl.h.

132 {
133 return _multiDims_.exists(&impl);
134 }

References _multiDims_.

◆ content() [1/2]

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

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

Implements gum::MultiDimContainer< GUM_SCALAR >.

Definition at line 332 of file multiDimImplementation_tpl.h.

332 {
333 return this;
334 }

◆ content() [2/2]

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

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

Implements gum::MultiDimContainer< GUM_SCALAR >.

Definition at line 325 of file multiDimImplementation_tpl.h.

325 {
326 return this;
327 }

References MultiDimImplementation().

Here is the call graph for this function:

◆ copy()

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

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

Parameters
srcThe MultiDimContainer to copy.

Reimplemented in gum::MultiDimFunctionGraph< GUM_SCALAR, TerminalNodePolicy >, gum::MultiDimFunctionGraph< bool >, gum::MultiDimFunctionGraph< bool, ExactTerminalNodePolicy >, gum::MultiDimFunctionGraph< double >, gum::MultiDimFunctionGraph< double, ExactTerminalNodePolicy >, gum::MultiDimFunctionGraph< gum::ActionSet, gum::SetTerminalNodePolicy >, gum::MultiDimFunctionGraph< GUM_SCALAR, ExactTerminalNodePolicy >, gum::MultiDimFunctionGraph< Size >, and gum::MultiDimFunctionGraph< Size, ExactTerminalNodePolicy >.

Definition at line 288 of file multiDimContainer_tpl.h.

288 {
289 this->beginMultipleChanges();
290
291 Size nbr = this->nbrDim();
292
293 for (Idx i = 0; i < nbr; i++) {
294 this->erase(this->variable(0));
295 }
296
297 for (Idx i = 0; i < src.nbrDim(); i++) {
298 this->add(src.variable(i));
299 }
300
301 this->endMultipleChanges();
302 this->copyFrom(src);
303 }
virtual void beginMultipleChanges()=0
Call this method before doing important changes in this MultiDimContainer.
virtual void endMultipleChanges()=0
Call this method after doing important changes in this MultiDimContainer.
virtual void copyFrom(const MultiDimContainer< GUM_SCALAR > &src) const
Basic copy of a 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 erase(const DiscreteVariable &v)=0
Removes a var from the variables of the multidimensional matrix.

References MultiDimContainer(), beginMultipleChanges(), gum::MultiDimInterface::erase(), gum::MultiDimInterface::nbrDim(), and gum::MultiDimInterface::variable().

Referenced by gum::TreeRegress< GUM_SCALAR, COMBINEOPERATOR, PROJECTOPERATOR, TerminalNodePolicy >::compute().

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::MultiDimArray< GUM_SCALAR >, and gum::MultiDimICIModel< GUM_SCALAR >.

Definition at line 271 of file multiDimContainer_tpl.h.

271 {
272 if (src.domainSize() != domainSize()) {
274 "Domain sizes do not fit : " << src.domainSize() << "!=" << domainSize());
275 }
276
277 Instantiation i_dest(*this);
279
280 for (i_dest.setFirst(), i_src.setFirst(); !i_dest.end(); ++i_dest, ++i_src) {
281 set(i_dest, src[i_src]);
282 }
283 }
virtual Size domainSize() const =0
Returns the product of the variables domain size.

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

Referenced by gum::aggregator::MultiDimAggregator< GUM_SCALAR >::copyFrom(), gum::MultiDimArray< GUM_SCALAR >::copyFrom(), and gum::MultiDimICIModel< GUM_SCALAR >::copyFrom().

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 >, and gum::MultiDimFunctionGraph< GUM_SCALAR, ExactTerminalNodePolicy >.

Definition at line 225 of file multiDimContainer_tpl.h.

226 {
227 if (src.domainSize() != domainSize()) {
229 "Domain sizes do not fit : " << src.domainSize() << "!=" << domainSize());
230 }
231
232 if (p_i == nullptr) { // if null, we just follow the same order
234 for (i.setFirst(); !i.end(); ++i) {
235 set(i, src[i]);
236 }
237 } else {
238 Instantiation i_dest(*this);
240 for (i_dest.setFirst(), i_src.setFirst(); !i_dest.end(); i_dest.incIn(*p_i), ++i_src) {
241 set(i_dest, src[i_src]);
242 }
243 }
244 }

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

Here is the call graph for this function:

◆ domainSize()

◆ empty()

template<typename GUM_SCALAR>
INLINE bool gum::MultiDimImplementation< GUM_SCALAR >::empty ( ) const
overridevirtualinherited

Returns true if no var is in *this.

Returns
Returns true if no var is in *this.

Implements gum::MultiDimInterface.

Definition at line 222 of file multiDimImplementation_tpl.h.

222 {
223 GUM_ASSERT(!this->isCommitNeeded_());
224 return _vars_.empty();
225 }
Sequence< const DiscreteVariable * > _vars_
List of discrete variables (dimensions).
bool isCommitNeeded_() const
Get the actual state of *this.

References _vars_, and isCommitNeeded_().

Referenced by gum::MultiDimBucket< GUM_SCALAR >::_initializeBuffer_(), and gum::MultiDimArray< GUM_SCALAR >::fill().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ endMultipleChanges() [1/2]

template<typename GUM_SCALAR>
INLINE void gum::MultiDimImplementation< GUM_SCALAR >::endMultipleChanges ( )
overridevirtualinherited

Call this method after doing important changes in this MultiDimContainer.

Implements gum::MultiDimContainer< GUM_SCALAR >.

Definition at line 233 of file multiDimImplementation_tpl.h.

References _internalChangeState_, commitMultipleChanges_(), NO_CHANGE, and NOT_COMMITTED_CHANGE.

Here is the call graph for this function:

◆ endMultipleChanges() [2/2]

template<typename GUM_SCALAR>
INLINE void gum::MultiDimImplementation< GUM_SCALAR >::endMultipleChanges ( const GUM_SCALAR & v)
overridevirtualinherited

Call this method after doing important changes in this MultiDimContainer.

Implements gum::MultiDimContainer< GUM_SCALAR >.

Definition at line 243 of file multiDimImplementation_tpl.h.

References _internalChangeMethod_, _internalChangeState_, commitMultipleChanges_(), DIRECT_CHANGE, NO_CHANGE, and NOT_COMMITTED_CHANGE.

Here is the call graph for this function:

◆ erase() [1/3]

template<typename GUM_SCALAR>
INLINE void gum::MultiDimBucket< GUM_SCALAR >::erase ( const DiscreteVariable & v)
overridevirtual

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.

Reimplemented from gum::MultiDimImplementation< GUM_SCALAR >.

Definition at line 208 of file multiDimBucket_tpl.h.

208 {
210
212 && (this->domainSize() <= _bufferSize_)) {
213 if (_bucket_) {
214 _bucket_->erase(v);
215 } else {
217 }
218 }
219 }
virtual void erase(const DiscreteVariable &v) override
Removes a var from the variables of the multidimensional matrix.

References _bucket_, _bufferSize_, _initializeBuffer_(), gum::MultiDimImplementation< GUM_SCALAR >::domainSize(), gum::MultiDimImplementation< GUM_SCALAR >::erase(), and gum::MultiDimImplementation< GUM_SCALAR >::isInMultipleChangeMethod_().

Here is the call graph for this function:

◆ erase() [2/3]

template<typename GUM_SCALAR>
INLINE void gum::MultiDimBucket< GUM_SCALAR >::erase ( const MultiDimContainer< GUM_SCALAR > & impl)

Remove a MultiDimContainer from this bucket.

Parameters
implThe MultiDimContainer to remove.

Definition at line 108 of file multiDimBucket_tpl.h.

108 {
109 this->erase(&impl);
110 }
void erase(const MultiDimContainer< GUM_SCALAR > &impl)
Remove a MultiDimContainer from this bucket.

References erase().

Referenced by erase().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ erase() [3/3]

template<typename GUM_SCALAR>
void gum::MultiDimBucket< GUM_SCALAR >::erase ( const MultiDimContainer< GUM_SCALAR > * impl)

Remove a MultiDimContainer from this bucket.

Parameters
implThe MultiDimContainer to remove.

Definition at line 113 of file multiDimBucket_tpl.h.

113 {
114 try {
115 delete _multiDims_[impl];
116 _multiDims_.erase(impl);
117
119 for (auto var: impl->variablesSequence()) {
121 }
122 }
123
124 _changed_ = true;
125 } catch (NotFound const&) {
126 // Do nothing
127 }
128 }
void _eraseVariable_(const DiscreteVariable *var)
Erase a variable from allVariables if no other multidimensional table uses it in this bucket.

References _changed_, _eraseVariable_(), _multiDims_, gum::MultiDimImplementation< GUM_SCALAR >::isInMultipleChangeMethod_(), and gum::MultiDimInterface::variablesSequence().

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 Tensor : the

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

Definition at line 247 of file multiDimContainer_tpl.h.

248 {
249 this->beginMultipleChanges();
250
251 Size nbr = this->nbrDim();
252 for (Idx i = 0; i < nbr; i++) {
253 this->erase(this->variable(0));
254 }
255
256 for (Idx i = 0; i < src.nbrDim(); i++) {
257 if (!imask.contains(src.variable(i))) this->add(src.variable(i));
258 }
259
260 this->endMultipleChanges();
261
262 if (this->nbrDim() == 0) { GUM_ERROR(FatalError, "Empty tensor") }
263
265 inst.setVals(imask);
266 for (inst.setFirstOut(imask); !inst.end(); inst.incOut(imask))
267 set(inst, src[inst]);
268 }
virtual bool contains(const DiscreteVariable &v) const =0
Returns true if var is in *this.

References MultiDimContainer(), and beginMultipleChanges().

Here is the call graph for this function:

◆ fill()

template<typename GUM_SCALAR>
void gum::MultiDimReadOnly< GUM_SCALAR >::fill ( const GUM_SCALAR & ) const
virtualinherited
Warning
An OperationNotAllowed will be raised because this is a read only table.

Implements gum::MultiDimContainer< GUM_SCALAR >.

Definition at line 86 of file multiDimReadOnly_tpl.h.

86 {
87 GUM_ERROR(OperationNotAllowed, "Write access to an aggregator")
88 }
Abstract base class for all multi dimensionnal read only structure.

References GUM_ERROR.

◆ get()

template<typename GUM_SCALAR>
INLINE GUM_SCALAR gum::MultiDimBucket< GUM_SCALAR >::get ( const Instantiation & i) const
overridevirtual

Returns the value pointed by i.

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

Reimplemented from gum::MultiDimContainer< GUM_SCALAR >.

Definition at line 232 of file multiDimBucket_tpl.h.

232 {
233 compute();
234
235 if (_bucket_) {
236 try {
237 return _bucket_->get(*(_instantiations_.second(const_cast< Instantiation* >(&i))));
238 } catch (NotFound const&) { return _bucket_->get(i); }
239 } else if (i.isMaster(this)) {
240 if (!_slavesValue_.exists(&i)) { _slavesValue_.insert(&i, _computeValue_(i)); }
241
242 return _slavesValue_[&i];
243 } else {
244 return _computeValue_(i);
245 }
246 }
void compute(bool force=false) const
This method computes the final table of this bucket.

References _bucket_, _computeValue_(), _instantiations_, _slavesValue_, compute(), and gum::Instantiation::isMaster().

Referenced by toString().

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::MultiDimBucket< GUM_SCALAR >::get_ ( const Instantiation & i) const
overrideprotectedvirtual
Warning
This will raise en exception, you should directly use the get() and operator[]() methods.

Reimplemented from gum::MultiDimReadOnly< GUM_SCALAR >.

Definition at line 418 of file multiDimBucket_tpl.h.

418 {
419 GUM_ERROR(OperationNotAllowed, "a MultiDimBucket is a read only MultiDim")
420 }

References GUM_ERROR.

◆ getMasterRef() [1/2]

template<typename GUM_SCALAR>
INLINE const MultiDimAdressable & gum::MultiDimBucket< GUM_SCALAR >::getMasterRef ( ) const
overridevirtual

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

Returns
Returns the master of this MultiDimAdressable.

Reimplemented from gum::MultiDimContainer< GUM_SCALAR >.

Definition at line 375 of file multiDimBucket_tpl.h.

375 {
376 if (_bucket_) {
377 return *_bucket_;
378 } else {
379 return *this;
380 }
381 }

References _bucket_.

◆ getMasterRef() [2/2]

template<typename GUM_SCALAR>
INLINE MultiDimAdressable & gum::MultiDimBucket< GUM_SCALAR >::getMasterRef ( )
overridevirtual

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&

Reimplemented from gum::MultiDimContainer< GUM_SCALAR >.

Definition at line 366 of file multiDimBucket_tpl.h.

366 {
367 if (_bucket_) {
368 return *_bucket_;
369 } else {
370 return *this;
371 }
372 }

References _bucket_.

◆ invert_()

template<typename GUM_SCALAR>
INLINE void gum::MultiDimImplementation< GUM_SCALAR >::invert_ ( Idx p1,
Idx p2 )
protectedvirtualinherited

Inverts variables at position p1 and p2.

Call this from subclass when you want to invert position of two variables in the MultiDimImplementation.

Parameters
p1The first position.
p2The second position.

Definition at line 312 of file multiDimImplementation_tpl.h.

312 {
313 _vars_.swap(p1, p2);
314 }

◆ isBucketEmpty()

template<typename GUM_SCALAR>
INLINE bool gum::MultiDimBucket< GUM_SCALAR >::isBucketEmpty ( ) const

Returns true if this bucket is empty.

Returns
Returns true if this bucket is empty.

Definition at line 147 of file multiDimBucket_tpl.h.

147 {
148 return _multiDims_.empty();
149 }

References _multiDims_.

◆ isCommitNeeded_()

template<typename GUM_SCALAR>
INLINE bool gum::MultiDimImplementation< GUM_SCALAR >::isCommitNeeded_ ( ) const
protectedinherited

Get the actual state of *this.

Returns
Returns true if a commit is needed.

Definition at line 270 of file multiDimImplementation_tpl.h.

References _internalChangeState_, and NOT_COMMITTED_CHANGE.

Referenced by MultiDimImplementation(), and empty().

Here is the caller graph for this function:

◆ isInMultipleChangeMethod_()

template<typename GUM_SCALAR>
INLINE bool gum::MultiDimImplementation< GUM_SCALAR >::isInMultipleChangeMethod_ ( ) const
protectedinherited

Get the actual change method of this MultiDimImplementation.

Returns
Returns true if in multiple changes.

Definition at line 264 of file multiDimImplementation_tpl.h.

References _internalChangeMethod_, and MULTIPLE_CHANGE.

Referenced by gum::MultiDimArray< GUM_SCALAR >::add(), gum::MultiDimBucket< GUM_SCALAR >::add(), gum::MultiDimBucket< GUM_SCALAR >::add(), gum::MultiDimArray< GUM_SCALAR >::erase(), gum::MultiDimBucket< GUM_SCALAR >::erase(), and gum::MultiDimBucket< GUM_SCALAR >::erase().

Here is the caller graph for this function:

◆ multidims()

template<typename GUM_SCALAR>
INLINE const HashTable< const MultiDimContainer< GUM_SCALAR > *, Instantiation * > & gum::MultiDimBucket< GUM_SCALAR >::multidims ( ) const

Returns the MultiDimContainer and their respective Instantiation.

Returns
Returns the MultiDimContainer and their respective Instantiation.

Definition at line 557 of file multiDimBucket_tpl.h.

557 {
558 return _multiDims_;
559 }

References _multiDims_.

◆ name()

template<typename GUM_SCALAR>
const std::string & gum::MultiDimBucket< GUM_SCALAR >::name ( ) const
overridevirtual

Returns the real name of the multiDim implementation.

In aGrUM, all the types of multi-dimensional arrays/functionals have a name that describes what they are in reality. For instance, a table stored in extension is a "MultiDimArray", one that stores only non zero elements is a "MultiDimSparseArray", and so on. These names are unique for each type of implementation and is used by the system to determine which is the best functions to use, say, when we wish to use operators such as operator+ on two MultiDimImplementations.

Returns
Returns the real name of the multiDim implementation

Implements gum::MultiDimImplementation< GUM_SCALAR >.

Definition at line 189 of file multiDimBucket_tpl.h.

189 {
190 return _name_;
191 }

References _name_.

◆ nbrDim()

◆ newFactory()

template<typename GUM_SCALAR>
INLINE MultiDimContainer< GUM_SCALAR > * gum::MultiDimBucket< GUM_SCALAR >::newFactory ( ) const
overridevirtual

Default constructor.

Implements gum::MultiDimReadOnly< GUM_SCALAR >.

Definition at line 526 of file multiDimBucket_tpl.h.

526 {
528 }

References MultiDimBucket().

Here is the call graph for this function:

◆ operator!=()

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

171 {
172 return !operator==(p);
173 }
bool operator==(const MultiDimContainer< GUM_SCALAR > &p) const
Test if this MultiDimContainer is equal to p.

References MultiDimContainer().

Here is the call graph for this function:

◆ operator==()

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

146 {
147 if ((nbrDim() == p.nbrDim()) && (domainSize() == p.domainSize())) {
148 if (nbrDim() == 0) return true;
149
150 for (auto iter = variablesSequence().beginSafe(); iter != variablesSequence().endSafe();
151 ++iter) {
152 if (!p.variablesSequence().exists(*iter)) { return false; }
153 }
154 } else {
155 return false;
156 }
157
158 Instantiation i(*this);
160 for (i.setFirst(); !i.end(); ++i) {
161 if (cmp(get(i), p.get(i))) { return false; }
162 }
163
164 return true;
165 }
virtual const Sequence< const DiscreteVariable * > & variablesSequence() const =0
Returns a const ref to the sequence of DiscreteVariable*.

References MultiDimContainer(), gum::MultiDimInterface::domainSize(), gum::MultiDimInterface::nbrDim(), and gum::MultiDimInterface::variablesSequence().

Here is the call 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 101 of file multiDimContainer_tpl.h.

101 {
102 return get(i);
103 }

References get().

Here is the call graph for this function:

◆ populate() [1/2]

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

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]);
}
Class for assigning/browsing values to tuples of discrete variables.
virtual void set(const Instantiation &i, const GUM_SCALAR &value) const
std::size_t Size
In aGrUM, hashed values are unsigned long int.
Definition types.h:74
Parameters
vVector of values.
Exceptions
SizeErrorRaised if v size's does not matches this MultiDimContainer domain size.

Reimplemented in gum::MultiDimBijArray< GUM_SCALAR >, gum::MultiDimDecorator< GUM_SCALAR >, gum::MultiDimFunctionGraph< GUM_SCALAR, TerminalNodePolicy >, gum::MultiDimFunctionGraph< bool >, gum::MultiDimFunctionGraph< bool, ExactTerminalNodePolicy >, gum::MultiDimFunctionGraph< double >, gum::MultiDimFunctionGraph< double, ExactTerminalNodePolicy >, gum::MultiDimFunctionGraph< gum::ActionSet, gum::SetTerminalNodePolicy >, gum::MultiDimFunctionGraph< GUM_SCALAR, ExactTerminalNodePolicy >, gum::MultiDimFunctionGraph< Size >, and gum::MultiDimFunctionGraph< Size, ExactTerminalNodePolicy >.

Definition at line 177 of file multiDimContainer_tpl.h.

177 {
178 if (domainSize() != v.size()) {
179 GUM_ERROR(SizeError, "Sizes do not match : " << domainSize() << "!=" << v.size())
180 }
181
182 Size cpt = 0;
183
184 Instantiation i(*this);
185
186 for (i.setFirst(); !i.end(); ++i, ++cpt)
187 set(i, v[cpt]);
188 }

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

Referenced by gum::prm::PRMFactory< GUM_SCALAR >::setRawCPFByLines().

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 >, and gum::MultiDimFunctionGraph< GUM_SCALAR, TerminalNodePolicy >.

Definition at line 191 of file multiDimContainer_tpl.h.

191 {
192 if (domainSize() != l.size()) {
193 GUM_ERROR(SizeError, "Sizes do not match : " << domainSize() << "!=" << l.size())
194 }
195
196 Instantiation i(*this);
197 // insert all the elements
198 for (const auto& elt: l) {
199 set(i, elt);
200 ++i;
201 }
202 }

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

Here is the call graph for this function:

◆ pos()

template<typename GUM_SCALAR>
INLINE Idx gum::MultiDimImplementation< GUM_SCALAR >::pos ( const DiscreteVariable & v) const
overridevirtualinherited

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 203 of file multiDimImplementation_tpl.h.

203 {
204 return _vars_.pos(&v);
205 }

References _vars_.

Referenced by gum::MultiDimArray< GUM_SCALAR >::erase(), and gum::MultiDimWithOffset< GUM_SCALAR >::erase().

Here is the caller graph for this function:

◆ realSize()

template<typename GUM_SCALAR>
INLINE Size gum::MultiDimBucket< GUM_SCALAR >::realSize ( ) const
overridevirtual

Returns the real number of parameters used for this table.

This function is used by the MultiDimImplementation::compressionRate() method.

See also
MultiDimImplementation::compressionRate()
Returns
Returns the real number of parameters used for this table.

Implements gum::MultiDimImplementation< GUM_SCALAR >.

Definition at line 222 of file multiDimBucket_tpl.h.

222 {
223 return (_bucket_) ? _bucket_->realSize() : (Size)0;
224 }

References _bucket_.

◆ reduce()

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

compute lfold for this container

Parameters
fthe function to apply
basethe initial value

Reimplemented in gum::MultiDimArray< GUM_SCALAR >, and gum::MultiDimDecorator< GUM_SCALAR >.

Definition at line 214 of file multiDimContainer_tpl.h.

215 {
217 Instantiation i(*this);
218 for (i.setFirst(); !i.end(); ++i) {
219 tmp = f(tmp, get(i));
220 }
221 return tmp;
222 }

References gum::Instantiation::end(), get(), and gum::Instantiation::setFirst().

Here is the call graph for this function:

◆ registerSlave()

template<typename GUM_SCALAR>
INLINE bool gum::MultiDimBucket< GUM_SCALAR >::registerSlave ( Instantiation & i)
overridevirtual

Register i as a slave of this MultiDimAdressable.

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

Reimplemented from gum::MultiDimImplementation< GUM_SCALAR >.

Definition at line 335 of file multiDimBucket_tpl.h.

335 {
336 if (_bucket_) {
337 try {
339 } catch (DuplicateElement const&) { return false; }
340 }
341
343 }
virtual bool registerSlave(Instantiation &slave) override
Register i as a slave of this MultiDimAdressable.

References _bucket_, _instantiations_, and gum::MultiDimImplementation< GUM_SCALAR >::registerSlave().

Here is the call graph for this function:

◆ replace()

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

Replace variables in this multidim.

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

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

Definition at line 56 of file multiDimInterface_inl.h.

56 {
57 if (!contains(x)) { GUM_ERROR(NotFound, "could not find the variable") }
58
59 if (contains(y)) { GUM_ERROR(DuplicateElement, "variable " << y << " already in MultiDim") }
60
61 if (x.domainSize() != y.domainSize()) {
62 GUM_ERROR(OperationNotAllowed, "incompatible variables")
63 }
64
65 replace_(&x, &y);
66 }
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.

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

Here is the call graph for this function:

◆ replace_()

template<typename GUM_SCALAR>
INLINE void gum::MultiDimBucket< GUM_SCALAR >::replace_ ( const DiscreteVariable * x,
const DiscreteVariable * y )
overrideprotectedvirtual

Replace variable x by y.

Technically this should be call by any subclass overloading this method to proceed with the changes in this class containers.

Parameters
xThe first variable to swap.
yThe second variable to swap.

Reimplemented from gum::MultiDimImplementation< GUM_SCALAR >.

Definition at line 540 of file multiDimBucket_tpl.h.

541 {
543 for (auto iter = _instantiations_.beginSafe(); iter != _instantiations_.endSafe(); ++iter) {
544 iter.first()->replace(*x, *y);
545 iter.second()->replace(*x, *y);
546 }
547
548 if (_bucket_) _bucket_->replace(*x, *y);
549
550 _allVariables_.erase(x);
551 _allVariables_.insert(y);
552 _allVarsInst_.replace(*x, *y);
553 }
virtual void replace_(const DiscreteVariable *x, const DiscreteVariable *y) override
Replace variable x by y.
void replace(const DiscreteVariable &x, const DiscreteVariable &y)
Replace variables in this multidim.

References _allVariables_, _allVarsInst_, _bucket_, _instantiations_, and gum::MultiDimImplementation< GUM_SCALAR >::replace_().

Here is the call graph for this function:

◆ set()

template<typename GUM_SCALAR>
INLINE void gum::MultiDimReadOnly< GUM_SCALAR >::set ( const Instantiation & i,
const GUM_SCALAR & value ) const
virtualinherited
Warning
An OperationNotAllowed will be raised because this is a read only table.

Reimplemented from gum::MultiDimContainer< GUM_SCALAR >.

Definition at line 78 of file multiDimReadOnly_tpl.h.

79 {
80 GUM_ERROR(OperationNotAllowed, "Write access to an aggregator")
81 }

References GUM_ERROR.

◆ setBufferSize()

template<typename GUM_SCALAR>
INLINE void gum::MultiDimBucket< GUM_SCALAR >::setBufferSize ( Size amount)

Changes the amount of memory allowed for this bucket.

If the new amount is not enough for the current size of this bucket, then internal buffer is deleted. In the other case, the internal buffer is created but not computed.

Parameters
amountThe amount of memory allowed for this bucket.

Definition at line 162 of file multiDimBucket_tpl.h.

162 {
164
165 if ((this->domainSize() > _bufferSize_) && (_bucket_ != 0)) {
167 } else if (_bucket_ == 0) {
169 }
170 }

References _bucket_, _bufferSize_, _eraseBuffer_(), _initializeBuffer_(), and gum::MultiDimImplementation< GUM_SCALAR >::domainSize().

Here is the call graph for this function:

◆ setChangeNotification()

template<typename GUM_SCALAR>
INLINE void gum::MultiDimBucket< GUM_SCALAR >::setChangeNotification ( const Instantiation & i)
overridevirtual

Listen to an assignment of a value in a Instantiation.

Parameters
iThe Instantiation to listen.

Implements gum::MultiDimAdressable.

Definition at line 321 of file multiDimBucket_tpl.h.

321 {
322 if (_bucket_) {
323 try {
324 _bucket_->setChangeNotification(
325 *(_instantiations_.second(const_cast< Instantiation* >(&i))));
326 } catch (NotFound const&) {
327 // Then i is not a slave of this
328 }
329 } else {
330 _slavesValue_.erase(&i);
331 }
332 }

References _bucket_, _instantiations_, and _slavesValue_.

◆ setDecNotification()

template<typename GUM_SCALAR>
INLINE void gum::MultiDimBucket< GUM_SCALAR >::setDecNotification ( const Instantiation & i)
overridevirtual

Listen to increment in each recorded Instantiation.

Parameters
iThe Instantiation to listen.

Implements gum::MultiDimAdressable.

Definition at line 308 of file multiDimBucket_tpl.h.

308 {
309 if (_bucket_) {
310 try {
311 _bucket_->setDecNotification(*(_instantiations_.second(const_cast< Instantiation* >(&i))));
312 } catch (NotFound const&) {
313 // Then i is not a slave of this
314 }
315 } else {
316 _slavesValue_.erase(&i);
317 }
318 }

References _bucket_, _instantiations_, and _slavesValue_.

◆ setFirstNotification()

template<typename GUM_SCALAR>
INLINE void gum::MultiDimBucket< GUM_SCALAR >::setFirstNotification ( const Instantiation & i)
overridevirtual

Listen to setFirst in a given Instantiation.

Parameters
iThe Instantiation to listen.

Implements gum::MultiDimAdressable.

Definition at line 268 of file multiDimBucket_tpl.h.

268 {
269 if (_bucket_) {
270 try {
271 _bucket_->setFirstNotification(
272 *(_instantiations_).second(const_cast< Instantiation* >(&i)));
273 } catch (NotFound const&) {
274 // Then i is not a slave of this
275 }
276 } else {
277 _slavesValue_.erase(&i);
278 }
279 }

References _bucket_, _instantiations_, and _slavesValue_.

◆ setIncNotification()

template<typename GUM_SCALAR>
INLINE void gum::MultiDimBucket< GUM_SCALAR >::setIncNotification ( const Instantiation & i)
overridevirtual

Listen to increment in a given Instantiation.

Parameters
iThe Instantiation to listen.

Implements gum::MultiDimAdressable.

Definition at line 295 of file multiDimBucket_tpl.h.

295 {
296 if (_bucket_) {
297 try {
298 _bucket_->setIncNotification(*(_instantiations_.second(const_cast< Instantiation* >(&i))));
299 } catch (NotFound const&) {
300 // Then i is not a slave of this
301 }
302 } else {
303 _slavesValue_.erase(&i);
304 }
305 }

References _bucket_, _instantiations_, and _slavesValue_.

◆ setLastNotification()

template<typename GUM_SCALAR>
INLINE void gum::MultiDimBucket< GUM_SCALAR >::setLastNotification ( const Instantiation & i)
overridevirtual

Listen to setLast in a given Instantiation.

Parameters
iThe Instantiation to listen.

Implements gum::MultiDimAdressable.

Definition at line 282 of file multiDimBucket_tpl.h.

282 {
283 if (_bucket_) {
284 try {
285 _bucket_->setLastNotification(*(_instantiations_).second(const_cast< Instantiation* >(&i)));
286 } catch (NotFound const&) {
287 // Then i is not a slave of this
288 }
289 } else {
290 _slavesValue_.erase(&i);
291 }
292 }

References _bucket_, _instantiations_, and _slavesValue_.

◆ slaves_()

template<typename GUM_SCALAR>
INLINE const List< Instantiation * > & gum::MultiDimImplementation< GUM_SCALAR >::slaves_ ( ) const
protectedinherited

Returns a constant reference over the list of slaved instantiations.

Returns
Returns a constant reference over the list of slaved instantiations.

Definition at line 276 of file multiDimImplementation_tpl.h.

276 {
278 }
List< Instantiation * > _slaveInstantiations_
List of instantiations of the tuples (sequences) of variables.

References _slaveInstantiations_.

Referenced by gum::MultiDimBucket< GUM_SCALAR >::_initializeBuffer_().

Here is the caller graph for this function:

◆ toString() [1/2]

template<typename GUM_SCALAR>
INLINE std::string gum::MultiDimBucket< GUM_SCALAR >::toString ( const Instantiation * i) const
overridevirtual

Display the internal representation of i.

Returns
Returns an internal representation of i.

Implements gum::MultiDimContainer< GUM_SCALAR >.

Definition at line 384 of file multiDimBucket_tpl.h.

384 {
386 sBuff << (*i) << " = " << get(*i);
387 return sBuff.str();
388 }

References get().

Here is the call graph for this function:

◆ toString() [2/2]

template<typename GUM_SCALAR>
std::string gum::MultiDimContainer< GUM_SCALAR >::toString ( ) const
virtualinherited

Returns a representation of this MultiDimContainer.

Returns
Returns a representation of this MultiDimContainer.

Reimplemented in gum::aggregator::MultiDimAggregator< GUM_SCALAR >, gum::MultiDimDecorator< GUM_SCALAR >, gum::MultiDimICIModel< GUM_SCALAR >, gum::MultiDimLogit< GUM_SCALAR >, gum::MultiDimNoisyAND< GUM_SCALAR >, gum::MultiDimNoisyORCompound< GUM_SCALAR >, gum::MultiDimNoisyORNet< GUM_SCALAR >, and gum::Tensor< GUM_SCALAR >.

Definition at line 123 of file multiDimContainer_tpl.h.

123 {
124 // we create a new instantiation and iterate over it to display the whole
125 // content of the array
126 if (this->nbrDim() == 0) { return "[]"; }
127
129 Instantiation inst(const_cast< MultiDimContainer* >(this));
130
131 bool first = true;
132
133 for (inst.setFirst(); !inst.end(); ++inst) {
134 if (!first) { ss << " /"; }
135 first = false;
136
137 ss << inst << " :: " << get(inst);
138 }
139
140 return ss.str();
141 }

Referenced by gum::operator<<().

Here is the caller graph for this function:

◆ unregisterSlave()

template<typename GUM_SCALAR>
INLINE bool gum::MultiDimBucket< GUM_SCALAR >::unregisterSlave ( Instantiation & i)
overridevirtual

Unregister i as a slave of this MultiDimAdressable.

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

Reimplemented from gum::MultiDimImplementation< GUM_SCALAR >.

Definition at line 346 of file multiDimBucket_tpl.h.

346 {
348
349 if (_bucket_) {
350 try {
351 delete _instantiations_.second(&i);
352 _instantiations_.eraseFirst(&i);
353 return true;
354 } catch (NotFound const&) { return false; }
355 } else {
356 if (_slavesValue_.exists(&i)) {
357 _slavesValue_.erase(&i);
358 return true;
359 } else {
360 return false;
361 }
362 }
363 }
virtual bool unregisterSlave(Instantiation &i)=0
Unregister i as a slave of this MultiDimAdressable.

References _bucket_, _instantiations_, _slavesValue_, and gum::MultiDimAdressable::unregisterSlave().

Here is the call graph for this function:

◆ variable() [1/2]

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

Returns the variable with the name.

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

Implements gum::MultiDimInterface.

Definition at line 194 of file multiDimImplementation_tpl.h.

194 {
195 for (const auto& v: _vars_) {
196 if (v->name() == name) return *v;
197 }
198
199 GUM_ERROR(NotFound, "'" << name << "' can not be found in the multidim structure.")
200 }
virtual const std::string & name() const =0
Returns the real name of the multiDim implementation.

◆ variable() [2/2]

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

◆ variablesSequence()

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

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 216 of file multiDimImplementation_tpl.h.

216 {
217 return _vars_;
218 }

References _vars_.

Referenced by gum::MultiDimBijArray< GUM_SCALAR >::MultiDimBijArray(), gum::MultiDimBijArray< GUM_SCALAR >::MultiDimBijArray(), gum::MultiDimBijArray< GUM_SCALAR >::MultiDimBijArray(), gum::MultiDimFunctionGraphOperator< GUM_SCALAR, FUNCTOR, TerminalNodePolicy >::_distance_(), gum::MultiDimFunctionGraphOperator< GUM_SCALAR, FUNCTOR, TerminalNodePolicy >::_findRetrogradeVariables_(), gum::Regress< GUM_SCALAR, COMBINEOPERATOR, PROJECTOPERATOR, TerminalNodePolicy >::_findRetrogradeVariables_(), gum::MultiDimBucket< GUM_SCALAR >::_initializeBuffer_(), gum::MultiDimFunctionGraph< GUM_SCALAR, TerminalNodePolicy >::add(), gum::MultiDimFunctionGraph< GUM_SCALAR, TerminalNodePolicy >::clear(), gum::prm::copyTensor(), gum::MultiDimArray< GUM_SCALAR >::erase(), gum::MultiDimWithOffset< GUM_SCALAR >::erase(), gum::MultiDimFunctionGraphGenerator::generate(), gum::MDDOperatorStrategy< GUM_SCALAR >::lastVar_(), gum::StructuredPlaner< GUM_SCALAR >::makeArgMax_(), gum::TreeOperatorStrategy< GUM_SCALAR >::regress(), and gum::MultiDimFunctionGraph< GUM_SCALAR, TerminalNodePolicy >::varNodeListe().

Here is the caller graph for this function:

Member Data Documentation

◆ _allVariables_

template<typename GUM_SCALAR>
gum::VariableSet gum::MultiDimBucket< GUM_SCALAR >::_allVariables_
private

The set of all variables of the multidims in this bucket.

Definition at line 309 of file multiDimBucket.h.

Referenced by MultiDimBucket(), _addVariable_(), _eraseVariable_(), allVariables(), commitMultipleChanges_(), and replace_().

◆ _allVarsInst_

template<typename GUM_SCALAR>
Instantiation gum::MultiDimBucket< GUM_SCALAR >::_allVarsInst_
mutableprivate

Instantiation over all variable in this.

Definition at line 312 of file multiDimBucket.h.

Referenced by MultiDimBucket(), _addVariable_(), _computeValue_(), _eraseVariable_(), commitMultipleChanges_(), and replace_().

◆ _bucket_

◆ _bufferSize_

template<typename GUM_SCALAR>
Size gum::MultiDimBucket< GUM_SCALAR >::_bufferSize_
private

The number of element allowed in bucket.

Definition at line 296 of file multiDimBucket.h.

Referenced by MultiDimBucket(), MultiDimBucket(), add(), bufferSize(), commitMultipleChanges_(), erase(), and setBufferSize().

◆ _changed_

template<typename GUM_SCALAR>
bool gum::MultiDimBucket< GUM_SCALAR >::_changed_
mutableprivate

Flag used to know if changes has occurred in the bucket since last computation.

Definition at line 355 of file multiDimBucket.h.

Referenced by MultiDimBucket(), MultiDimBucket(), _initializeBuffer_(), add(), bucketChanged(), commitMultipleChanges_(), compute(), and erase().

◆ _domainSize_

template<typename GUM_SCALAR>
Size gum::MultiDimImplementation< GUM_SCALAR >::_domainSize_
privateinherited

This MultiDimImplementation domain size.

Definition at line 307 of file multiDimImplementation.h.

Referenced by MultiDimImplementation(), MultiDimImplementation(), and erase().

◆ _instantiations_

template<typename GUM_SCALAR>
Bijection< Instantiation*, Instantiation* > gum::MultiDimBucket< GUM_SCALAR >::_instantiations_
private

◆ _internalChangeMethod_

template<typename GUM_SCALAR>
_InternalChangeMethod_ gum::MultiDimImplementation< GUM_SCALAR >::_internalChangeMethod_
privateinherited

◆ _internalChangeState_

template<typename GUM_SCALAR>
_InternalChangeState_ gum::MultiDimImplementation< GUM_SCALAR >::_internalChangeState_
privateinherited

◆ _multiDims_

template<typename GUM_SCALAR>
HashTable< const MultiDimContainer< GUM_SCALAR >*, Instantiation* > gum::MultiDimBucket< GUM_SCALAR >::_multiDims_
mutableprivate

◆ _name_

template<typename GUM_SCALAR>
std::string gum::MultiDimBucket< GUM_SCALAR >::_name_
private

The class name.

Definition at line 362 of file multiDimBucket.h.

Referenced by MultiDimBucket(), MultiDimBucket(), and name().

◆ _slaveInstantiations_

template<typename GUM_SCALAR>
List< Instantiation* > gum::MultiDimImplementation< GUM_SCALAR >::_slaveInstantiations_
privateinherited

List of instantiations of the tuples (sequences) of variables.

Definition at line 292 of file multiDimImplementation.h.

Referenced by MultiDimImplementation(), ~MultiDimImplementation(), erase(), replace_(), and slaves_().

◆ _slavesValue_

template<typename GUM_SCALAR>
HashTable< const Instantiation*, GUM_SCALAR > gum::MultiDimBucket< GUM_SCALAR >::_slavesValue_
mutableprivate

This table is used to keep the last value computed for an instantiation when the value are computed on the fly.

Definition at line 359 of file multiDimBucket.h.

Referenced by changeNotification(), compute(), get(), setChangeNotification(), setDecNotification(), setFirstNotification(), setIncNotification(), setLastNotification(), and unregisterSlave().

◆ _vars_

template<typename GUM_SCALAR>
Sequence< const DiscreteVariable* > gum::MultiDimImplementation< GUM_SCALAR >::_vars_
privateinherited

List of discrete variables (dimensions).

Definition at line 289 of file multiDimImplementation.h.

Referenced by MultiDimImplementation(), MultiDimImplementation(), empty(), erase(), pos(), registerSlave(), replace_(), variable(), and variablesSequence().


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