Package edu.cmu.tetrad.search.utils
Class PossibleMsepFci
java.lang.Object
edu.cmu.tetrad.search.utils.PossibleMsepFci
Implements the Possible-M-Sep search step of Spirtes, et al's (1993) FCI algorithm (pp 144-145). Specifically, the
 methods in this class perform step D. of the algorithm. The algorithm implemented by this class is a bit broader,
 however, because it allows for the possibility that some pairs of variables have already been compared by a different
 algorithm. Specifically, if the 
prevCheck variable is provided in the constructor, then the algorithm
 pairwise checks every variable in the graph with every variable in v \
 prevCheck (that is, the unchecked variables). This feature is used by the CIVI algorithm of Danks's
 "Efficient Inclusion of Novel Variables."- Version:
- $Id: $Id
- Author:
- David Danks
- 
Constructor SummaryConstructorsConstructorDescriptionPossibleMsepFci(Graph graph, IndependenceTest test) Creates a new SepSet and assumes that none of the variables have yet been checked.
- 
Method SummaryModifier and TypeMethodDescriptionintgetDepth()Getter for the fielddepth.Getter for the fieldknowledge.getSepset(IndependenceTest test, Node node1, Node node2) Getter for the fieldsepset.search()Performs pairwise comparisons of each variable in the graph with the variables that have not already been checked.voidsetDepth(int depth) Setter for the fielddepth.voidsetKnowledge(Knowledge knowledge) Setter for the fieldknowledge.voidsetMaxReachablePathLength(int maxReachablePathLength) Sets the maximum reachable path length for the search algorithm.
- 
Constructor Details- 
PossibleMsepFciCreates a new SepSet and assumes that none of the variables have yet been checked.- Parameters:
- graph- The GaSearchGraph on which to work
- test- The IndependenceChecker to use as an oracle
 
 
- 
- 
Method Details- 
searchPerforms pairwise comparisons of each variable in the graph with the variables that have not already been checked. We get the Possible-M-Sep sets for the pair of variables, and we check to see if they are independent conditional on some subset of the union of Possible-M-Sep sets. This method returns the SepSet passed in the constructor (if any), possibly augmented by some edge removals in this step. The GaSearchGraph passed in the constructor is directly changed.- Returns:
- a SepsetMapobject
- Throws:
- InterruptedException
 
- 
getSepsetpublic Set<Node> getSepset(IndependenceTest test, Node node1, Node node2) throws InterruptedException Getter for the field sepset.- Parameters:
- test- a- IndependenceTestobject
- node1- a- Nodeobject
- node2- a- Nodeobject
- Returns:
- a Setobject
- Throws:
- InterruptedException
 
- 
getDepthpublic int getDepth()Getter for the field depth.- Returns:
- a int
 
- 
setDepthpublic void setDepth(int depth) Setter for the field depth.- Parameters:
- depth- a int
 
- 
getKnowledge
- 
setKnowledge
- 
setMaxReachablePathLengthpublic void setMaxReachablePathLength(int maxReachablePathLength) Sets the maximum reachable path length for the search algorithm.- Parameters:
- maxReachablePathLength- The maximum reachable path length. Must be -1 (unlimited) or >= 0.
- Throws:
- IllegalArgumentException- if maxReachablePathLength is less than -1.
 
 
-