Class SessionNode
- All Implemented Interfaces:
- Node,- TetradSerializable,- Serializable,- Comparable<Node>
Represents a node in a session for a model in a particular class. The sets of possible model classes for this node are given in the constructors of the model classes for the node. Parents (also SessionNodes) may be added to this node provided some combination of the parents' model classes serves a partial argument set to some constructor of the one of this node's model classes. To put it slightly differently, parents can be added to this node one at a time, though at any step along the way it ought to be possible (perhaps by adding more parent nodes) to use the parent models to construct a model of one of the legal types for this node.> 0
 To retrieve the list of classes for which models may be created, call the getConsistentModelClasses
 . To construct a model for a particular model choice, call
 createModel method for the desired class. If the model has a
 parameterizing object, this object may be passed in using the
 createParameterizedModel method. For parameterized models, the
 model object is treated simply as an additional parent to the model and therefore must appear as an argument to one
 of the constructors of the model.> 0
 
This node keeps track of its parents and its children and keeps these two sets of SessionNodes in sync.> 0
- Author:
- josephramsey
- See Also:
- 
Field Summary
- 
Constructor SummaryConstructorsConstructorDescriptionSessionNode(Class modelClass) Creates a new session node capable of implementing the given model class.SessionNode(Class[] modelClasses) Creates a new session node with the given name capable of implementing the given model classes.SessionNode(String boxType, String displayName, Class modelClass) Creates a new session node with the given name, capable of implementing the given model class.SessionNode(String boxType, String displayName, Class[] modelClasses) Creates a new session node with the given name capable of implementing the given model classes.
- 
Method SummaryModifier and TypeMethodDescriptionvoidaddAttribute(String key, Object value) booleanaddChild(SessionNode child) Adds a child to the node, provided this node can be added as a parent to the child node.booleanaddParent(SessionNode parent) Adds a parent to this node provided the resulting set of parents taken together provides some combination of possible model classes that can be used as a constructor to some one of the model classes for this node.booleanaddParent2(SessionNode parent) Same as addParent except tests if this has already been created.voidAdds a property change listener.voidAdds a session listener.booleanassignClasses(Class[] constructorTypes, Class[] modelTypes, boolean exact, List<SessionNode> existingNodes) Object[]assignParameters(Class[] parameterTypes, List objects) Returns the objects in the List as an array in the same order as the parameter types.intReturns the hashcode for this node.booleancontainsChild(SessionNode child) booleancreateModel(boolean simulation) Creates a model, provided the class of the model can be uniquely determined without any further hints.voidcreateModel(Class modelClass, boolean simulation) Creates a model of the given class using models of the parent SessionNodes as constructor arguments.voidSets the model to null.booleanexistsConstructor(Class modelClass, Class[] argumentTypes) Tests whether the model class has an argument that takes all of the given argument classes (or more) as arguments.booleanexistsParameterizedConstructor(Class modelClass) voidForgets the old model so that it can't be used to recapture parameter values.voidgetAssignableClass(List classes, Class clazz) Returns the first class c inclassesthatclazzis assignable to.> 0getAttribute(String key) Gets the (optional) name of this node.intReturns the x coordinate of the center of this node.intReturns the y coordinate of the center of this node.Class[]getConsistentModelClasses(boolean exact) getLoggerConfig(Class modelClass) getModel()Class[]Object[]getModelConstructorArguments(Class modelClass) getName()Returns the name of this node.Returns the node type for this node.Returns the node shape for this node.intintGets the parameter object for the givem model class.intgetProduct(int[] arr) intint[]getValueCombination(int index, int[] numValues) booleanisConsistentModelClass(Class<Type1> modelClass, List nodes, boolean exact) Determines whether a given model class is consistent with the models contained in the given List of nodes, in the sense that the model class has a constructor that can take the models of the nodes as arguments.booleanisConsistentParent(SessionNode parent) booleanisConsistentParent(SessionNode parent, List<SessionNode> existingNodes) booleanbooleanTests whether two session nodes that are not necessarily object identical are nevertheless identical in structure.Creates a new node of the same type as this one with the given name.voidputParam(Class modelClass, Parameters param) Sets the parameter object for the given model class to the given object.voidremoveAttribute(String key) booleanremoveChild(SessionNode child) Removes a child from the node.voidremoveParam(Class modelClass) Removes the parameter object for the given model class.booleanremoveParent(SessionNode parent) Removes a parent from the node.voidRemoves a session listener.voidResets this sesion node to the state it was in when first constructed.voidvoidrestrictConnectionsToList(List sessionNodes) Removes any parents or children of the node that are not in the given list.voidRemoves any listeners that are not SessionNodes.static SessionNodeGenerates a simple exemplar of this class to test serialization.final voidsetBoxType(String boxType) Sets the (optional) name for this node.voidsetCenter(int centerX, int centerY) Sets the (x, y) coordinates of the center of this node.voidsetCenterX(int centerX) Sets the x coordinate of the center of this node.voidsetCenterY(int centerY) Sets the y coordinate of the center of this node.final voidsetDisplayName(String displayName) final voidsetModelClasses(Class[] modelClasses) Sets the model classes to the new array of model classes.voidSets the name of this node.voidsetNextEdgeAddAllowed(boolean nextEdgeAddAllowed) True iff the next edge should not be added.voidsetNodeType(NodeType nodeType) Sets the node type for this node.voidsetNodeVariableType(NodeVariableType nodeVariableType) Sets the type (domain, interventional status, interventional value..) for this node variablevoidsetRepetition(int repetition) toString()Prints out the name of the session node.boolean
- 
Constructor Details- 
SessionNodeCreates a new session node capable of implementing the given model class.
- 
SessionNodeCreates a new session node with the given name, capable of implementing the given model class.- Parameters:
- boxType- The name of the box type--for instance, "Graph."
- displayName- The name of this particular session node. Any non-null string.
- modelClass- A single model class associated with this session node.
 
