public DiscreteTimeMarkovChain GenerateMarkovChain(Formula terminateEarlyCondition = null) { Requires.That(IntPtr.Size == 8, "Model checking is only supported in 64bit processes."); ProbabilityMatrixCreationStarted = true; CollectStateFormulasVisitor stateFormulaCollector; if (Configuration.UseAtomarPropositionsAsStateLabels) { stateFormulaCollector = new CollectAtomarPropositionFormulasVisitor(); } else { stateFormulaCollector = new CollectMaximalCompilableFormulasVisitor(); } foreach (var stateFormula in _formulasToCheck) { stateFormulaCollector.VisitNewTopLevelFormula(stateFormula); } if (terminateEarlyCondition) { stateFormulaCollector.VisitNewTopLevelFormula(terminateEarlyCondition); } var stateFormulas = stateFormulaCollector.CollectedStateFormulas.ToArray(); ExecutedModel <TExecutableModel> model = null; var modelCreator = _runtimeModelCreator.CreateCoupledModelCreator(stateFormulas); Func <AnalysisModel <TExecutableModel> > createAnalysisModelFunc = () => model = new LtmcExecutedModel <TExecutableModel>(modelCreator, 0, Configuration.SuccessorCapacity); var createAnalysisModel = new AnalysisModelCreator <TExecutableModel>(createAnalysisModelFunc); return(GenerateMarkovChain(createAnalysisModel, terminateEarlyCondition, stateFormulas)); }
public LabeledTransitionMarkovChain GenerateLabeledMarkovChain() { Requires.That(IntPtr.Size == 8, "Model checking is only supported in 64bit processes."); ProbabilityMatrixCreationStarted = true; FormulaManager.Calculate(Configuration); var stateFormulasToCheckInBaseModel = FormulaManager.StateFormulasToCheckInBaseModel.ToArray(); ExecutedModel <TExecutableModel> model = null; var modelCreator = _runtimeModelCreator.CreateCoupledModelCreator(stateFormulasToCheckInBaseModel); Func <AnalysisModel> createAnalysisModelFunc = () => model = new LtmcExecutedModel <TExecutableModel>(modelCreator, Configuration); var createAnalysisModel = new AnalysisModelCreator(createAnalysisModelFunc); var ltmc = GenerateLtmc(createAnalysisModel); return(ltmc); }