Search in sources :

Example 11 with RandomForward

use of edu.cmu.tetrad.algcomparison.graph.RandomForward in project tetrad by cmu-phil.

the class TestGenerateMixedData method test1.

public void test1() {
    Parameters parameters = new Parameters();
    parameters.set("numRuns", 100);
    parameters.set("numMeasures", 100);
    parameters.set("avgDegree", 4);
    parameters.set("sampleSize", 5000);
    parameters.set("maxDegree", 8);
    parameters.set("minCategories", 2);
    parameters.set("maxCategories", 5);
    parameters.set("percentDiscrete", 50);
    parameters.set("intervalBetweenRecordings", 20);
    parameters.set("varLow", 1.);
    parameters.set("varHigh", 3.);
    parameters.set("coefLow", .1);
    parameters.set("coefHigh", 1.5);
    parameters.set("coefSymmetric", true);
    parameters.set("meanLow", -1);
    parameters.set("meanHigh", 1);
    final LeeHastieSimulation simulation = new LeeHastieSimulation(new RandomForward());
    Comparison comparison = new Comparison();
    comparison.setShowAlgorithmIndices(true);
    comparison.setShowSimulationIndices(false);
    comparison.setSortByUtility(false);
    comparison.setShowUtilities(false);
    comparison.setParallelized(false);
    comparison.setSaveGraphs(true);
    comparison.setTabDelimitedTables(true);
    comparison.saveToFiles("mixed.lee.hastie.avg.degree.4", simulation, parameters);
}
Also used : Parameters(edu.cmu.tetrad.util.Parameters) LeeHastieSimulation(edu.cmu.tetrad.algcomparison.simulation.LeeHastieSimulation) Comparison(edu.cmu.tetrad.algcomparison.Comparison) RandomForward(edu.cmu.tetrad.algcomparison.graph.RandomForward)

Example 12 with RandomForward

use of edu.cmu.tetrad.algcomparison.graph.RandomForward in project tetrad by cmu-phil.

the class SimulationEditor method resetPanel.

