Tensor and Instantiation
pyagrum.Tensor is a multi-dimensional array with a pyagrum.DiscreteVariable associated to each dimension.
It is used to represent probabilities and utilities tables in aGrUMs’ multidimensional (graphical) models with some conventions.
The data are stored by iterating over each variable in the sequence.
>>> import pyagrum as gum
>>> a=gum.RangeVariable("A","variable A",1,3)
>>> b=gum.RangeVariable("B","variable B",1,2)
>>> p=gum.Tensor().add(a).add(b).fillWith([1,2,3,4,5,6])
>>> print(p)
|| A |
B ||1 |2 |3 |
------||---------|---------|---------|
1 || 1.0000 | 2.0000 | 3.0000 |
2 || 4.0000 | 5.0000 | 6.0000 |
If a
pyagrum.Tensorwith the sequence ofpyagrum.DiscreteVariableX,Y,Z represents a conditional probability Table (CPT), it will be P(X|Y,Z).
>>> print(p.normalizeAsCPT())
|| A |
B ||1 |2 |3 |
------||---------|---------|---------|
1 || 0.1667 | 0.3333 | 0.5000 |
2 || 0.2667 | 0.3333 | 0.4000 |
For addressing and looping in a
pyagrum.Tensorstructure, pyAgrum providespyagrum.Instantiationclass which represents a multi-dimensionnal index.
>>> I=gum.Instantiation(p)
>>> print(I)
<A:1|B:1>
>>> I.inc();print(I)
<A:2|B:1>
>>> I.inc();print(I)
<A:3|B:1>
>>> I.inc();print(I)
<A:1|B:2>
>>> I.setFirst();print(f"{I} -> {p.get(I)}")
<A:1|B:1> -> 0.16666666666666666
>>> I["B"]="2";print(f"{I} -> {p.get(I)}")
<A:1|B:2> -> 0.26666666666666666
pyagrum.Tensorinclude tensor operators (see for instance this notebook).
>>> c=gum.RangeVariable("C","variable C",1,5)
>>> q=gum.Tensor().add(a).add(c).fillWith(1)
>>> print(p+q)
|| A |
C |B ||1 |2 |3 |
------|------||---------|---------|---------|
1 |1 || 1.1667 | 1.3333 | 1.5000 |
2 |1 || 1.1667 | 1.3333 | 1.5000 |
3 |1 || 1.1667 | 1.3333 | 1.5000 |
4 |1 || 1.1667 | 1.3333 | 1.5000 |
5 |1 || 1.1667 | 1.3333 | 1.5000 |
1 |2 || 1.2667 | 1.3333 | 1.4000 |
2 |2 || 1.2667 | 1.3333 | 1.4000 |
3 |2 || 1.2667 | 1.3333 | 1.4000 |
4 |2 || 1.2667 | 1.3333 | 1.4000 |
5 |2 || 1.2667 | 1.3333 | 1.4000 |
>>> print((p*q).sumOut(["B","C"])) # marginalize p*q over B and C(using sum)
A |
1 |2 |3 |
---------|---------|---------|
2.1667 | 3.3333 | 4.5000 |
Instantiation
- class pyagrum.Instantiation(*args)
Class for assigning/browsing values to tuples of discrete variables.
Instantiation is designed to assign values to tuples of variables and to efficiently loop over values of subsets of variables.
- Instantiation() -> Instantiation
default constructor
- Instantiation(aI) -> Instantiation
- Parameters:
aI (pyagrum.Instantiation) – the Instantiation we copy
- Returns:
pyagrum.Instantiation – An empty tuple or a copy of the one in parameters
Instantiation is subscriptable therefore values can be easily accessed/modified.
Examples
>>> ## Access the value of A in an instantiation aI >>> valueOfA = aI['A'] >>> ## Modify the value >>> aI['A'] = newValueOfA
- add(v)
Adds a new variable in the Instantiation.
- Parameters:
v (pyagrum.DiscreteVariable) – The new variable added to the Instantiation
- Raises:
DuplicateElement – If the variable is already in this Instantiation
- Return type:
None
- addVarsFromModel(model, names)
From a graphical model, add all the variable whose names are in the iterable
- Parameters:
model (pyagrum.GraphicalModel)
network (a (discrete) graphical model such as Bayesian)
field (Markov random)
Diagram (Influence)
etc.
names (iterable of strings)
string) (a list/set/etc of names of variables (as)
- Returns:
pyagrum.Instantiation
the current instantiation (self) in order to chain methods.
- chgVal(*args)
Assign newval to v (or to the variable at position varPos) in the Instantiation.
- Parameters:
v (pyagrum.DiscreteVariable or string) – The variable whose value is assigned (or its name)
varPos (int) – The index of the variable whose value is assigned in the tuple of variables of the Instantiation
newval (int or string) – The index of the value assigned (or its name)
- Returns:
The modified instantiation
- Return type:
- Raises:
NotFound – If variable v does not belong to the instantiation.
OutOfBounds – If newval is not a possible value for the variable.
- clear()
Erase all variables from an Instantiation.
- Return type:
None
- contains(*args)
Indicates whether a given variable belongs to the Instantiation.
- Parameters:
v (pyagrum.DiscreteVariable) – The variable for which the test is made.
- Returns:
True if the variable is in the Instantiation.
- Return type:
bool
- dec()
Operator –.
- Return type:
None
- decIn(i)
Operator – for the variables in i.
- Parameters:
i (pyagrum.Instantiation) – The set of variables to decrement in this Instantiation
- Return type:
None
- decNotVar(v)
Operator – for vars which are not v.
- Parameters:
v (pyagrum.DiscreteVariable) – The variable not to decrement in this Instantiation.
- Return type:
None
- decOut(i)
Operator – for the variables not in i.
- Parameters:
i (pyagrum.Instantiation) – The set of variables to not decrement in this Instantiation.
- Return type:
None
- decVar(v)
Operator – for variable v only.
- Parameters:
v (pyagrum.DiscreteVariable) – The variable to decrement in this Instantiation.
- Raises:
NotFound – If variable v does not belong to the Instantiation.
- Return type:
None
- domainSize()
- Returns:
The product of the variable’s domain size in the Instantiation.
- Return type:
int
- empty()
- Returns:
True if the instantiation is empty.
- Return type:
bool
- end()
- Returns:
True if the Instantiation reached the end.
- Return type:
bool
- erase(*args)
- Parameters:
v (pyagrum.DiscreteVariable) – The variable to be removed from this Instantiation.
- Raises:
NotFound – If v does not belong to this Instantiation.
- Return type:
None
- fromdict(dict)
Change the values in an instantiation from a dictionary {variable_name:value} where value can be a position (int) or a label (string).
If a variable_name does not occur in the instantiation, nothing is done.
Warning
OutOfBounds raised if a value cannot be found.
- Parameters:
dict (
object)- Return type:
None
- hamming()
- Returns:
the hamming distance of this instantiation.
- Return type:
int
- inOverflow()
- Returns:
True if the current value of the tuple is correct
- Return type:
bool
- inc()
Operator ++.
- Return type:
None
- incIn(i)
Operator ++ for the variables in i.
- Parameters:
i (pyagrum.Instantiation) – The set of variables to increment in this Instantiation.
- Return type:
None
- incNotVar(v)
Operator ++ for vars which are not v.
- Parameters:
v (pyagrum.DiscreteVariable) – The variable not to increment in this Instantiation.
- Return type:
None
- incOut(i)
Operator ++ for the variables not in i.
- Parameters:
i (Instantiation) – The set of variable to not increment in this Instantiation.
- Return type:
None
- incVar(v)
Operator ++ for variable v only.
- Parameters:
v (pyagrum.DiscreteVariable) – The variable to increment in this Instantiation.
- Raises:
NotFound – If variable v does not belong to the Instantiation.
- Return type:
None
- isMutable()
- Return type:
bool
- loopIn()
Generator to iterate on an Instantiation.
Yield an pyagrum.Instantiation (copy of self) that iterates over all the possible values for the Instantiation.
Examples
>>> import pyagrum as gum >>> bn=pyagrum.fastBN("A[3]->B[3]<-C[3]") >>> I=pyagrum.Instantiation(bn.cpt("B")) >>> for i in I.loopIn(): print(i) print(bn.cpt("B").get(i)) bn.cpt("B").set(i,0.3)
- nbrDim()
- Returns:
The number of variables in the Instantiation.
- Return type:
int
- pos(v)
- Returns:
the position of the variable v.
- Return type:
int
- Parameters:
v (pyagrum.DiscreteVariable) – the variable for which its position is return.
- Raises:
NotFound – If v does not belong to the instantiation.
- rend()
- Returns:
True if the Instantiation reached the rend.
- Return type:
bool
- reorder(*args)
Reorder vars of this instantiation giving the order in v (or i).
- Parameters:
i (pyagrum.Instantiation) – The sequence of variables with which to reorder this Instantiation.
v (list) – The new order of variables for this Instantiation.
- Return type:
None
- setFirst()
Assign the first values to the tuple of the Instantiation.
- Return type:
None
- setFirstIn(i)
Assign the first values in the Instantiation for the variables in i.
- Parameters:
i (pyagrum.Instantiation) – The variables to which their first value is assigned in this Instantiation.
- Return type:
None
- setFirstNotVar(v)
Assign the first values to variables different of v.
- Parameters:
v (pyagrum.DiscreteVariable) – The variable that will not be set to its first value in this Instantiation.
- Return type:
None
- setFirstOut(i)
Assign the first values in the Instantiation for the variables not in i.
- Parameters:
i (pyagrum.Instantiation) – The variable that will not be set to their first value in this Instantiation.
- Return type:
None
- setFirstVar(v)
Assign the first value in the Instantiation for var v.
- Parameters:
v (pyagrum.DiscreteVariable) – The variable that will be set to its first value in this Instantiation.
- Return type:
None
- setLast()
Assign the last values in the Instantiation.
- Return type:
None
- setLastIn(i)
Assign the last values in the Instantiation for the variables in i.
- Parameters:
i (pyagrum.Instantiation) – The variables to which their last value is assigned in this Instantiation.
- Return type:
None
- setLastNotVar(v)
Assign the last values to variables different of v.
- Parameters:
v (pyagrum.DiscreteVariable) – The variable that will not be set to its last value in this Instantiation.
- Return type:
None
- setLastOut(i)
Assign the last values in the Instantiation for the variables not in i.
- Parameters:
i (pyagrum.Instantiation) – The variables that will not be set to their last value in this Instantiation.
- Return type:
None
- setLastVar(v)
Assign the last value in the Instantiation for var v.
- Parameters:
v (pyagrum.DiscreteVariable) – The variable that will be set to its last value in this Instantiation.
- Return type:
None
- setMutable()
- Return type:
None
- setVals(i)
Assign the values from i in the Instantiation.
- Parameters:
i (pyagrum.Instantiation) – An Instantiation in which the new values are searched
- Returns:
a reference to the instantiation
- Return type:
- todict(withLabels=False)
Create a dictionary {variable_name:value} from an instantiation
- Parameters:
withLabels (boolean) – The value will be a label (string) if True. It will be a position (int) if False. Default is False
- Returns:
The dictionary
- Return type:
Dict[str,int]
- unsetEnd()
Alias for unsetOverflow().
- Return type:
None
- unsetOverflow()
Removes the flag overflow.
- Return type:
None
- val(*args)
- Parameters:
i (int) – The index of the variable.
var (pyagrum.DiscreteVariable) – The variable the value of which we wish to know
- Returns:
the current value of the variable.
- Return type:
int
- Raises:
NotFound – If the element cannot be found.
- variable(*args)
- Parameters:
i (int) – The index of the variable
- Returns:
the variable at position i in the tuple.
- Return type:
- Raises:
NotFound – If the element cannot be found.
- variablesSequence()
- Returns:
a list containing the sequence of variables
- Return type:
list
Tensor
- class pyagrum.Tensor(*args)
Class representing a tensor.
- Tensor() -> Tensor
default constructor
- Tensor(src) -> Tensor
- Parameters:
src (* pyagrum.Tensor *) – the Tensor to copy
- Tensor(v1,v2, …) -> Tensor
- Parameters:
v1,v2… (* pyagrum.DiscreteVariable *) – the variables to be added to the tensor
- KL(p)
Check the compatibility and compute the Kullback-Leibler divergence between the tensor and.
- Parameters:
p (pyagrum.Tensor) – the tensor from which we want to calculate the divergence.
- Returns:
The value of the divergence
- Return type:
float
- Raises:
pyagrum.InvalidArgument – If p is not compatible with the tensor (dimension, variables)
pyagrum.FatalError – If a zero is found in p or the tensor and not in the other.
- abs()
Apply abs on every element of the container
- Returns:
a reference to the modified tensor.
- Return type:
- add(v)
Add a discrete variable to the tensor.
- Parameters:
v (pyagrum.DiscreteVariable) – the var to be added
- Raises:
DuplicateElement – If the variable is already in this Tensor.
InvalidArgument – If the variable is empty.
- Returns:
a reference to the modified tensor.
- Return type:
- argmax()
- Returns:
the list of positions of the max and the max of all elements in the Tensor
- Return type:
Tuple[Dict[str,int],float]
- argmin()
- Returns:
the list of positions of the min and the min of all elements in the Tensor
- Return type:
Tuple[Dict[str,int],float]
- contains(v)
- Parameters:
v (pyagrum.Tensor) – a DiscreteVariable.
- Returns:
True if the var is in the tensor
- Return type:
bool
- static deterministicTensor(*args)
This static method generates a Tensor representing a deterministic function of a
pyagrum.DiscreteVariable) such as a hard evidence.- Parameters:
var (pyagrum.DiscreteVariable) – the variable to use
value (int str) – the indice or the label of the value for the variable
- Returns:
The representation of the deterministic function as a
pyagrum.Tensor.- Return type:
- domainSize()
Compute the size of the domain of the Tensor, i.e., the product of the domain sizes of the variables in the Tensor.
- Returns:
the size of the domain of the Tensor (the number of values it can take)
- Return type:
int
- draw()
draw a value using the tensor as a probability table.
- Returns:
the index of the drawn value
- Return type:
int
- empty()
- Returns:
Returns true if no variable is in the tensor.
- Return type:
bool
- entropy()
- Returns:
the entropy of the tensor
- Return type:
float
- static evEq(v, val)
This static method generates a Tensor representing an observation where a quasi-continuous variable (a
pyagrum.DiscretizedVariablewith many ticks) takes a specific given value.Note
see also
BayesNet.evEq()see also
Tensor.evGt(),Tensor.evLt(),Tensor.evIn()
Examples
>>> A=pyagrum.fastVariable('A[0:10:20]') >>> p=pyagrum.Tensor.evEq(A,5) >>> p (pyagrum.Tensor@000001D7FAB06AD0) A | [0;0.5[ |[0.5;1[ |[1;1.5[ |[1.5;2[ |[2;2.5[ |[2.5;3[ |[3;3.5[ |[3.5;4[ |[4;4.5[ |[4.5;5[ |[5;5.5[ |[5.5;6[ |[6;6.5[ |[6.5;7[ |[7;7.5[ |[7.5;8[ |[8;8.5[ |[8.5;9[ |[9;9.5[ |[9.5;10] | ---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------| 0.0000 | 0.0000 | 0.0000 | 0.0000 | 0.0000 | 0.0000 | 0.0000 | 0.0000 | 0.0000 | 0.0000 | 1.0000 | 0.0000 | 0.0000 | 0.0000 | 0.0000 | 0.0000 | 0.0000 | 0.0000 | 0.0000 | 0.0000 |
- Parameters:
var (pyagrum.DiscretizedVariable) – the variable to use
value (float)
v (
DiscreteVariable)val (
float)
- Returns:
The representation of the evidence as a
Tensor.- Return type:
- static evGt(v, val)
This static method generates a Tensor representing an observation where a quasi-continuous variable (a
pyagrum.DiscretizedVariablewith many ticks) takes a value greater than the parameter.Note
see also
BayesNet.evGt()see also
Tensor.evEq(),Tensor.evLt(),Tensor.evIn()
Examples
>>> A=pyagrum.fastVariable('A[0:10:20]') >>> p=pyagrum.Tensor.evGt(A,5) >>> p (pyagrum.Tensor@000001D7FAB06AD0) A | [0;0.5[ |[0.5;1[ |[1;1.5[ |[1.5;2[ |[2;2.5[ |[2.5;3[ |[3;3.5[ |[3.5;4[ |[4;4.5[ |[4.5;5[ |[5;5.5[ |[5.5;6[ |[6;6.5[ |[6.5;7[ |[7;7.5[ |[7.5;8[ |[8;8.5[ |[8.5;9[ |[9;9.5[ |[9.5;10] | ---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------| 0.0000 | 0.0000 | 0.0000 | 0.0000 | 0.0000 | 0.0000 | 0.0000 | 0.0000 | 0.0000 | 0.0000 | 1.0000 | 1.0000 | 1.0000 | 1.0000 | 1.0000 | 1.0000 | 1.0000 | 1.0000 | 1.0000 | 1.0000 |
- Parameters:
var (pyagrum.DiscretizedVariable) – the variable to use
value (float)
v (
DiscreteVariable)val (
float)
- Returns:
The representation of the evidence as a
Tensor.- Return type:
- static evIn(v, val1, val2)
This static method generates a Tensor representing an observation where a quasi-continuous variable (a
pyagrum.DiscretizedVariablewith many ticks) takes a value between the 2 paramerts (min,max)Note
see also
BayesNet.evIn()see also
Tensor.evEq(),Tensor.evLt(),Tensor.evGt()
- Parameters:
var (pyagrum.DiscretizedVariable) – the variable to use
valueMin (float) – the minimum value
valueMax (float) – the maximum value
v (
DiscreteVariable)val1 (
float)val2 (
float)
- Returns:
The representation of the evidence as a
Tensor.- Return type:
pyAgrum.Tensor
- static evLt(v, val)
This static method generates a Tensor representing an observation where a quasi-continuous variable (a
pyagrum.DiscretizedVariablewith many ticks) takes a value less than the parameter.Note
see also
BayesNet.evLt()see also
Tensor.evEq(),Tensor.evGt(),Tensor.evIn()
- Parameters:
var (pyagrum.DiscretizedVariable) – the variable to use
value (float)
v (
DiscreteVariable)val (
float)
- Returns:
The representation of the evidence as a
Tensor.- Return type:
- expectedValue(*args)
Calculate the mathematical expected value of a (joint) random variable using the given function as an argument.
- Parameters:
func (function(Dict[str,int])->float) – A function that takes a single argument, representing the value of a python representation of a pyagrum.Instantiation (as a dictionary), and returns a float.
Warning
The pyagrum.Tensor is assumed to contain a joint distribution.
Examples
>>> def log2cptA(x): ... return -math.log2(bn.cpt('A')[x]) >>> entropy_of_A=bn.cpt('A').expectedValue(log2cptA) # OK it A has no parents.
- Returns:
The mathematical expected value of the random variable calculated using the given function as an argument.
- Return type:
float
- extract(*args)
create a new Tensor extracted from self given a partial instantiation.
- Parameters:
inst (pyagrum.instantiation) – a partial instantiation
dict (Dict[str,str|int]) – a dictionnary containing values for some discrete variables.
Warning
if the dictionnary contains a key that is not the name of a variable in the pyagrum.Tensor, this key is just not used without notification. Then pyagrum.Tensor.extract concerns only the variables that both are in the Tensor and in the dictionnary.
- Returns:
the new Tensor
- Return type:
- fillFromDistribution(distribution, **s_fns)
Automatically fills the tensor as a familly of distributions whose parameters are found using evaluation of the expressions s_fns.
The symbolic expressions s_fns gives a value for the named parameters of the distributions.
Examples
>>> import scipy.stats as stats >>> import pyagrum as gum >>> bn=pyagrum.fastBN('A[10]->B[10]<-C[10]') >>> bn.cpt("B").fillFromDistribution(stats.norm,loc="(A+C)/2",scale=1)
- Parameters:
s_fns (a list of named arguments (str)) – the named arguments with an evaluation of the expressions in s_fns are passed as argument for the chosen distribution.
- Returns:
a reference to the modified tensor
- Return type:
- Raises:
pyagrum.InvalidArgument – If the first variable is Labelized.
- fillFromExpression(s_fn)
Automatically fills the tensor with the evaluation of the expression s_fn (no matter if is a CPT or not).
The symbolic expression s_fn gives a value for each parameters of the Tensor
Examples
>>> import pyagrum as gum >>> bn=pyagrum.fastBN('A[3]->B[3]<-C[3]') >>> bn.cpt('B').fillFromFunction('(B+A+C)/2')
- Parameters:
s_fn (str) – a symbolic expression using the name of the variables of the Tensor and giving a value to the first variable of the Tensor. This evaluation is done in a context that inclides ‘math’ module.
Warning
The expression may have any numerical values, but will be then transformed to the closest correct value for the range of the variable.
- Returns:
a reference to the modified tensor
- Return type:
- fillFromFunction(s_fn)
Automatically fills the tensor as a deterministic CPT with the evaluation of the expression s_fn.
The symbolic expression s_fn gives a value for the first variable, depending on the following variables. The computed CPT is deterministic.
Examples
>>> import pyagrum as gum >>> bn=pyagrum.fastBN('A[3]->B[3]<-C[3]') >>> bn.cpt('B').fillFromFunction('(A+C)/2')
- Parameters:
s_fn (str) – a symbolic expression using the name of the second and following variables of the Tensor and giving a value to the first variable of the Tensor. This evaluation is done in a context that inclides ‘math’ module.
Warning
The expression may have any numerical values, but will be then transformed to the closest correct value for the range of the variable.
- Returns:
a reference to the modified tensor
- Return type:
- Raises:
pyagrum.InvalidArgument – If the first variable is Labelized.
- fillWith(*args)
Automatically fills the tensor with v.
- Parameters:
v (number or list of values or pyagrum.Tensor) – a value or a list/pyagrum.Tensor containing the values to fill the Tensor with.
mapping (list|tuple|dict)
Warning
if v is a list, the size of the list must be the size of the tensor
if v is a ref:pyagrum.Tensor, it must contain variables with exactly the same names and labels but not necessarily the same variables. If
If the second argument mapping is given, mapping explains how to map the variables of the tensor source to the variables of the tensor destination.
If mapping is a sequence, the order follows the same order as destination.names. If mapping is a dict, the keys are the names in the destination and the values are the names in the source.
- Returns:
a reference to the modified potentia
- Return type:
- Raises:
pyagrum.SizeError – If v size’s does not matches the domain size.
pyagrum.ArgumentError – If anything wrong with the arguments.
- findAll(v)
Find all the position of a value in the Tensor.
- Parameters:
v (float) – the value to find
- Returns:
a list of all the instantiations (as python dictionary) where the value is found
- Return type:
list[dict[str,int]]
- get(i)
- Parameters:
i (pyagrum.Instantiation) – an Instantiation
- Returns:
the value in the Tensor at the position given by the instantiation
- Return type:
float
- isEvidence()
- Return type:
bool
- isNonZeroMap()
- Returns:
a boolean-like tensor using the predicate isNonZero.
- Return type:
- log2()
log2 all the values in the Tensor
Warning
When the Tensor contains 0 or negative values, no exception are raised but -inf or nan values are assigned.
- Return type:
- loopIn()
Generator to iterate inside a Tensor.
Yield an pyagrum.Instantiation that iterates over all the possible values for the pyagrum.Tensor
Examples
>>> import pyagrum as gum >>> bn=pyagrum.fastBN("A[3]->B[3]<-C[3]") >>> for i in bn.cpt("B").loopIn(): print(i) print(bn.cpt("B").get(i)) bn.cpt("B").set(i,0.3)
- max()
- Returns:
the maximum of all elements in the Tensor
- Return type:
float
- maxIn(*args)
Projection using max as operation.
- Parameters:
varnames (set) – the set of vars to keep
- Returns:
the projected Tensor
- Return type:
- maxNonOne()
- Returns:
the maximum of non one elements in the Tensor
- Return type:
float
- Raises:
pyagrum.NotFound – If all value == 1.0
- maxOut(*args)
Projection using max as operation.
- Parameters:
varnames (set) – the set of vars to eliminate
- Returns:
the projected Tensor
- Return type:
- Raises:
pyagrum.InvalidArgument – If varnames contains only one variable that does not exist in the Tensor
- memoryFootprint()
get the size (in byte) of the Tensor representation in memory
- Returns:
the size in byte of the representation of the Tensor in memory.
- Return type:
int
- min()
- Returns:
the min of all elements in the Tensor
- Return type:
float
- minIn(*args)
Projection using min as operation.
- Parameters:
varnames (set) – the set of vars to keep
- Returns:
the projected Tensor
- Return type:
- minNonZero()
- Returns:
the min of non zero elements in the Tensor
- Return type:
float
- Raises:
pyagrum.NotFound – If all value == 0.0
- minOut(*args)
Projection using min as operation.
- Parameters:
varnames (set) – the set of vars to eliminate
- Returns:
the projected Tensor
- Return type:
Warning
InvalidArgument raised if varnames contains only one variable that does not exist in the Tensor
- property names
- Returns:
a list containing the name of each variables in the tensor
- Return type:
list
Warning
listed in the reverse order of the enumeration order of the variables.
- nbrDim(*args)
- Returns:
the number of vars in the multidimensional container.
- Return type:
int
- normalize()
Normalize the Tensor (do nothing if sum is 0)
- Returns:
a reference to the normalized Tensor
- Return type:
- normalizeAsCPT(varId=0)
Normalize the Tensor as a CPT
- Returns:
a reference to the normalized Tensor
- Return type:
- Raises:
pyagrum.FatalError – If some distribution sums to 0
- Parameters:
varId (
int)
- pos(v)
- Parameters:
v (pyagrum.DiscreteVariable) – The variable for which the index is returned.
- Return type:
int- Returns:
Returns the index of a variable.
- Raises:
pyagrum.NotFound – If v is not in this multidimensional matrix.
- prodIn(*args)
Projection using multiplication as operation.
- Parameters:
varnames (set) – the set of vars to keep
- Returns:
the projected Tensor
- Return type:
- prodOut(*args)
Projection using multiplication as operation.
- Parameters:
varnames (set) – the set of vars to eliminate
- Returns:
the projected Tensor
- Return type:
- Raises:
pyagrum.InvalidArgument – If varnames contains only one variable that does not exist in the Tensor
- product()
- Returns:
the product of all elements in the Tensor
- Return type:
float
- putFirst(varname)
- Parameters:
v (pyagrum.DiscreteVariable) – The variable for which the index should be 0.
varname (
str)
- Returns:
a reference to the modified tensor
- Return type:
- Raises:
pyagrum.InvalidArgument – If the var is not in the tensor
- remove(var)
- Parameters:
v (pyagrum.DiscreteVariable) – The variable to be removed
- Returns:
a reference to the modified tensor
- Return type:
Warning
IndexError raised if the var is not in the tensor
- Parameters:
var (
DiscreteVariable)
- reorganize(*args)
Create a new Tensor with another order.
- Returns:
varnames – a list of the var names in the new order
- Return type:
list
- Returns:
a reference to the modified tensor
- Return type:
- scale(v)
Create a new tensor multiplied by v.
- Parameters:
v (float) – a multiplier
- Return type:
- Returns:
a reference to the modified tensor
- set(i, value)
Change the value pointed by i
- Parameters:
i (pyagrum.Instantiation) – The Instantiation to be changed
value (float) – The new value of the Instantiation
- Return type:
None
- property shape
- Returns:
a list containing the dimensions of each variables in the tensor
- Return type:
list
Warning
p.shape and p[:].shape list the dimensions in different order
- sum()
- Returns:
the sum of all elements in the Tensor
- Return type:
float
- sumIn(*args)
Projection using sum as operation.
- Parameters:
varnames (set) – the set of vars to keep
- Returns:
the projected Tensor
- Return type:
- sumOut(*args)
Projection using sum as operation.
- Parameters:
varnames (set) – the set of vars to eliminate
- Returns:
the projected Tensor
- Return type:
- Raises:
pyagrum.InvalidArgument – If varnames contains only one variable that does not exist in the Tensor
- property thisown
The membership flag
- toVarsIn(p)
Create a copy of the Tensor with the same variables as in p.
Warning
p is a pyAgrum’s object that can refer to variables through a method p.variable(name:str). For instance, a Potential, an Instantiation or a Graphical Model (Bayesian Network,…).
Examples
>>> import pyagrum as gum >>> bn1=pyagrum.fastBN('A[3]->B[3]<-C[3]') >>> bn2=pyagrum.fastBN('A[3]<-B[3]<-C[3]') >>> # bn1.cpt('A')+bn2.cpt('A') # does not work since the vars 'A' in bn1 and bn2 are not the same. >>> bn1.cpt('A').toVars(bn2)+bn2.cpt('A') # OK
- Returns:
- pyagrum.Tensor
a copy of the Potential with the same variables as p.
- toarray()
- Returns:
the tensor as an array
- Return type:
array
- toclipboard(**kwargs)
Write a text representation of object to the system clipboard. This can be pasted into spreadsheet, for instance.
- tolatex()
Render object to a LaTeX tabular.
Requires to include booktabs package in the LaTeX document.
- Returns:
the tensor as LaTeX string
- Return type:
str
- tolist()
- Returns:
the tensor as a list
- Return type:
list
- topandas()
- Returns:
the tensor as an pandas.DataFrame
- Return type:
pandas.DataFrame
- translate(v)
Create a new tensor added with v.
- Parameters:
v (float) – The value to be added
- Return type:
- Returns:
a reference to the modified tensor
- static uniformTensor(var)
- Parameters:
var (
DiscreteVariable)- Return type:
- variable(*args)
- Parameters:
i (int) – An index of this multidimensional matrix.
- Return type:
- Returns:
the varible at the ith index
- Raises:
pyagrum.NotFound – If i does not reference a variable in this multidimensional matrix.
- variablesSequence()
- Returns:
a list containing the sequence of variables
- Return type:
list