Class DirichletBayesIm
- All Implemented Interfaces:
- BayesIm,- Simulator,- VariableSource,- Im,- TetradSerializable,- Serializable
Stores Dirichlet pseudocounts for the distributions of each variable conditional on particular combinations of its parent values and, together with Bayes Pm and Dag, provides methods to manipulate these tables. The division of labor is as follows. The Dag is responsible for manipulating the basic graphical structure of the Dirichlet Bayes net. Dag also stores and manipulates the names of the nodes in the graph; there are no method in either BayesPm or DiriculetBayesIm to do this. BayesPm stores and manipulates the *values* of each node in a DAG, considered as a variable in a Bayes net. The number of values for a variable can be changed there as well as the names for those values. This class, DirichletBayesIm, stores the actual tables of parameter pseudocounts whose structures are implied by the structures in the other two classes. The implied parameters take the form of conditional probabilities--e.g., P(V=v0|P1=v1, P2=v2, ...), for all nodes and all combinations of their parent values. The set of all such probabilities is organized in this class as a three-dimensional table of double values. The first dimension corresponds to the nodes in the DAG. For each such node, the second dimension corresponds to a flat list of combinations of parent values for that node. The third dimension corresponds to the list of pseudocounts for each node/row combination. Two methods in this class allow these values to be set and retrieved:
- getPseudocount(int nodeIndex, int rowIndex, int colIndex); and,
- setPseudocount(int nodeIndex, int rowIndex, int colIndex, int pValue).
- getNodeIndex(Node node).
- getRowIndex(int[] parentVals).
- getParents(int nodeIndex)
- getCategoryIndex(Node node)
Thanks to Bill Taysom for an earlier version.
- Author:
- josephramsey
- See Also:
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionstatic DirichletBayesImblankDirichletIm(BayesPm bayesPm) voidclearRow(int nodeIndex, int rowIndex) Assigns random probability values to the child values of this row that add to 1.voidclearTable(int nodeIndex) Randomizes every row in the table for the given node index.booleanintgetCorrespondingNodeIndex(int nodeIndex, BayesIm otherBayesIm) getDag()getNode(int nodeIndex) intgetNodeIndex(Node node) intgetNumColumns(int nodeIndex) intintgetNumParents(int nodeIndex) intgetNumRows(int nodeIndex) intgetParent(int nodeIndex, int parentIndex) intgetParentDim(int nodeIndex, int parentIndex) int[]getParentDims(int nodeIndex) int[]getParents(int nodeIndex) intgetParentValue(int nodeIndex, int rowIndex, int colIndex) int[]getParentValues(int nodeIndex, int rowIndex) doublegetProbability(int nodeIndex, int rowIndex, int colIndex) doublegetPseudocount(int nodeIndex, int rowIndex, int colIndex) intgetRowIndex(int nodeIndex, int[] values) doublegetRowPseudocount(int nodeIndex, int rowIndex) booleanisIncomplete(int nodeIndex) booleanisIncomplete(int nodeIndex, int rowIndex) voidNormalizes all rows in the tables associated with each of node in turn.voidnormalizeNode(int nodeIndex) Normalizes all rows in the table associated with a given node.voidnormalizeRow(int nodeIndex, int rowIndex) Normalizes the given row.voidrandomizeIncompleteRows(int nodeIndex) Randomizes any row in the table for the given node index that has a Double.NaN value in it.voidrandomizeRow(int nodeIndex, int rowIndex) Assigns random probability values to the child values of this row that add to 1.voidrandomizeTable(int nodeIndex) Randomizes every row in the table for the given node index.static DirichletBayesImGenerates a simple exemplar of this class to test serialization.voidsetProbability(int nodeIndex, double[][] probMatrix) Sets the probability for the given node.voidsetProbability(int nodeIndex, int rowIndex, int colIndex, double value) Sets the probability for the given node at a given row and column in the table for that node.voidsetPseudocount(int nodeIndex, int rowIndex, int colIndex, double pseudocount) simulateData(int sampleSize, boolean latentDataSaved) Simulates and returns a dataset with number of cases equal tosampleSize.simulateData(DataSet dataSet, boolean latentDataSaved) Would be nice to have this method supported, but no one's using it, so it's not.static DirichletBayesImsymmetricDirichletIm(BayesPm bayesPm, double symmetricAlpha) toString()Prints out the probability table for each variable.
- 
Constructor Details- 
DirichletBayesImCopy constructor.- Throws:
- IllegalArgumentException
 
 
- 
- 
Method Details- 
blankDirichletIm
- 
symmetricDirichletIm
- 
serializableInstanceGenerates a simple exemplar of this class to test serialization.
- 
getBayesPm- Specified by:
- getBayesPmin interface- BayesIm
- Returns:
- this PM.
 