private void resetPanel(Simulation simulation, String[] graphItems, String[] simulationItems, JTabbedPane tabbedPane) {
    RandomGraph randomGraph = (simulation.getSourceGraph() == null) ? new SingleGraph(new EdgeListGraph()) : new SingleGraph(simulation.getSourceGraph());
    if (!simulation.isFixedGraph()) {
        String graphItem = (String) graphsDropdown.getSelectedItem();
        simulation.getParams().set("graphsDropdownPreference", graphItem);
        if (graphItem.equals(graphItems[0])) {
            randomGraph = new RandomForward();
        } else if (graphItem.equals(graphItems[1])) {
            randomGraph = new ScaleFree();
        } else if (graphItem.equals(graphItems[2])) {
            randomGraph = new Cyclic();
        } else if (graphItem.equals(graphItems[3])) {
            randomGraph = new RandomSingleFactorMim();
        } else if (graphItem.equals(graphItems[4])) {
            randomGraph = new RandomTwoFactorMim();
        } else {
            throw new IllegalArgumentException("Unrecognized simulation type: " + graphItem);
        }
    }
    if (!simulation.isFixedSimulation()) {
        if (simulation.getSourceGraph() == null) {
            String simulationItem = (String) simulationsDropdown.getSelectedItem();
            simulation.getParams().set("simulationsDropdownPreference", simulationItem);
            simulation.setFixedGraph(false);
            if (randomGraph instanceof SingleGraph) {
                simulation.setFixedGraph(true);
            }
            if (simulationItem.equals(simulationItems[0])) {
                simulation.setSimulation(new BayesNetSimulation(randomGraph), simulation.getParams());
            } else if (simulationItem.equals(simulationItems[1])) {
                simulation.setSimulation(new SemSimulation(randomGraph), simulation.getParams());
            } else if (simulationItem.equals(simulationItems[2])) {
                simulation.setSimulation(new LinearFisherModel(randomGraph, simulation.getInputDataModelList()), simulation.getParams());
            } else if (simulationItem.equals(simulationItems[3])) {
                simulation.setSimulation(new LeeHastieSimulation(randomGraph), simulation.getParams());
            } else if (simulationItem.equals(simulationItems[4])) {
                simulation.setSimulation(new ConditionalGaussianSimulation(randomGraph), simulation.getParams());
            } else if (simulationItem.equals(simulationItems[5])) {
                simulation.setSimulation(new TimeSeriesSemSimulation(randomGraph), simulation.getParams());
            } else {
                throw new IllegalArgumentException("Unrecognized simulation type: " + simulationItem);
            }
        } else {
            String simulationItem = (String) simulationsDropdown.getSelectedItem();
            simulation.getParams().set("simulationsDropdownPreference", simulationItem);
            simulation.setFixedGraph(false);
            if (randomGraph instanceof SingleGraph) {
                simulation.setFixedGraph(true);
            }
            if (simulationItem.equals(simulationItems[0])) {
                simulation.setSimulation(new BayesNetSimulation(randomGraph), simulation.getParams());
            } else if (simulationItem.equals(simulationItems[1])) {
                simulation.setSimulation(new SemSimulation(randomGraph), simulation.getParams());
            } else if (simulationItem.equals(simulationItems[2])) {
                simulation.setSimulation(new LinearFisherModel(randomGraph), simulation.getParams());
            } else if (simulationItem.equals(simulationItems[3])) {
                simulation.setSimulation(new LeeHastieSimulation(randomGraph), simulation.getParams());
            } else if (simulationItem.equals(simulationItems[4])) {
                simulation.setSimulation(new ConditionalGaussianSimulation(randomGraph), simulation.getParams());
            } else if (simulationItem.equals(simulationItems[5])) {
                simulation.setSimulation(new TimeSeriesSemSimulation(randomGraph), simulation.getParams());
            } else {
                throw new IllegalArgumentException("Unrecognized simulation type: " + simulationItem);
            }
        }
    }
    tabbedPane.setComponentAt(0, new PaddingPanel(getParameterPanel(simulation, simulation.getSimulation(), simulation.getParams())));
}
Also used : LinearFisherModel(edu.cmu.tetrad.algcomparison.simulation.LinearFisherModel) RandomSingleFactorMim(edu.cmu.tetrad.algcomparison.graph.RandomSingleFactorMim) TimeSeriesSemSimulation(edu.cmu.tetrad.algcomparison.simulation.TimeSeriesSemSimulation) GeneralSemSimulation(edu.cmu.tetrad.algcomparison.simulation.GeneralSemSimulation) SemSimulation(edu.cmu.tetrad.algcomparison.simulation.SemSimulation) StandardizedSemSimulation(edu.cmu.tetrad.algcomparison.simulation.StandardizedSemSimulation) RandomForward(edu.cmu.tetrad.algcomparison.graph.RandomForward) EdgeListGraph(edu.cmu.tetrad.graph.EdgeListGraph) BayesNetSimulation(edu.cmu.tetrad.algcomparison.simulation.BayesNetSimulation) ScaleFree(edu.cmu.tetrad.algcomparison.graph.ScaleFree) TimeSeriesSemSimulation(edu.cmu.tetrad.algcomparison.simulation.TimeSeriesSemSimulation) PaddingPanel(edu.cmu.tetradapp.ui.PaddingPanel) RandomTwoFactorMim(edu.cmu.tetrad.algcomparison.graph.RandomTwoFactorMim) RandomGraph(edu.cmu.tetrad.algcomparison.graph.RandomGraph) Cyclic(edu.cmu.tetrad.algcomparison.graph.Cyclic) LeeHastieSimulation(edu.cmu.tetrad.algcomparison.simulation.LeeHastieSimulation) ConditionalGaussianSimulation(edu.cmu.tetrad.algcomparison.simulation.ConditionalGaussianSimulation) SingleGraph(edu.cmu.tetrad.algcomparison.graph.SingleGraph)

Example 13 with RandomForward

use of edu.cmu.tetrad.algcomparison.graph.RandomForward in project tetrad by cmu-phil.

the class ExampleNonlinearSave method main.