- 
SessionNodeCreates a new session node with the given name capable of implementing the given model classes.
- 
SessionNodeCreates a new session node with the given name capable of implementing the given model classes. When models are created, they will be of one of these classes. Reflection will be used to create the models by matching the models of the parent Session Nodes to constructor arguments of the class given as argument to thecreateModelmethod, which must itself be one of these model classes.- Parameters:
- boxType- The name of the box type--for instance, "Graph."
- displayName- The name of this particular session node. Any non-null string.
- modelClasses- An array of model classes associated with this session node.
 
 
- 
- 
Method Details- 
serializableInstanceGenerates a simple exemplar of this class to test serialization.
- 
addParentAdds a parent to this node provided the resulting set of parents taken together provides some combination of possible model classes that can be used as a constructor to some one of the model classes for this node.
- 
isConsistentParent
- 
isConsistentParent
- 
addParent2Same as addParent except tests if this has already been created. If so the user is asked whether to add parent and update parent's desendents or to cancel the operation.
- 
removeParentRemoves a parent from the node.
- 
getParents- Returns:
- the set of parents.
 
- 
getNumParentspublic int getNumParents()- Returns:
- the number of parents.
 
- 
addChildAdds a child to the node, provided this node can be added as a parent to the child node.
- 
containsChild- Returns:
- true iff the given node is child of this node.
 
- 
removeChildRemoves a child from the node.
- 
getChildren- Returns:
- the set of children.
 
- 
getNumChildrenpublic int getNumChildren()- Returns:
- the number of children.
 
- 
createModelpublic boolean createModel(boolean simulation) Creates a model, provided the class of the model can be uniquely determined without any further hints. If a model was created previously, the previous model class is used. If there is only one consistent model class, than that model class is used. Otherwise, an exception is thrown.- Returns:
- true iff this node contains a model when this method completes.
- Throws:
- RuntimeException- if the model could not be created.
 
