Browse Source

formula parser now correctly accepts variables of a loaded model

Former-commit-id: 9d6312b529
tempestpy_adaptions
dehnert 10 years ago
parent
commit
3849c59d6b
  1. 18
      src/builder/DdPrismModelBuilder.cpp
  2. 2
      src/utility/cli.cpp

18
src/builder/DdPrismModelBuilder.cpp

@ -1017,13 +1017,6 @@ namespace storm {
ModuleDecisionDiagram const& globalModule = system.globalModule; ModuleDecisionDiagram const& globalModule = system.globalModule;
storm::dd::Add<Type> stateActionDd = system.stateActionDd; storm::dd::Add<Type> stateActionDd = system.stateActionDd;
// Cut the transitions and rewards to the reachable fragment of the state space.
storm::dd::Bdd<Type> initialStates = createInitialStatesDecisionDiagram(generationInfo);
storm::dd::Bdd<Type> transitionMatrixBdd = transitionMatrix.notZero();
if (program.getModelType() == storm::prism::Program::ModelType::MDP) {
transitionMatrixBdd = transitionMatrixBdd.existsAbstract(generationInfo.allNondeterminismVariables);
}
// If we were asked to treat some states as terminal states, we cut away their transitions now. // If we were asked to treat some states as terminal states, we cut away their transitions now.
if (options.terminalStates) { if (options.terminalStates) {
storm::expressions::Expression terminalExpression; storm::expressions::Expression terminalExpression;
@ -1033,7 +1026,16 @@ namespace storm {
std::string const& labelName = boost::get<std::string>(options.terminalStates.get()); std::string const& labelName = boost::get<std::string>(options.terminalStates.get());
terminalExpression = preparedProgram.getLabelExpression(labelName); terminalExpression = preparedProgram.getLabelExpression(labelName);
} }
// TODO
STORM_LOG_TRACE("Making the states satisfying " << terminalExpression << " terminal.");
storm::dd::Add<Type> terminalStatesAdd = generationInfo.rowExpressionAdapter->translateExpression(terminalExpression);
transitionMatrix *= !terminalStatesAdd;
}
// Cut the transitions and rewards to the reachable fragment of the state space.
storm::dd::Bdd<Type> initialStates = createInitialStatesDecisionDiagram(generationInfo);
storm::dd::Bdd<Type> transitionMatrixBdd = transitionMatrix.notZero();
if (program.getModelType() == storm::prism::Program::ModelType::MDP) {
transitionMatrixBdd = transitionMatrixBdd.existsAbstract(generationInfo.allNondeterminismVariables);
} }
storm::dd::Bdd<Type> reachableStates = computeReachableStates(generationInfo, initialStates, transitionMatrixBdd); storm::dd::Bdd<Type> reachableStates = computeReachableStates(generationInfo, initialStates, transitionMatrixBdd);

2
src/utility/cli.cpp

@ -222,7 +222,7 @@ namespace storm {
if (settings.isPropertySet()) { if (settings.isPropertySet()) {
storm::parser::FormulaParser formulaParser; storm::parser::FormulaParser formulaParser;
if (program) { if (program) {
storm::parser::FormulaParser formulaParser(program.get().getManager().getSharedPointer());
storm::parser::FormulaParser formulaParser = storm::parser::FormulaParser(program.get().getManager().getSharedPointer());
} }
// If the given property looks like a file (containing a dot and there exists a file with that name), // If the given property looks like a file (containing a dot and there exists a file with that name),

Loading…
Cancel
Save