public static void main(String... args) {
    Parameters parameters = new Parameters();
    parameters.set("numRuns", 100);
    parameters.set("numMeasures", 20);
    parameters.set("avgDegree", 3);
    parameters.set("sampleSize", 500);
    parameters.set("percentDiscrete", 0);
    parameters.set("minCategories", 2);
    parameters.set("maxCategories", 5);
    parameters.set("differentGraphs", true);
    parameters.set("interceptLow", 0);
    parameters.set("interceptHigh", 1);
    parameters.set("contiuousInfluence", 0.5);
    parameters.set("linearLow", 0.5);
    parameters.set("linearHigh", 1.0);
    parameters.set("quadraticLow", 0.5);
    parameters.set("quadraticHigh", 1.0);
    parameters.set("cubicLow", 0.2);
    parameters.set("cubicHigh", 0.3);
    parameters.set("varLow", 1);
    parameters.set("varHigh", 1);
    parameters.set("betaLow", 5);
    parameters.set("betaHigh", 8);
    parameters.set("gammaLow", 1.0);
    parameters.set("gammaHigh", 1.5);
    Simulation simulation = new LinearSineSimulation(new RandomForward());
    Comparison comparison = new Comparison();
    comparison.setShowAlgorithmIndices(true);
    comparison.saveToFiles("comparison", simulation, parameters);
}
Also used : Parameters(edu.cmu.tetrad.util.Parameters) Comparison(edu.cmu.tetrad.algcomparison.Comparison) RandomForward(edu.cmu.tetrad.algcomparison.graph.RandomForward)

Example 14 with RandomForward

use of edu.cmu.tetrad.algcomparison.graph.RandomForward in project tetrad by cmu-phil.

the class ExampleStARS method main.

public static void main(String... args) {
    Parameters parameters = new Parameters();
    // parameters.set("numMeasures", 100);
    // parameters.set("avgDegree", 2, 4);
    // parameters.set("sampleSize", 100, 500);
    // parameters.set("numRuns", 5);
    parameters.set("numMeasures", 200);
    parameters.set("avgDegree", 2, 4, 6);
    parameters.set("sampleSize", 100, 500);
    parameters.set("numRuns", 2);
    parameters.set("differentGraphs", true);
    parameters.set("numLatents", 0);
    parameters.set("maxDegree", 100);
    parameters.set("maxIndegree", 100);
    parameters.set("maxOutdegree", 100);
    parameters.set("connected", false);
    parameters.set("coefLow", 0.2);
    parameters.set("coefHigh", 0.9);
    parameters.set("varLow", 1);
    parameters.set("varHigh", 3);
    parameters.set("verbose", false);
    parameters.set("coefSymmetric", true);
    parameters.set("percentDiscrete", 0);
    parameters.set("numCategories", 3);
    parameters.set("differentGraphs", true);
    parameters.set("intervalBetweenShocks", 10);
    parameters.set("intervalBetweenRecordings", 10);
    parameters.set("fisherEpsilon", 0.001);
    parameters.set("randomizeColumns", true);
    parameters.set("alpha", 0.01);
    parameters.set("depth", -1);
    parameters.set("penaltyDiscount", 2);
    parameters.set("useMaxPOrientationHeuristic", false);
    parameters.set("maxPOrientationMaxPathLength", 3);
    parameters.set("verbose", false);
    parameters.set("scaleFreeAlpha", 0.00001);
    parameters.set("scaleFreeBeta", 0.4);
    parameters.set("scaleFreeDeltaIn", .1);
    parameters.set("scaleFreeDeltaOut", 3);
    parameters.set("symmetricFirstStep", false);
    parameters.set("faithfulnessAssumed", true);
    parameters.set("maxDegree", 100);
    parameters.set("StARS.tolerance", .5);
    parameters.set("StARS.cutoff", .05);
    parameters.set("numSubsamples", 7);
    parameters.set("percentSubsampleSize", .5);
    parameters.set("percentStability", .5);
    Statistics statistics = new Statistics();
    statistics.add(new ParameterColumn("numMeasures"));
    statistics.add(new ParameterColumn("avgDegree"));
    statistics.add(new ParameterColumn("sampleSize"));
    statistics.add(new AdjacencyPrecision());
    statistics.add(new AdjacencyRecall());
    statistics.add(new ArrowheadPrecision());
    statistics.add(new ArrowheadRecall());
    statistics.add(new ElapsedTime());
    statistics.setWeight("AP", 0.25);
    statistics.setWeight("AR", 0.25);
    statistics.setWeight("AHP", 0.25);
    statistics.setWeight("AHR", 0.25);
    Algorithms algorithms = new Algorithms();
    parameters.set("logScale", false);
    algorithms.add(new StabilitySelection(new Fges(new SemBicScore())));
    algorithms.add(new StARS(new Fges(new SemBicScore()), "penaltyDiscount", 1, 5));
    algorithms.add(new FirstInflection(new Fges(new SemBicScore()), "penaltyDiscount", 1, 5, .1));
    // parameters.set("penaltyDiscount", 5, 11, 15);
    // algorithms.add(new Fges(new SemBicScore()));
    // parameters.set("logScale", true);
    // Algorithm fges = new Fges(new FisherZScore());
    // algorithms.add(new StARS(fges, "alpha", -10, -2, -8));
    // algorithms.add(new FirstInflection(fges, "alpha", -10, -2, -3));
    Simulations simulations = new Simulations();
    simulations.add(new LinearFisherModel(new RandomForward()));
    Comparison comparison = new Comparison();
    comparison.setShowAlgorithmIndices(true);
    comparison.setShowSimulationIndices(true);
    comparison.setSortByUtility(false);
    comparison.setShowUtilities(false);
    comparison.setParallelized(true);
    comparison.setComparisonGraph(Comparison.ComparisonGraph.Pattern_of_the_true_DAG);
    comparison.compareFromSimulations("first.inflection", simulations, algorithms, statistics, parameters);
}
Also used : Simulations(edu.cmu.tetrad.algcomparison.simulation.Simulations) Parameters(edu.cmu.tetrad.util.Parameters) LinearFisherModel(edu.cmu.tetrad.algcomparison.simulation.LinearFisherModel) StabilitySelection(edu.cmu.tetrad.algcomparison.algorithm.StabilitySelection) StARS(edu.cmu.tetrad.algcomparison.algorithm.StARS) RandomForward(edu.cmu.tetrad.algcomparison.graph.RandomForward) Fges(edu.cmu.tetrad.algcomparison.algorithm.oracle.pattern.Fges) Algorithms(edu.cmu.tetrad.algcomparison.algorithm.Algorithms) Comparison(edu.cmu.tetrad.algcomparison.Comparison) SemBicScore(edu.cmu.tetrad.algcomparison.score.SemBicScore) FirstInflection(edu.cmu.tetrad.algcomparison.algorithm.FirstInflection)

