diff --git a/src/counterexamples/SMTMinimalCommandSetGenerator.h b/src/counterexamples/SMTMinimalCommandSetGenerator.h index 250083ea7..fcb0aff94 100644 --- a/src/counterexamples/SMTMinimalCommandSetGenerator.h +++ b/src/counterexamples/SMTMinimalCommandSetGenerator.h @@ -1693,7 +1693,7 @@ namespace storm { storm::models::Mdp subMdp = labeledMdp.restrictChoiceLabels(commandSet); storm::modelchecker::SparseMdpPrctlModelChecker modelchecker(subMdp); LOG4CPLUS_DEBUG(logger, "Invoking model checker."); - std::vector result = modelchecker.checkUntil(false, phiStates, psiStates, false).first; + std::vector result = modelchecker.computeUntilProbabilitiesHelper(false, phiStates, psiStates, false) LOG4CPLUS_DEBUG(logger, "Computed model checking results."); totalModelCheckingTime += std::chrono::high_resolution_clock::now() - modelCheckingClock; diff --git a/src/logic/BinaryPathFormula.cpp b/src/logic/BinaryPathFormula.cpp index 046d53803..adfac9686 100644 --- a/src/logic/BinaryPathFormula.cpp +++ b/src/logic/BinaryPathFormula.cpp @@ -44,10 +44,12 @@ namespace storm { void BinaryPathFormula::gatherAtomicExpressionFormulas(std::vector>& atomicExpressionFormulas) const { this->getLeftSubformula().gatherAtomicExpressionFormulas(atomicExpressionFormulas); + this->getLeftSubformula().gatherAtomicExpressionFormulas(atomicExpressionFormulas); } void BinaryPathFormula::gatherAtomicLabelFormulas(std::vector>& atomicLabelFormulas) const { this->getLeftSubformula().gatherAtomicLabelFormulas(atomicLabelFormulas); + this->getRightSubformula().gatherAtomicLabelFormulas(atomicLabelFormulas); } } } \ No newline at end of file diff --git a/src/logic/BinaryStateFormula.cpp b/src/logic/BinaryStateFormula.cpp index e8557651b..fb9a7560e 100644 --- a/src/logic/BinaryStateFormula.cpp +++ b/src/logic/BinaryStateFormula.cpp @@ -44,10 +44,12 @@ namespace storm { void BinaryStateFormula::gatherAtomicExpressionFormulas(std::vector>& atomicExpressionFormulas) const { this->getLeftSubformula().gatherAtomicExpressionFormulas(atomicExpressionFormulas); + this->getRightSubformula().gatherAtomicExpressionFormulas(atomicExpressionFormulas); } void BinaryStateFormula::gatherAtomicLabelFormulas(std::vector>& atomicLabelFormulas) const { this->getLeftSubformula().gatherAtomicLabelFormulas(atomicLabelFormulas); + this->getRightSubformula().gatherAtomicLabelFormulas(atomicLabelFormulas); } } } \ No newline at end of file diff --git a/src/modelchecker/prctl/SparseMdpPrctlModelChecker.h b/src/modelchecker/prctl/SparseMdpPrctlModelChecker.h index a24dfcc06..a3a7a9c08 100644 --- a/src/modelchecker/prctl/SparseMdpPrctlModelChecker.h +++ b/src/modelchecker/prctl/SparseMdpPrctlModelChecker.h @@ -7,6 +7,11 @@ #include "src/solver/NondeterministicLinearEquationSolver.h" namespace storm { + namespace counterexamples { + template + class SMTMinimalCommandSetGenerator; + } + namespace modelchecker { // Forward-declare other model checkers to make them friend classes. @@ -17,6 +22,7 @@ namespace storm { class SparseMdpPrctlModelChecker : public AbstractModelChecker { public: friend class SparseMarkovAutomatonCslModelChecker; + friend class counterexamples::SMTMinimalCommandSetGenerator; explicit SparseMdpPrctlModelChecker(storm::models::Mdp const& model); explicit SparseMdpPrctlModelChecker(storm::models::Mdp const& model, std::shared_ptr> nondeterministicLinearEquationSolver); diff --git a/src/utility/cli.h b/src/utility/cli.h index 3eaacbe45..30b9d4625 100644 --- a/src/utility/cli.h +++ b/src/utility/cli.h @@ -278,9 +278,8 @@ namespace storm { typename storm::builder::ExplicitPrismModelBuilder::Options options; if (formula) { options = storm::builder::ExplicitPrismModelBuilder::Options(*formula.get()); - } else { - options.addConstantDefinitionsFromString(program, settings.getConstantDefinitionString()); } + options.addConstantDefinitionsFromString(program, settings.getConstantDefinitionString()); // Then, build the model from the symbolic description. result = storm::builder::ExplicitPrismModelBuilder::translateProgram(program, options);