- 
createModelCreates a model of the given class using models of the parent SessionNodes as constructor arguments. If no appropriate constructor is available, no model is created, and the method returns false. If the attempt to construct a model using reflection fails, the stack trace is printed to System.err and an IllegalArgumentException is thrown. t- Throws:
- RuntimeException- if the attempt to construct the model throws either an IllegalAccessException, an InstantiationException, or an InvocationTargetException. In this case, a stack trace is printed to System.err.
- Exception
 
- 
getLoggerConfig
- 
getLoggerConfig
- 
destroyModelpublic void destroyModel()Sets the model to null. This step must be performed before a new model can be created.
- 
forgetOldModelpublic void forgetOldModel()Forgets the old model so that it can't be used to recapture parameter values.
- 
getModelClasses- Returns:
- the class of the model.
 
- 
setModelClassesSets the model classes to the new array of model classes.
- 
getConsistentModelClasses- Parameters:
- exact-
- Returns:
- those model classes among the possible model classes that are at least consistent with the model class of the parent session nodes, in the sense that possibly with the addition of more parent session nodes, and assuming that the models of the parent session nodes are non-null, it is possible to construct a model in one of the legal classes for this node using the parent models as arguments to some constructor in that class.
 
- 
getModel- Returns:
- the model, or null if no model has been created yet.
 
- 
getLastModelClass- Returns:
- the class of the last model that was created, or null if no model has been created yet.
 
- 
addSessionListenerAdds a session listener.
- 
removeSessionListenerRemoves a session listener.
- 
isFreshlyCreatedpublic boolean isFreshlyCreated()- Returns:
- true iff this node is in a freshly created state. A node that is in a freshly created state has no model, no parents, no children, and no listeners. It does, however, have the array of possible model classes that it was constructed with, and it may or may not have a name.
 
- 
resetToFreshlyCreatedpublic void resetToFreshlyCreated()Resets this sesion node to the state it was in when first constructed. Removes any parents or children, destroys the model if there is one, and resets all listeners. Fires an event for each action taken.
- 
restrictConnectionsToListRemoves any parents or children of the node that are not in the given list.
- 
restrictListenersToSessionNodespublic void restrictListenersToSessionNodes()Removes any listeners that are not SessionNodes.
- 
isStructurallyIdenticalTests whether two session nodes that are not necessarily object identical are nevertheless identical in structure. This method should not be made to override equalssinceequalsis used in the Collections API to determine, for example, containment in an ArrayList, and the sense of equality needed for that is object identity. Nevertheless, for certain other purposes, such as checking serialization, a looser sense of structural identity is helpful.> 0Two SessionNodes are structurally identical just in case their possible model classes are equal, the parameter type arrays used to construct their models are equal, their models themselves are equal, and the model classes of the parent and child SessionNodes are equal. We dare not check equality of parents and children outright for fear of circularity.> 0 
- 
getBoxTypeGets the (optional) name of this node. May be null.
- 
setBoxTypeSets the (optional) name for this node. May be null.
- 
putParamSets the parameter object for the given model class to the given object.
- 
getParamGets the parameter object for the givem model class.
- 
removeParamRemoves the parameter object for the given model class.
- 
getModelConstructorArguments
- 
getNameDescription copied from interface:NodeReturns the name of this node.
- 
setNameDescription copied from interface:NodeSets the name of this node.
- 
getNodeTypeDescription copied from interface:NodeReturns the node type for this node.- Specified by:
- getNodeTypein interface- Node
- Returns:
- the node type for this node.
 
- 
setNodeTypeDescription copied from interface:NodeSets the node type for this node.- Specified by:
- setNodeTypein interface- Node
- Parameters:
- nodeType- the node type for this node.
 
- 
toStringPrints out the name of the session node.
- 
getCenterXpublic int getCenterX()Description copied from interface:NodeReturns the x coordinate of the center of this node.- Specified by:
- getCenterXin interface- Node
- Returns:
- the x coordinate of the center of the node.
 
- 
setCenterXpublic void setCenterX(int centerX) Description copied from interface:NodeSets the x coordinate of the center of this node.- Specified by:
- setCenterXin interface- Node
- Parameters:
- centerX- This coordinate.
 