Example 15 with RandomForward

use of edu.cmu.tetrad.algcomparison.graph.RandomForward in project tetrad by cmu-phil.

the class ExampleCompareSimulation method main.

public static void main(String... args) {
    if (args.length > 0) {
        int numMeasures = Integer.parseInt(args[0]);
        int avgDegree = Integer.parseInt(args[1]);
        Parameters parameters = new Parameters();
        // parameters.set("minCategories", 3);
        // parameters.set("maxCategories", 3);
        parameters.set("numRuns", 2);
        parameters.set("differentGraphs", true);
        parameters.set("sampleSize", 1000);
        parameters.set("numMeasures", numMeasures);
        parameters.set("numLatents", 0);
        parameters.set("avgDegree", avgDegree);
        parameters.set("maxDegree", 100);
        parameters.set("maxIndegree", 100);
        parameters.set("maxOutdegree", 100);
        parameters.set("connected", false);
        parameters.set("coefLow", 0.2);
        parameters.set("coefHigh", 0.9);
        parameters.set("varLow", 1);
        parameters.set("varHigh", 3);
        parameters.set("verbose", false);
        parameters.set("coefSymmetric", true);
        parameters.set("numRuns", 1);
        parameters.set("percentDiscrete", 0);
        parameters.set("numCategories", 3);
        parameters.set("differentGraphs", true);
        parameters.set("sampleSize", 1000);
        parameters.set("intervalBetweenShocks", 10);
        parameters.set("intervalBetweenRecordings", 10);
        parameters.set("fisherEpsilon", 0.001);
        parameters.set("randomizeColumns", true);
        parameters.set("alpha", 1e-8);
        parameters.set("depth", -1);
        parameters.set("penaltyDiscount", 4);
        parameters.set("useMaxPOrientationHeuristic", false);
        parameters.set("maxPOrientationMaxPathLength", 3);
        parameters.set("verbose", false);
        parameters.set("scaleFreeAlpha", 0.00001);
        parameters.set("scaleFreeBeta", 0.4);
        parameters.set("scaleFreeDeltaIn", .1);
        parameters.set("scaleFreeDeltaOut", 3);
        parameters.set("symmetricFirstStep", false);
        parameters.set("faithfulnessAssumed", true);
        parameters.set("maxDegree", 100);
        Statistics statistics = new Statistics();
        statistics.add(new ParameterColumn("numMeasures"));
        statistics.add(new ParameterColumn("avgDegree"));
        statistics.add(new AdjacencyPrecision());
        statistics.add(new AdjacencyRecall());
        statistics.add(new ArrowheadPrecision());
        statistics.add(new ArrowheadRecall());
        // statistics.add(new NumBidirectedEdges());
        // statistics.add(new MathewsCorrAdj());
        // statistics.add(new MathewsCorrArrow());
        // statistics.add(new F1Adj());
        // statistics.add(new F1Arrow());
        // statistics.add(new SHD());
        statistics.add(new ElapsedTime());
        statistics.setWeight("AP", 0.25);
        statistics.setWeight("AR", 0.25);
        statistics.setWeight("AHP", 0.25);
        statistics.setWeight("AHR", 0.25);
        Algorithms algorithms = new Algorithms();
        // algorithms.add(new Pc(new FisherZ()));
        // algorithms.add(new Pc(new SemBicTest()));
        // algorithms.add(new Cpc(new FisherZ()));
        // algorithms.add(new PcStable(new FisherZ()));
        // algorithms.add(new CpcStable(new FisherZ()));
        // algorithms.add(new PcStableMax(new FisherZ(), false));
        // algorithms.add(new PcStableMax(new SemBicTest(), false));
        algorithms.add(new Fges(new FisherZScore(), false));
        // algorithms.add(new Fges(new SemBicScore(), false));
        Simulations simulations = new Simulations();
        simulations.add(new LinearFisherModel(new RandomForward()));
        Comparison comparison = new Comparison();
        comparison.setShowAlgorithmIndices(true);
        comparison.setShowSimulationIndices(true);
        comparison.setSortByUtility(false);
        comparison.setShowUtilities(true);
        comparison.compareFromSimulations("comparisonJoe", simulations, algorithms, statistics, parameters);
    }
}
Also used : FisherZScore(edu.cmu.tetrad.algcomparison.score.FisherZScore) Simulations(edu.cmu.tetrad.algcomparison.simulation.Simulations) Parameters(edu.cmu.tetrad.util.Parameters) LinearFisherModel(edu.cmu.tetrad.algcomparison.simulation.LinearFisherModel) RandomForward(edu.cmu.tetrad.algcomparison.graph.RandomForward) Algorithms(edu.cmu.tetrad.algcomparison.algorithm.Algorithms) Comparison(edu.cmu.tetrad.algcomparison.Comparison)

