Package edu.cmu.tetrad.search
Class Bridges
java.lang.Object
edu.cmu.tetrad.search.Bridges
- All Implemented Interfaces:
- GraphScorer,- GraphSearch
GesSearch is an implementation of the GES algorithm, as specified in
 Chickering (2002) "Optimal structure identification with greedy search"
 Journal of Machine Learning Research. It works for both BayesNets and SEMs.
 
Some code optimization could be done for the scoring part of the graph for discrete models (method scoreGraphChange). Some of Andrew Moore's approaches for caching sufficient statistics, for instance.
To speed things up, it has been assumed that variables X and Y with zero correlation do not correspond to edges in the graph. This is a restricted form of the heuristicSpeedup assumption, something GES does not assume. This the graph. This is a restricted form of the heuristicSpeedup assumption, something GES does not assume. This heuristicSpeedup assumption needs to be explicitly turned on using setHeuristicSpeedup(true).
A number of other optimizations were added 5/2015. See code for details.
- Author:
- Ricardo Silva, Summer 2003, Joseph Ramsey, Revisions 5/2015
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionlongintThe maximum of parents any nodes can have in output pattern.getNeighbors(Graph graph, Node node) getOut()doublesearch()Greedy equivalence search: Start from the empty graph, add edges till model is significant.voidsetAdjacencies(Graph adjacencies) Sets the set of preset adjacenies for the algorithm; edges not in this adjacencies graph will not be added.voidsetBoundGraph(Graph boundGraph) If non-null, edges not adjacent in this graph will not be added.voidsetDepth(int depth) voidsetFaithfulnessAssumed(boolean faithfulnessAssumed) voidsetKnowledge(Knowledge knowledge) Sets the background knowledge.voidsetMaxDegree(int maxDegree) The maximum of parents any nodes can have in output pattern.voidsetMeekVerbose(boolean meekVerbose) Sets whether verbose output should be produced.voidsetOut(PrintStream out) Sets the output stream that output (except for log output) should be sent to.voidsetParallelized(boolean parallelized) voidsetSymmetricFirstStep(boolean symmetricFirstStep) voidsetVerbose(boolean verbose) Sets whether verbose output should be produced.
- 
Constructor Details- 
BridgesConstruct a Score and pass it in here. The totalScore should return a positive value in case of conditional dependence and a negative values in case of conditional independence. See Chickering (2002), locally consistent scoring criterion. This by default uses all of the processors on the machine.
- 
Bridgespublic Bridges(int depth) 
 
- 
- 
Method Details- 
setFaithfulnessAssumedpublic void setFaithfulnessAssumed(boolean faithfulnessAssumed) 
- 
setDepthpublic void setDepth(int depth) 
- 
search- Specified by:
- searchin interface- GraphSearch
 
- 
search2Greedy equivalence search: Start from the empty graph, add edges till model is significant. Then start deleting edges till a minimum is achieved.- Returns:
- the resulting Pattern.
 
- 
getKnowledge- Returns:
- the background knowledge.
 
- 
setKnowledgeSets the background knowledge.- Parameters:
- knowledge- the knowledge object, specifying forbidden and required edges.
 
- 
getElapsedTimepublic long getElapsedTime()
- 
scoreDag- Specified by:
- scoreDagin interface- GraphScorer
- Returns:
- the totalScore of the given DAG, up to a constant.
 
- 
getTopGraphs- Returns:
- the list of top scoring graphs.
 
- 
setVerbosepublic void setVerbose(boolean verbose) Sets whether verbose output should be produced.
- 
setMeekVerbosepublic void setMeekVerbose(boolean meekVerbose) Sets whether verbose output should be produced.
- 
getOut- Returns:
- the output stream that output (except for log output) should be sent to.
 
- 
setOutSets the output stream that output (except for log output) should be sent to. By detault System.out.
- 
getAdjacencies- Returns:
- the set of preset adjacenies for the algorithm; edges not in this adjacencies graph will not be added.
 
- 
setAdjacenciesSets the set of preset adjacenies for the algorithm; edges not in this adjacencies graph will not be added.
- 
setBoundGraphIf non-null, edges not adjacent in this graph will not be added.
- 
getMaxDegreepublic int getMaxDegree()The maximum of parents any nodes can have in output pattern.- Returns:
- -1 for unlimited.
 
- 
setMaxDegreepublic void setMaxDegree(int maxDegree) The maximum of parents any nodes can have in output pattern.- Parameters:
- maxDegree- -1 for unlimited.
 
- 
setSymmetricFirstSteppublic void setSymmetricFirstStep(boolean symmetricFirstStep) 
- 
logEdgeBayesFactorsString
- 
getNeighbors
- 
setParallelizedpublic void setParallelized(boolean parallelized) 
 
-