- 
getCenterYpublic int getCenterY()Description copied from interface:NodeReturns the y coordinate of the center of this node.- Specified by:
- getCenterYin interface- Node
- Returns:
- the y coordinate of the center of the node.
 
- 
setCenterYpublic void setCenterY(int centerY) Description copied from interface:NodeSets the y coordinate of the center of this node.- Specified by:
- setCenterYin interface- Node
- Parameters:
- centerY- This coordinate.
 
- 
setCenterpublic void setCenter(int centerX, int centerY) Description copied from interface:NodeSets the (x, y) coordinates of the center of this node.
- 
addPropertyChangeListenerDescription copied from interface:NodeAdds a property change listener.- Specified by:
- addPropertyChangeListenerin interface- Node
- Parameters:
- l- This listener.
 
- 
likeDescription copied from interface:NodeCreates a new node of the same type as this one with the given name.
- 
compareToDescription copied from interface:NodeReturns the hashcode for this node.- Specified by:
- compareToin interface- Comparable<Node>
- Specified by:
- compareToin interface- Node
- Parameters:
- node- the object to be compared.
- Returns:
- the hashcode for this node.
 
- 
existsParameterizedConstructor
- 
getRepetitionpublic int getRepetition()
- 
setRepetitionpublic void setRepetition(int repetition) 
- 
useClonedModelpublic boolean useClonedModel()- Returns:
- true if the cloning operation was successful, false if not. If the cloning operation was not successful, the model will not have been altered.
 
- 
forgetSavedModelpublic void forgetSavedModel()
- 
restoreOriginalModelpublic void restoreOriginalModel()
- 
isConsistentModelClassDetermines whether a given model class is consistent with the models contained in the given List of nodes, in the sense that the model class has a constructor that can take the models of the nodes as arguments.
- 
existsConstructorTests whether the model class has an argument that takes all of the given argument classes (or more) as arguments. The purpose of this is to allow parent nodes to be added one at a time to this node, whether or not any of the nodes in question have non-null models.> 0 
- 
getAssignableClassReturns the first class c in classesthatclazzis assignable to.> 0
- 
assignParametersReturns the objects in the List as an array in the same order as the parameter types. If an exact match cannot be found, throws a RuntimeException with an appropriate message. - Parameters:
- parameterTypes- a list of classes; if any of them is null, a NullPointerException will be thrown.
- objects- a List of objects. (The nulls will be automatically thrown out for this one.)
- Throws:
- RuntimeException
 
- 
assignClassespublic boolean assignClasses(Class[] constructorTypes, Class[] modelTypes, boolean exact, List<SessionNode> existingNodes) throws RuntimeException - Throws:
- RuntimeException
 
- 
getValueCombinationpublic int[] getValueCombination(int index, int[] numValues) - Returns:
- an array with a combination of particular values for variables given an array indicating the number of values for each variable.
 
- 
getProductpublic int getProduct(int[] arr) - Returns:
- the product of the entries in the given array.
 
- 
setNextEdgeAddAllowedpublic void setNextEdgeAddAllowed(boolean nextEdgeAddAllowed) True iff the next edge should not be added. (Included for GUI user control.) Reset to true every time an edge is added; edge adds must be disallowed individually. To disallow the next edge add, set to false.
- 
getDisplayName
- 
setDisplayName
- 
getParameters
- 
getNodeVariableTypeDescription copied from interface:NodeReturns the node shape for this node.- Specified by:
- getNodeVariableTypein interface- Node
- Returns:
- the intervention type
 
- 
setNodeVariableTypeDescription copied from interface:NodeSets the type (domain, interventional status, interventional value..) for this node variable- Specified by:
- setNodeVariableTypein interface- Node
- Parameters:
- nodeVariableType- the type (domain, interventional status, interventional value..) for this node variable
 
- 
getAllAttributes- Specified by:
- getAllAttributesin interface- Node
 
- 
getAttribute- Specified by:
- getAttributein interface- Node
 
- 
removeAttribute- Specified by:
- removeAttributein interface- Node
 
- 
addAttribute- Specified by:
- addAttributein interface- Node
 
 
-