- 
getCorrespondingNodeIndex- Specified by:
- getCorrespondingNodeIndexin interface- BayesIm
- Returns:
- the index of the node with the given name in the specified DirichletBayesIm.
 
- 
getDag
- 
getNode
- 
getNode
- 
getNodeIndex- Specified by:
- getNodeIndexin interface- BayesIm
- Parameters:
- node- the given node.
- Returns:
- the index for that node, or -1 if the node is not in the DirichletBayesIm.
 
- 
getNumColumnspublic int getNumColumns(int nodeIndex) - Specified by:
- getNumColumnsin interface- BayesIm
- Returns:
- this number.
- See Also:
 
- 
getNumNodespublic int getNumNodes()- Specified by:
- getNumNodesin interface- BayesIm
- Returns:
- the number of nodes in the model.
 
- 
getNumParentspublic int getNumParents(int nodeIndex) - Specified by:
- getNumParentsin interface- BayesIm
- Parameters:
- nodeIndex- the given node.
- Returns:
- the number of parents for this node.
 
- 
getNumRowspublic int getNumRows(int nodeIndex) - Specified by:
- getNumRowsin interface- BayesIm
- Returns:
- this number.
- See Also:
 
- 
getParentpublic int getParent(int nodeIndex, int parentIndex) 
- 
getParentDimpublic int getParentDim(int nodeIndex, int parentIndex) - Specified by:
- getParentDimin interface- BayesIm
- Returns:
- the dimension of the given parent for the given node.
 
- 
getParentDimspublic int[] getParentDims(int nodeIndex) - Specified by:
- getParentDimsin interface- BayesIm
- Returns:
- this array of parent dimensions.
- See Also:
 
- 
getParentspublic int[] getParents(int nodeIndex) - Specified by:
- getParentsin interface- BayesIm
- Returns:
- (a defensive copy of) the array containing all of the parents of a given node in the order in which they are stored internally.
- See Also:
 
- 
getParentValuepublic int getParentValue(int nodeIndex, int rowIndex, int colIndex) - Specified by:
- getParentValuein interface- BayesIm
- Returns:
- the value in the probability table for the given node, at the given row and column.
 
- 
getParentValuespublic int[] getParentValues(int nodeIndex, int rowIndex) - Specified by:
- getParentValuesin interface- BayesIm
- Parameters:
- nodeIndex- the index of the node.
- rowIndex- the index of the row in question.
- Returns:
- the array representing the combination of parent values for this row.
- See Also:
 
- 
getProbabilitypublic double getProbability(int nodeIndex, int rowIndex, int colIndex) - Specified by:
- getProbabilityin interface- BayesIm
- Parameters:
- nodeIndex- the index of the node in question.
- rowIndex- the row in the table for this for node which represents the combination of parent values in question.
- colIndex- the column in the table for this node which represents the value of the node in question.
- Returns:
- the probability stored for this parameter.
- See Also:
 
- 
getPseudocountpublic double getPseudocount(int nodeIndex, int rowIndex, int colIndex) 
- 
getRowIndexpublic int getRowIndex(int nodeIndex, int[] values) - Specified by:
- getRowIndexin interface- BayesIm
- Returns:
- the row in the table for the given node and combination of parent values.
- See Also:
 
- 
getRowPseudocountpublic double getRowPseudocount(int nodeIndex, int rowIndex) 
- 
getVariableNames- Specified by:
- getVariableNamesin interface- BayesIm
- Specified by:
- getVariableNamesin interface- VariableSource
- Returns:
- the list of variable names for this Bayes net.
 
- 
getMeasuredNodes- Specified by:
- getMeasuredNodesin interface- BayesIm
- Returns:
- the list of measured variableNodes.
 
- 
getVariables- Specified by:
- getVariablesin interface- BayesIm
- Specified by:
- getVariablesin interface- VariableSource
- Returns:
- the list of variable for this Bayes net.
 
