Package edu.cmu.tetrad.search
Class Fges
java.lang.Object
edu.cmu.tetrad.search.Fges
- 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.getOut()doublesearch()Greedy equivalence search: Start from the empty graph, add edges till model is significant.voidsetBoundGraph(Graph boundGraph) If non-null, edges not adjacent in this graph will not be added.voidsetFaithfulnessAssumed(boolean faithfulnessAssumed) voidsetInitialGraph(Graph initialGraph) Sets the initial graph.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- 
FgesConstruct 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 the processors on the machine.
 
- 
- 
Method Details- 
setFaithfulnessAssumedpublic void setFaithfulnessAssumed(boolean faithfulnessAssumed) 
- 
searchGreedy equivalence search: Start from the empty graph, add edges till model is significant. Then start deleting edges till a minimum is achieved.- Specified by:
- searchin interface- GraphSearch
- 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.
 
- 
setInitialGraphSets the initial graph.
- 
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.
- 
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
- 
setParallelizedpublic void setParallelized(boolean parallelized) 
 
-