Browse Source

fixed some guards for smtsolver

Former-commit-id: 2205f1af57
tempestpy_adaptions
sjunges 10 years ago
parent
commit
0bd4b9b8ad
  1. 25
      src/solver/SmtratSmtSolver.cpp
  2. 3
      src/solver/SmtratSmtSolver.h

25
src/solver/SmtratSmtSolver.cpp

@ -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

3
src/solver/SmtratSmtSolver.h

@ -26,7 +26,7 @@ namespace storm {
virtual void pop(uint_fast64_t n) override; virtual void pop(uint_fast64_t n) override;
virtual CheckResult check() override; virtual CheckResult check() override;
#ifdef STORM_HAVE_CARL
void add(storm::RawPolynomial const&, storm::CompareRelation); void add(storm::RawPolynomial const&, storm::CompareRelation);
template<typename ReturnType> template<typename ReturnType>
@ -38,7 +38,6 @@ namespace storm {
#endif
// The last result that was returned by any of the check methods. // The last result that was returned by any of the check methods.
CheckResult lastResult; CheckResult lastResult;

Loading…
Cancel
Save