Browse Source

removed warning for missing naming capabilities in Z3 LP solver

tempestpy_adaptions
dehnert 7 years ago
parent
commit
7636a0339d
  1. 2
      src/storm/solver/Z3LpSolver.cpp
  2. 5
      src/storm/transformer/SymbolicToSparseTransformer.cpp

2
src/storm/solver/Z3LpSolver.cpp

@ -26,7 +26,6 @@ namespace storm {
template<typename ValueType> template<typename ValueType>
Z3LpSolver<ValueType>::Z3LpSolver(std::string const& name, OptimizationDirection const& optDir) : LpSolver<ValueType>(optDir) { Z3LpSolver<ValueType>::Z3LpSolver(std::string const& name, OptimizationDirection const& optDir) : LpSolver<ValueType>(optDir) {
STORM_LOG_WARN_COND(name == "", "Z3 does not support names for solvers");
z3::config config; z3::config config;
config.set("model", true); config.set("model", true);
context = std::unique_ptr<z3::context>(new z3::context(config)); context = std::unique_ptr<z3::context>(new z3::context(config));
@ -137,7 +136,6 @@ namespace storm {
void Z3LpSolver<ValueType>::addConstraint(std::string const& name, storm::expressions::Expression const& constraint) { void Z3LpSolver<ValueType>::addConstraint(std::string const& name, storm::expressions::Expression const& constraint) {
STORM_LOG_THROW(constraint.isRelationalExpression(), storm::exceptions::InvalidArgumentException, "Illegal constraint is not a relational expression."); STORM_LOG_THROW(constraint.isRelationalExpression(), storm::exceptions::InvalidArgumentException, "Illegal constraint is not a relational expression.");
STORM_LOG_THROW(constraint.getOperator() != storm::expressions::OperatorType::NotEqual, storm::exceptions::InvalidArgumentException, "Illegal constraint uses inequality operator."); STORM_LOG_THROW(constraint.getOperator() != storm::expressions::OperatorType::NotEqual, storm::exceptions::InvalidArgumentException, "Illegal constraint uses inequality operator.");
STORM_LOG_WARN_COND(name == "", "Z3 does not support names for constraints");
solver->add(expressionAdapter->translateExpression(constraint)); solver->add(expressionAdapter->translateExpression(constraint));
} }

5
src/storm/transformer/SymbolicToSparseTransformer.cpp

@ -68,6 +68,11 @@ namespace storm {
storm::models::sparse::StateLabeling labelling(transitionMatrix.getRowGroupCount()); storm::models::sparse::StateLabeling labelling(transitionMatrix.getRowGroupCount());
labelling.addLabel("init", symbolicMdp.getInitialStates().toVector(odd)); labelling.addLabel("init", symbolicMdp.getInitialStates().toVector(odd));
symbolicMdp.getDeadlockStates().template toAdd<ValueType>().exportToDot("deadlock.dot");
std::cout << "height " << odd.getHeight() << std::endl;
for (auto const& var : symbolicMdp.getDeadlockStates().getContainedMetaVariables()) {
std::cout << "var " << var.getName() << " = " << symbolicMdp.getManager().getMetaVariable(var).getNumberOfDdVariables() << " dd vars" << std::endl;
}
labelling.addLabel("deadlock", symbolicMdp.getDeadlockStates().toVector(odd)); labelling.addLabel("deadlock", symbolicMdp.getDeadlockStates().toVector(odd));
for(auto const& label : symbolicMdp.getLabels()) { for(auto const& label : symbolicMdp.getLabels()) {
labelling.addLabel(label, symbolicMdp.getStates(label).toVector(odd)); labelling.addLabel(label, symbolicMdp.getStates(label).toVector(odd));

Loading…
Cancel
Save