Aggregations

RandomForward (edu.cmu.tetrad.algcomparison.graph.RandomForward)20 Comparison (edu.cmu.tetrad.algcomparison.Comparison)14 Parameters (edu.cmu.tetrad.util.Parameters)14 Simulations (edu.cmu.tetrad.algcomparison.simulation.Simulations)10 Algorithms (edu.cmu.tetrad.algcomparison.algorithm.Algorithms)9 SemSimulation (edu.cmu.tetrad.algcomparison.simulation.SemSimulation)9 LinearFisherModel (edu.cmu.tetrad.algcomparison.simulation.LinearFisherModel)8 RandomGraph (edu.cmu.tetrad.algcomparison.graph.RandomGraph)5 Algorithm (edu.cmu.tetrad.algcomparison.algorithm.Algorithm)4 FisherZ (edu.cmu.tetrad.algcomparison.independence.FisherZ)4 SemBicScore (edu.cmu.tetrad.algcomparison.score.SemBicScore)4 Simulation (edu.cmu.tetrad.algcomparison.simulation.Simulation)4 Fges (edu.cmu.tetrad.algcomparison.algorithm.oracle.pattern.Fges)3 SemBicTest (edu.cmu.tetrad.algcomparison.independence.SemBicTest)3 LeeHastieSimulation (edu.cmu.tetrad.algcomparison.simulation.LeeHastieSimulation)3 FirstInflection (edu.cmu.tetrad.algcomparison.algorithm.FirstInflection)2 IndependenceWrapper (edu.cmu.tetrad.algcomparison.independence.IndependenceWrapper)2 SemBicDTest (edu.cmu.tetrad.algcomparison.independence.SemBicDTest)2 FisherZScore (edu.cmu.tetrad.algcomparison.score.FisherZScore)2 ScoreWrapper (edu.cmu.tetrad.algcomparison.score.ScoreWrapper)2