![]() |
aGrUM
0.20.3
a C++ library for (probabilistic) graphical models
|
A multidim implementation for buckets. More...
#include <agrum/tools/multidim/multiDimBucket.h>
Public Member Functions | |
const HashTable< const MultiDimContainer< GUM_SCALAR > *, Instantiation *> & | multidims () const |
Returns the MultiDimContainer and their respective Instantiation. More... | |
Constructor & destructor. | |
MultiDimBucket (Size bufferSize=INT_MAX) | |
Default constructor. More... | |
MultiDimBucket (const MultiDimBucket< GUM_SCALAR > &source) | |
Copy constructor. More... | |
virtual | ~MultiDimBucket () |
Destructor. More... | |
Bucket methods | |
void | add (const MultiDimContainer< GUM_SCALAR > &impl) |
Add a MultiDimContainer in the bucket. More... | |
void | add (const MultiDimContainer< GUM_SCALAR > *impl) |
Add a MultiDimContainer in the bucket. More... | |
void | erase (const MultiDimContainer< GUM_SCALAR > &impl) |
Remove a MultiDimContainer from this bucket. More... | |
void | erase (const MultiDimContainer< GUM_SCALAR > *impl) |
Remove a MultiDimContainer from this bucket. More... | |
bool | contains (const MultiDimContainer< GUM_SCALAR > &impl) const |
Returns true if the MultiDimContainer is in this bucket. More... | |
const Set< const DiscreteVariable *> & | allVariables () const |
Returns the sequence of all the variables contained in the bucket. More... | |
Size | bucketSize () const |
Returns the number of MultiDimContainer in in this bukcet. More... | |
bool | isBucketEmpty () const |
Returns true if this bucket is empty. More... | |
bool | bucketChanged () const |
Returns true if the bucket need re-computation since the last computation. More... | |
const MultiDimArray< GUM_SCALAR > & | bucket () const |
Returns the MultiDimArray used by this MultiDimBucket. More... | |
Size | bufferSize () const |
Returns the amount of memory allowed for this bucket. More... | |
void | setBufferSize (Size amount) |
Changes the amount of memory allowed for this bucket. More... | |
void | compute (bool force=false) const |
This method computes the final table of this bucket. More... | |
Inherited methods | |
virtual MultiDimContainer< GUM_SCALAR > * | newFactory () const override |
Default constructor. More... | |
const std::string & | name () const override |
Returns the real name of the multiDim implementation. More... | |
virtual void | add (const DiscreteVariable &v) override |
Adds a new var to the variables of the multidimensional matrix. More... | |
virtual void | erase (const DiscreteVariable &v) override |
Removes a var from the variables of the multidimensional matrix. More... | |
virtual Size | realSize () const override |
Returns the real number of parameters used for this table. More... | |
bool | contains (const DiscreteVariable &v) const override |
Returns true if var is in *this. More... | |
virtual GUM_SCALAR | get (const Instantiation &i) const override |
Returns the value pointed by i. More... | |
virtual void | changeNotification (const Instantiation &i, const DiscreteVariable *const var, Idx oldval, Idx newval) override |
Listen to changes in a given Instantiation. More... | |
virtual void | setFirstNotification (const Instantiation &i) override |
Listen to setFirst in a given Instantiation. More... | |
virtual void | setLastNotification (const Instantiation &i) override |
Listen to setLast in a given Instantiation. More... | |
virtual void | setIncNotification (const Instantiation &i) override |
Listen to increment in a given Instantiation. More... | |
virtual void | setDecNotification (const Instantiation &i) override |
Listen to increment in each recorded Instantiation. More... | |
virtual void | setChangeNotification (const Instantiation &i) override |
Listen to an assignment of a value in a Instantiation. More... | |
virtual bool | registerSlave (Instantiation &i) override |
Register i as a slave of this MultiDimAdressable. More... | |
virtual bool | unregisterSlave (Instantiation &i) override |
Unregister i as a slave of this MultiDimAdressable. More... | |
virtual MultiDimAdressable & | getMasterRef () override |
In order to insure the dereference for decorators, we need to virtualize the access to master pointer. More... | |
virtual const MultiDimAdressable & | getMasterRef () const override |
In order to insure the dereference for decorators, we need to virtualize the access to master pointer. More... | |
virtual std::string | toString (const Instantiation *i) const override |
Display the internal representation of i. More... | |
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. More... | |
float | compressionRate () const |
The compression ratio of the table (depending on the type of implementation). More... | |
MultiDimInterface implementation | |
virtual Idx | nbrDim () const override |
Returns the number of vars in the multidimensional container. More... | |
virtual Size | domainSize () const override |
Returns the product of the variables domain size. More... | |
virtual const Sequence< const DiscreteVariable *> & | variablesSequence () const override |
Returns a const ref to the sequence of DiscreteVariable*. More... | |
const DiscreteVariable & | variable (Idx i) const override |
Returns a const ref to the ith var. More... | |
const DiscreteVariable & | variable (const std::string &name) const override |
Returns the variable with the name. More... | |
virtual Idx | pos (const DiscreteVariable &v) const override |
Returns the index of a variable. More... | |
virtual bool | empty () const override |
Returns true if no var is in *this. More... | |
MultiDimContainer implementation | |
void | beginMultipleChanges () override |
Call this method before doing important changes in this MultiDimContainer. More... | |
void | endMultipleChanges () override |
Call this method after doing important changes in this MultiDimContainer. More... | |
void | endMultipleChanges (const GUM_SCALAR &) override |
Call this method after doing important changes in this MultiDimContainer. More... | |
Accessors / Modifiers | |
GUM_SCALAR | operator[] (const Instantiation &i) const |
An [] operator using a Instantiation as argument. More... | |
virtual void | populate (const std::vector< GUM_SCALAR > &v) const |
Automatically fills this MultiDimContainer with the values in v. More... | |
virtual void | populate (std::initializer_list< GUM_SCALAR > l) const |
Automatically fills this MultiDimContainer with the values in l. 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 void | copy (const MultiDimContainer< GUM_SCALAR > &src) |
Removes all variables in this MultiDimContainer and copy the content of src, variables included. More... | |
Various methods. | |
virtual std::string | toString () const |
Returns a representation of this MultiDimContainer. More... | |
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... | |
virtual void | apply (std::function< GUM_SCALAR(GUM_SCALAR) > f) const |
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 |
compute lfold for this container More... | |
Accessors / Modifiers | |
void | replace (const DiscreteVariable &x, const DiscreteVariable &y) |
Replace variables in this multidim. More... | |
Protected Member Functions | |
virtual void | commitMultipleChanges_ () override |
Synchronize content after MultipleChanges. More... | |
virtual GUM_SCALAR & | get_ (const Instantiation &i) const override |
virtual void | replace_ (const DiscreteVariable *x, const DiscreteVariable *y) override |
Replace variable x by y. More... | |
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... | |
Fast large modifications in structures | |
virtual void | commitMultipleChanges_ (const GUM_SCALAR &value) |
Synchronize content after MultipleChanges. More... | |
bool | isInMultipleChangeMethod_ () const |
Get the actual change method of this MultiDimImplementation. More... | |
bool | isCommitNeeded_ () const |
Get the actual state of *this. More... | |
const List< Instantiation *> & | slaves_ () const |
Returns a constant reference over the list of slaved instantiations. More... | |
virtual void | invert_ (Idx p1, Idx p2) |
Inverts variables at position p1 and p2. More... | |
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.
GUM_SCALAR | The type of scalars stored in this multidimensional table. |
Definition at line 74 of file multiDimBucket.h.
|
explicit |
Default constructor.
The default amount of memory available for a bucket is 2^16 (65536) elements in the table.
bufferSize | The amount of memory allowed for this bucket. |
Definition at line 35 of file multiDimBucket_tpl.h.
gum::MultiDimBucket< GUM_SCALAR >::MultiDimBucket | ( | const MultiDimBucket< GUM_SCALAR > & | source | ) |
Copy constructor.
source | The MultiDimBucket to copy. |
Definition at line 42 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
virtual |
Destructor.
Definition at line 50 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
private |
Add a variable to allVariables, and do nothing if var is already in the set.
var | The DiscreteVariable to add. |
Definition at line 404 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
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.
value | The value to compute. |
SizeError | Raised if the bucket is empty. |
Definition at line 482 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
private |
Clean the buffer and switch it's instantiation to this bucket.
Definition at line 467 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
private |
Erase a variable from allVariables if no other multidimensional table uses it in this bucket.
var | The DiscreteVariable to remove. |
Definition at line 414 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
private |
Initialize the internal buffer.
This method delete bucket after saving it's slave instantiations.
Definition at line 435 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
INLINE void gum::MultiDimBucket< GUM_SCALAR >::add | ( | const MultiDimContainer< GUM_SCALAR > & | impl | ) |
Add a MultiDimContainer in the bucket.
impl | The MultiDimContainer to copy. |
DuplicateElement | Raised if impl is already in the bucket. |
Definition at line 69 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
void gum::MultiDimBucket< GUM_SCALAR >::add | ( | const MultiDimContainer< GUM_SCALAR > * | impl | ) |
Add a MultiDimContainer in the bucket.
impl | The MultiDimContainer to add. |
DuplicateElement | Raised if impl is already in the bucket. |
Definition at line 74 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
overridevirtual |
Adds a new var to the variables of the multidimensional matrix.
v | The new var. |
DuplicateElement | Raised if the variable already belongs to the sequence of variables. |
OperationNotAllowed | Raised if this object is non mutable. |
Reimplemented from gum::MultiDimImplementation< GUM_SCALAR >.
Definition at line 173 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
INLINE const Set< const DiscreteVariable *> & gum::MultiDimBucket< GUM_SCALAR >::allVariables | ( | ) | const |
Returns the sequence of all the variables contained in the bucket.
Definition at line 116 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
virtualinherited |
Apply a function on every element of the container.
f | the function to apply |
Reimplemented in gum::MultiDimDecorator< GUM_SCALAR >, and gum::MultiDimArray< GUM_SCALAR >.
Definition at line 188 of file multiDimContainer_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
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 273 of file multiDimImplementation_tpl.h.
|
overridevirtualinherited |
Call this method before doing important changes in this MultiDimContainer.
Implements gum::MultiDimContainer< GUM_SCALAR >.
Definition at line 207 of file multiDimImplementation_tpl.h.
INLINE const MultiDimArray< GUM_SCALAR > & gum::MultiDimBucket< GUM_SCALAR >::bucket | ( | ) | const |
Returns the MultiDimArray used by this MultiDimBucket.
OperationNotAllowed | Raised if the bucket has not been built. |
Definition at line 516 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
INLINE bool gum::MultiDimBucket< GUM_SCALAR >::bucketChanged | ( | ) | const |
Returns true if the bucket need re-computation since the last computation.
Definition at line 131 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
INLINE Size gum::MultiDimBucket< GUM_SCALAR >::bucketSize | ( | ) | const |
Returns the number of MultiDimContainer in in this bukcet.
Definition at line 121 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
INLINE Size gum::MultiDimBucket< GUM_SCALAR >::bufferSize | ( | ) | const |
Returns the amount of memory allowed for this bucket.
Definition at line 136 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
overridevirtual |
Listen to changes in a given Instantiation.
i | The Instantiation to listen. |
var | The changed dim. |
oldval | The old value. |
newval | The changed value. |
Implements gum::MultiDimAdressable.
Definition at line 230 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
protectedvirtualinherited |
Synchronize content after MultipleChanges.
value | Default value for uninitialized values. |
Reimplemented in gum::MultiDimArray< GUM_SCALAR >.
Definition at line 237 of file multiDimImplementation_tpl.h.
|
overrideprotectedvirtual |
Synchronize content after MultipleChanges.
Reimplemented from gum::MultiDimImplementation< GUM_SCALAR >.
Definition at line 372 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
inherited |
The compression ratio of the table (depending on the type of implementation).
This method uses domainSize() and realSize() to compute the ration, both methods are virtual and should be surcharge if a subclass has a special policies about memory management.
Definition at line 267 of file multiDimImplementation_tpl.h.
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.
force | If true (default set at false) then the final table is re-computed. |
OperationNotAllowed | Raised if the size of the final table is above the authorized amount of memory. |
SizeError | Raised if the bucket is empty. |
Definition at line 152 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
INLINE bool gum::MultiDimBucket< GUM_SCALAR >::contains | ( | const MultiDimContainer< GUM_SCALAR > & | impl | ) | const |
Returns true if the MultiDimContainer is in this bucket.
impl | The impl to test for existence. |
Definition at line 111 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
overridevirtual |
Returns true if var is in *this.
v | A DiscreteVariable. |
Reimplemented from gum::MultiDimImplementation< GUM_SCALAR >.
Definition at line 208 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
finalprotectedvirtualinherited |
Returns the implementation for this object (may be *this).
Implements gum::MultiDimContainer< GUM_SCALAR >.
Definition at line 312 of file multiDimImplementation_tpl.h.
|
finalprotectedvirtualinherited |
Returns the implementation for this object (may be *this).
Implements gum::MultiDimContainer< GUM_SCALAR >.
Definition at line 305 of file multiDimImplementation_tpl.h.
|
virtualinherited |
Removes all variables in this MultiDimContainer and copy the content of src, variables included.
src | The MultiDimContainer to copy. |
Reimplemented in gum::MultiDimFunctionGraph< GUM_SCALAR, TerminalNodePolicy >, gum::MultiDimFunctionGraph< GUM_SCALAR >, and gum::MultiDimFunctionGraph< GUM_SCALAR, ExactTerminalNodePolicy >.
Definition at line 272 of file multiDimContainer_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
virtualinherited |
Basic copy of a MultiDimContainer.
This method is virtual because it should be optimized in certain MultiDimContainer.
src | The MultiDimContainer src which values are copied. This is a full copy with no verification of dimensions. |
OperationNotAllowed | Raised if src does not have the same domain size than this MultiDimContainer. |
Reimplemented in gum::aggregator::MultiDimAggregator< GUM_SCALAR >, gum::MultiDimICIModel< GUM_SCALAR >, and gum::MultiDimArray< GUM_SCALAR >.
Definition at line 255 of file multiDimContainer_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
virtualinherited |
Basic copy of a MultiDimContainer.
This method is virtual because it should be optimized in certain MultiDimContainer.
src | The MultiDimContainer src which values are copied. |
p_i | Give the order to iterate in this MultiDimContainer during the copy (nullptr will correctly copy if this is a reorganization of src). |
OperationNotAllowed | Raised if src does not have the same domain size than this MultiDimContainer. |
Reimplemented in gum::MultiDimFunctionGraph< GUM_SCALAR, TerminalNodePolicy >, gum::MultiDimFunctionGraph< GUM_SCALAR >, and gum::MultiDimFunctionGraph< GUM_SCALAR, ExactTerminalNodePolicy >.
Definition at line 209 of file multiDimContainer_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
overridevirtualinherited |
Returns the product of the variables domain size.
Implements gum::MultiDimInterface.
Definition at line 162 of file multiDimImplementation_tpl.h.
|
overridevirtualinherited |
Returns true if no var is in *this.
Implements gum::MultiDimInterface.
Definition at line 201 of file multiDimImplementation_tpl.h.
|
overridevirtualinherited |
Call this method after doing important changes in this MultiDimContainer.
Implements gum::MultiDimContainer< GUM_SCALAR >.
Definition at line 212 of file multiDimImplementation_tpl.h.
|
overridevirtualinherited |
Call this method after doing important changes in this MultiDimContainer.
Implements gum::MultiDimContainer< GUM_SCALAR >.
Definition at line 222 of file multiDimImplementation_tpl.h.
INLINE void gum::MultiDimBucket< GUM_SCALAR >::erase | ( | const MultiDimContainer< GUM_SCALAR > & | impl | ) |
Remove a MultiDimContainer from this bucket.
impl | The MultiDimContainer to remove. |
Definition at line 87 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
void gum::MultiDimBucket< GUM_SCALAR >::erase | ( | const MultiDimContainer< GUM_SCALAR > * | impl | ) |
Remove a MultiDimContainer from this bucket.
impl | The MultiDimContainer to remove. |
Definition at line 92 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
overridevirtual |
Removes a var from the variables of the multidimensional matrix.
OperationNotAllowed | Raised if this object is non mutable. |
NotFound | Raised if v does not belong to this. |
Reimplemented from gum::MultiDimImplementation< GUM_SCALAR >.
Definition at line 189 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
virtualinherited |
Basic extraction of a MultiDimContainer.
This method is virtual because it should be optimized in certain MultiDimContainer.
src | The MultiDimContainer src which datas are copied. |
mask | partial instantiation of variables of the Potential : the |
extraction will concern every variable not in the instantiation and the copy of data will use the (relevant) values in this instantiation.
Definition at line 231 of file multiDimContainer_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
virtualinherited |
Implements gum::MultiDimContainer< GUM_SCALAR >.
Definition at line 66 of file multiDimReadOnly_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
overridevirtual |
Returns the value pointed by i.
i | An Instantiation of this MultiDimContainer. |
Reimplemented from gum::MultiDimContainer< GUM_SCALAR >.
Definition at line 213 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
overrideprotectedvirtual |
Reimplemented from gum::MultiDimReadOnly< GUM_SCALAR >.
Definition at line 399 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
overridevirtual |
In order to insure the dereference for decorators, we need to virtualize the access to master pointer.
Reimplemented from gum::MultiDimContainer< GUM_SCALAR >.
Definition at line 347 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
overridevirtual |
In order to insure the dereference for decorators, we need to virtualize the access to master pointer.
Reimplemented from gum::MultiDimContainer< GUM_SCALAR >.
Definition at line 356 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
protectedvirtualinherited |
Inverts variables at position p1 and p2.
Call this from subclass when you want to invert position of two variables in the MultiDimImplementation.
p1 | The first position. |
p2 | The second position. |
Definition at line 291 of file multiDimImplementation_tpl.h.
INLINE bool gum::MultiDimBucket< GUM_SCALAR >::isBucketEmpty | ( | ) | const |
Returns true if this bucket is empty.
Definition at line 126 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
protectedinherited |
Get the actual state of *this.
Definition at line 249 of file multiDimImplementation_tpl.h.
|
protectedinherited |
Get the actual change method of this MultiDimImplementation.
Definition at line 243 of file multiDimImplementation_tpl.h.
INLINE const HashTable< const MultiDimContainer< GUM_SCALAR > *, Instantiation *> & gum::MultiDimBucket< GUM_SCALAR >::multidims | ( | ) | const |
Returns the MultiDimContainer and their respective Instantiation.
Definition at line 544 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
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.
Implements gum::MultiDimImplementation< GUM_SCALAR >.
Definition at line 168 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
overridevirtualinherited |
Returns the number of vars in the multidimensional container.
Implements gum::MultiDimInterface.
Definition at line 157 of file multiDimImplementation_tpl.h.
|
overridevirtual |
Default constructor.
Implements gum::MultiDimReadOnly< GUM_SCALAR >.
Definition at line 511 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
inherited |
Test if this MultiDimContainer is different of p.
p | The MultiDimContainer to test for inequality. |
Definition at line 154 of file multiDimContainer_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
inherited |
Test if this MultiDimContainer is equal to p.
p | The MultiDimContainer to test for equality. |
Definition at line 124 of file multiDimContainer_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
inherited |
An [] operator using a Instantiation as argument.
i | An Instantiation. |
Definition at line 79 of file multiDimContainer_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
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.
v | Vector of values. |
SizeError | Raised if v size's does not matches this MultiDimContainer domain size. |
Reimplemented in gum::MultiDimDecorator< GUM_SCALAR >, gum::MultiDimBijArray< GUM_SCALAR >, gum::MultiDimFunctionGraph< GUM_SCALAR, TerminalNodePolicy >, gum::MultiDimFunctionGraph< GUM_SCALAR >, and gum::MultiDimFunctionGraph< GUM_SCALAR, ExactTerminalNodePolicy >.
Definition at line 160 of file multiDimContainer_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
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.
l | contains the data. |
SizeError | Raised if l size's does not matches this MultiDimContainer domain size. |
Reimplemented in gum::MultiDimBijArray< GUM_SCALAR >, gum::MultiDimFunctionGraph< GUM_SCALAR, TerminalNodePolicy >, gum::MultiDimFunctionGraph< GUM_SCALAR >, and gum::MultiDimFunctionGraph< GUM_SCALAR, ExactTerminalNodePolicy >.
Definition at line 174 of file multiDimContainer_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
overridevirtualinherited |
Returns the index of a variable.
v | The variable for which the index is returned. |
NotFound | Raised if v is not in this multidimensional matrix. |
Implements gum::MultiDimInterface.
Definition at line 182 of file multiDimImplementation_tpl.h.
|
overridevirtual |
Returns the real number of parameters used for this table.
This function is used by the MultiDimImplementation::compressionRate() method.
Implements gum::MultiDimImplementation< GUM_SCALAR >.
Definition at line 203 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
virtualinherited |
compute lfold for this container
f | the function to apply |
base | the initial value |
Reimplemented in gum::MultiDimDecorator< GUM_SCALAR >, and gum::MultiDimArray< GUM_SCALAR >.
Definition at line 197 of file multiDimContainer_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
overridevirtual |
Register i as a slave of this MultiDimAdressable.
i | The Instantiation to enslave. |
Reimplemented from gum::MultiDimImplementation< GUM_SCALAR >.
Definition at line 316 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
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.
x | The variable in this which will be replaced. |
y | The variable replacing y. |
NotFound | Raised if x does not belong to this MultiDim. |
OperationNotAllowed | If y and x are not interchangeable. |
DuplicateElement | If y is already in this MultiDim. |
Definition at line 35 of file multiDimInterface_inl.h.
References gum::Set< Key, Alloc >::emplace().
|
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.
x | The first variable to swap. |
y | The second variable to swap. |
Reimplemented from gum::MultiDimImplementation< GUM_SCALAR >.
Definition at line 525 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
virtualinherited |
Reimplemented from gum::MultiDimContainer< GUM_SCALAR >.
Definition at line 58 of file multiDimReadOnly_tpl.h.
References gum::Set< Key, Alloc >::emplace().
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.
amount | The amount of memory allowed for this bucket. |
Definition at line 141 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
overridevirtual |
Listen to an assignment of a value in a Instantiation.
i | The Instantiation to listen. |
Implements gum::MultiDimAdressable.
Definition at line 302 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
overridevirtual |
Listen to increment in each recorded Instantiation.
i | The Instantiation to listen. |
Implements gum::MultiDimAdressable.
Definition at line 289 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
overridevirtual |
Listen to setFirst in a given Instantiation.
i | The Instantiation to listen. |
Implements gum::MultiDimAdressable.
Definition at line 249 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
overridevirtual |
Listen to increment in a given Instantiation.
i | The Instantiation to listen. |
Implements gum::MultiDimAdressable.
Definition at line 276 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
overridevirtual |
Listen to setLast in a given Instantiation.
i | The Instantiation to listen. |
Implements gum::MultiDimAdressable.
Definition at line 263 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
protectedinherited |
Returns a constant reference over the list of slaved instantiations.
Definition at line 255 of file multiDimImplementation_tpl.h.
|
overridevirtual |
Display the internal representation of i.
Implements gum::MultiDimContainer< GUM_SCALAR >.
Definition at line 365 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
virtualinherited |
Returns a representation of this MultiDimContainer.
Reimplemented in gum::Potential< GUM_SCALAR >, gum::MultiDimDecorator< GUM_SCALAR >, gum::aggregator::MultiDimAggregator< GUM_SCALAR >, gum::MultiDimNoisyAND< GUM_SCALAR >, gum::MultiDimNoisyORCompound< GUM_SCALAR >, gum::MultiDimNoisyORNet< GUM_SCALAR >, gum::MultiDimLogit< GUM_SCALAR >, and gum::MultiDimICIModel< GUM_SCALAR >.
Definition at line 101 of file multiDimContainer_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
overridevirtual |
Unregister i as a slave of this MultiDimAdressable.
i | The Instantiation to free. |
Reimplemented from gum::MultiDimImplementation< GUM_SCALAR >.
Definition at line 327 of file multiDimBucket_tpl.h.
References gum::Set< Key, Alloc >::emplace().
|
overridevirtualinherited |
Returns a const ref to the ith var.
param i An index of this multidimensional matrix.
NotFound | Raised if i does not reference a variable in this multidimensional matrix. |
Implements gum::MultiDimInterface.
Definition at line 167 of file multiDimImplementation_tpl.h.
|
overridevirtualinherited |
Returns the variable with the name.
name | The index of the variable |
NotFound | Raised if the element cannot be found. |
Implements gum::MultiDimInterface.
Definition at line 173 of file multiDimImplementation_tpl.h.
|
overridevirtualinherited |
Returns a const ref to the sequence of DiscreteVariable*.
Implements gum::MultiDimInterface.
Definition at line 195 of file multiDimImplementation_tpl.h.
|
private |
The set of all variables of the multidims in this bucket.
Definition at line 293 of file multiDimBucket.h.
|
mutableprivate |
Instantiation over all variable in this.
Definition at line 296 of file multiDimBucket.h.
|
private |
The result table of this bucket.
Definition at line 287 of file multiDimBucket.h.
|
private |
The number of element allowed in bucket.
Definition at line 280 of file multiDimBucket.h.
|
mutableprivate |
Flag used to know if changes has occurred in the bucket since last computation.
Definition at line 339 of file multiDimBucket.h.
|
private |
Bijection between instantiations registered on this and their equivalent on bucket
Definition at line 284 of file multiDimBucket.h.
|
mutableprivate |
The set of MultiDimContainer in this bucket.
Definition at line 290 of file multiDimBucket.h.
|
private |
The class name.
Definition at line 346 of file multiDimBucket.h.
|
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 343 of file multiDimBucket.h.