- 
isIncompletepublic boolean isIncomplete(int nodeIndex) - Specified by:
- isIncompletein interface- BayesIm
- Returns:
- true iff any value in the table for the given node is Double.NaN.
 
- 
isIncompletepublic boolean isIncomplete(int nodeIndex, int rowIndex) - Specified by:
- isIncompletein interface- BayesIm
- Returns:
- true iff one of the values in the given row is Double.NaN.
 
- 
normalizeAllpublic void normalizeAll()Normalizes all rows in the tables associated with each of node in turn.- Specified by:
- normalizeAllin interface- BayesIm
 
- 
normalizeNodepublic void normalizeNode(int nodeIndex) Normalizes all rows in the table associated with a given node.- Specified by:
- normalizeNodein interface- BayesIm
 
- 
normalizeRowpublic void normalizeRow(int nodeIndex, int rowIndex) Normalizes the given row.- Specified by:
- normalizeRowin interface- BayesIm
 
- 
randomizeIncompleteRowspublic void randomizeIncompleteRows(int nodeIndex) Randomizes any row in the table for the given node index that has a Double.NaN value in it.- Specified by:
- randomizeIncompleteRowsin interface- BayesIm
- Parameters:
- nodeIndex- the node for the table whose incomplete rows are to be randomized.
 
- 
randomizeRowpublic void randomizeRow(int nodeIndex, int rowIndex) Assigns random probability values to the child values of this row that add to 1.- Specified by:
- randomizeRowin interface- BayesIm
- Parameters:
- nodeIndex- the node for the table that this row belongs to.
- rowIndex- the index of the row.
 
- 
randomizeTablepublic void randomizeTable(int nodeIndex) Randomizes every row in the table for the given node index.- Specified by:
- randomizeTablein interface- BayesIm
- Parameters:
- nodeIndex- the node for the table to be randomized.
 
- 
setProbabilitypublic void setProbability(int nodeIndex, double[][] probMatrix) Sets the probability for the given node. The matrix row represent row index, the row in the table for this for node which represents the combination of parent values in question. of the CPT. The matrix column represent column index, the column in the table for this node which represents the value of the node in question.- Specified by:
- setProbabilityin interface- BayesIm
- Parameters:
- nodeIndex- the index of the node in question.
- probMatrix- a matrix containing probabilities of a node along with its parents
 
- 
setProbabilitypublic void setProbability(int nodeIndex, int rowIndex, int colIndex, double value) Sets the probability for the given node at a given row and column in the table for that node. To get the node index, use getNodeIndex(). To get the row index, use getRowIndex(). To get the column index, use getCategoryIndex() from the underlying BayesPm(). The value returned will represent a conditional probability of the form P(N=v0 | P1=v1, P2=v2, ... , Pn=vn), where N is the node referenced by nodeIndex, v0 is the value referenced by colIndex, and the combination of parent values indicated is the combination indicated by rowIndex.- Specified by:
- setProbabilityin interface- BayesIm
- Parameters:
- nodeIndex- the index of the node in question.
- rowIndex- the row in the table for this for node which represents the combination of parent values in question.
- colIndex- the column in the table for this node which represents the value of the node in question.
- value- the desired probability to be set.
- See Also:
 
- 
setPseudocountpublic void setPseudocount(int nodeIndex, int rowIndex, int colIndex, double pseudocount) 
- 
simulateDataSimulates and returns a dataset with number of cases equal tosampleSize. iflatentDataSavedis true, data for latent variables is included in the simulated dataset.- Specified by:
- simulateDatain interface- BayesIm
- Specified by:
- simulateDatain interface- Simulator
- Parameters:
- sampleSize- the sample size.
- Returns:
- the simulated sample as a DataSet.
 
- 
simulateDataWould be nice to have this method supported, but no one's using it, so it's not.- Specified by:
- simulateDatain interface- BayesIm
- Returns:
- the simulated sample as a DataSet.
- Throws:
- UnsupportedOperationException- If you ever try to getDist it.
 
- 
clearRowpublic void clearRow(int nodeIndex, int rowIndex) Assigns random probability values to the child values of this row that add to 1.
- 
clearTablepublic void clearTable(int nodeIndex) Randomizes every row in the table for the given node index.- Specified by:
- clearTablein interface- BayesIm
- Parameters:
- nodeIndex- the node for the table to be randomized.
 
- 
equals
- 
toStringPrints out the probability table for each variable.
 
-