|
@ -5,7 +5,6 @@ |
|
|
|
|
|
|
|
|
#ifdef STORM_HAVE_SMTRAT
|
|
|
#ifdef STORM_HAVE_SMTRAT
|
|
|
#include "lib/smtrat.h"
|
|
|
#include "lib/smtrat.h"
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
namespace storm { |
|
|
namespace storm { |
|
|
namespace solver { |
|
|
namespace solver { |
|
@ -13,9 +12,6 @@ namespace storm { |
|
|
|
|
|
|
|
|
SmtratSmtSolver::SmtratSmtSolver(storm::expressions::ExpressionManager& manager) : SmtSolver(manager) |
|
|
SmtratSmtSolver::SmtratSmtSolver(storm::expressions::ExpressionManager& manager) : SmtSolver(manager) |
|
|
{ |
|
|
{ |
|
|
#ifndef STORM_HAVE_SMTRAT
|
|
|
|
|
|
STORM_LOG_THROW(false, storm::exceptions::NotSupportedException, "StoRM is compiled without SMT-RAT support."); |
|
|
|
|
|
#else
|
|
|
|
|
|
// Construct the settingsManager.
|
|
|
// Construct the settingsManager.
|
|
|
//smtrat::RuntimeSettingsManager settingsManager;
|
|
|
//smtrat::RuntimeSettingsManager settingsManager;
|
|
|
|
|
|
|
|
@ -28,7 +24,6 @@ namespace storm { |
|
|
// Introduce the settingsObjects from the modules to the manager.
|
|
|
// Introduce the settingsObjects from the modules to the manager.
|
|
|
//settingsManager.addSettingsObject( settingsObjects );
|
|
|
//settingsManager.addSettingsObject( settingsObjects );
|
|
|
//settingsObjects.clear();
|
|
|
//settingsObjects.clear();
|
|
|
#endif
|
|
|
|
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
SmtratSmtSolver::~SmtratSmtSolver() { |
|
|
SmtratSmtSolver::~SmtratSmtSolver() { |
|
@ -37,35 +32,23 @@ namespace storm { |
|
|
|
|
|
|
|
|
void SmtratSmtSolver::push() |
|
|
void SmtratSmtSolver::push() |
|
|
{ |
|
|
{ |
|
|
#ifndef STORM_HAVE_SMTRAT
|
|
|
|
|
|
STORM_LOG_THROW(false, storm::exceptions::NotSupportedException, "StoRM is compiled without SMT-RAT support."); |
|
|
|
|
|
#else
|
|
|
|
|
|
this->solver->push(); |
|
|
this->solver->push(); |
|
|
#endif
|
|
|
|
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
void SmtratSmtSolver::pop() |
|
|
void SmtratSmtSolver::pop() |
|
|
{ |
|
|
{ |
|
|
#ifndef STORM_HAVE_SMTRAT
|
|
|
|
|
|
STORM_LOG_THROW(false, storm::exceptions::NotSupportedException, "StoRM is compiled without SMT-RAT support."); |
|
|
|
|
|
#else
|
|
|
|
|
|
this->solver->pop(); |
|
|
this->solver->pop(); |
|
|
#endif
|
|
|
|
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
void SmtratSmtSolver::pop(uint_fast64_t n) |
|
|
void SmtratSmtSolver::pop(uint_fast64_t n) |
|
|
{ |
|
|
{ |
|
|
#ifndef STORM_HAVE_SMTRAT
|
|
|
|
|
|
STORM_LOG_THROW(false, storm::exceptions::NotSupportedException, "StoRM is compiled without SMT-RAT support."); |
|
|
|
|
|
#else
|
|
|
|
|
|
this->solver->pop(static_cast<unsigned int>(n)); |
|
|
this->solver->pop(static_cast<unsigned int>(n)); |
|
|
#endif
|
|
|
|
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
SmtSolver::CheckResult SmtratSmtSolver::check() |
|
|
SmtSolver::CheckResult SmtratSmtSolver::check() |
|
|
{ |
|
|
{ |
|
|
#ifdef STORM_HAVE_SMTRAT
|
|
|
|
|
|
|
|
|
|
|
|
switch (this->solver->check()) { |
|
|
switch (this->solver->check()) { |
|
|
case smtrat::Answer::True: |
|
|
case smtrat::Answer::True: |
|
|
this->lastResult = SmtSolver::CheckResult::Sat; |
|
|
this->lastResult = SmtSolver::CheckResult::Sat; |
|
@ -82,11 +65,8 @@ namespace storm { |
|
|
break; |
|
|
break; |
|
|
} |
|
|
} |
|
|
return this->lastResult; |
|
|
return this->lastResult; |
|
|
#else
|
|
|
|
|
|
STORM_LOG_THROW(false, storm::exceptions::NotSupportedException, "StoRM is compiled without Z3 support."); |
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
void SmtratSmtSolver::add(const storm::RawPolynomial& pol, storm::CompareRelation cr) { |
|
|
void SmtratSmtSolver::add(const storm::RawPolynomial& pol, storm::CompareRelation cr) { |
|
|
this->solver->add(smtrat::FormulaT(pol, cr)); |
|
|
this->solver->add(smtrat::FormulaT(pol, cr)); |
|
|
} |
|
|
} |
|
@ -105,3 +85,4 @@ namespace storm { |
|
|
|
|
|
|
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
#endif
|