Browse Source

Decoupled preprocessing and SMT solving in commandline interface

tempestpy_adaptions
Alexander Bork 6 years ago
parent
commit
ec67166041
  1. 52
      src/storm-dft-cli/storm-dft.cpp
  2. 35
      src/storm-dft/api/storm-dft.cpp
  3. 2
      src/storm-dft/api/storm-dft.h

52
src/storm-dft-cli/storm-dft.cpp

@ -28,7 +28,6 @@ void processOptions() {
storm::settings::modules::FaultTreeSettings const& faultTreeSettings = storm::settings::getModule<storm::settings::modules::FaultTreeSettings>(); storm::settings::modules::FaultTreeSettings const& faultTreeSettings = storm::settings::getModule<storm::settings::modules::FaultTreeSettings>();
storm::settings::modules::IOSettings const& ioSettings = storm::settings::getModule<storm::settings::modules::IOSettings>(); storm::settings::modules::IOSettings const& ioSettings = storm::settings::getModule<storm::settings::modules::IOSettings>();
storm::settings::modules::DftGspnSettings const& dftGspnSettings = storm::settings::getModule<storm::settings::modules::DftGspnSettings>(); storm::settings::modules::DftGspnSettings const& dftGspnSettings = storm::settings::getModule<storm::settings::modules::DftGspnSettings>();
auto const &debug = storm::settings::getModule<storm::settings::modules::DebugSettings>();
auto dftTransformator = storm::transformations::dft::DftTransformator<ValueType>(); auto dftTransformator = storm::transformations::dft::DftTransformator<ValueType>();
@ -90,21 +89,53 @@ void processOptions() {
return; return;
} }
// TODO introduce some flags
bool useSMT = false;
bool printOutput = false;
uint64_t solverTimeout = 10;
#ifdef STORM_HAVE_Z3 #ifdef STORM_HAVE_Z3
if (faultTreeSettings.solveWithSMT()) { if (faultTreeSettings.solveWithSMT()) {
useSMT = true;
STORM_PRINT("Use SMT for preprocessing" << std::endl)
dft = dftTransformator.transformUniqueFailedBe(*dft); dft = dftTransformator.transformUniqueFailedBe(*dft);
if (dft->getDependencies().size() > 0) { if (dft->getDependencies().size() > 0) {
// Making the constantly failed BE unique may introduce non-binary FDEPs // Making the constantly failed BE unique may introduce non-binary FDEPs
dft = dftTransformator.transformBinaryFDEPs(*dft); dft = dftTransformator.transformBinaryFDEPs(*dft);
} }
// Solve with SMT
STORM_LOG_DEBUG("Running DFT analysis with use of SMT");
// Set dynamic behavior vector
}
#endif
dft->setDynamicBehaviorInfo(); dft->setDynamicBehaviorInfo();
auto smtResults = storm::api::analyzeDFTSMT(*dft, true);
storm::api::PreprocessingResult preResults;
preResults.lowerBEBound = storm::dft::utility::FailureBoundFinder::getLeastFailureBound(*dft, useSMT,
solverTimeout);
preResults.upperBEBound = storm::dft::utility::FailureBoundFinder::getAlwaysFailedBound(*dft, useSMT,
solverTimeout);
if (printOutput) {
STORM_PRINT("BE FAILURE BOUNDS" << std::endl <<
"========================================" << std::endl <<
"Lower bound: " << std::to_string(preResults.lowerBEBound) << std::endl <<
"Upper bound: " << std::to_string(preResults.upperBEBound) << std::endl)
}
preResults.fdepConflicts = storm::dft::utility::FDEPConflictFinder::getDependencyConflicts(*dft, true,
solverTimeout);
if (printOutput) {
STORM_PRINT("========================================" << std::endl <<
"FDEP CONFLICTS" << std::endl <<
"========================================"
<< std::endl)
for (auto pair: preResults.fdepConflicts) {
STORM_PRINT("Conflict between " << dft->getElement(pair.first)->name() << " and "
<< dft->getElement(pair.second)->name() << std::endl)
}
}
// Set the conflict map of the dft // Set the conflict map of the dft
std::set<size_t> conflict_set; std::set<size_t> conflict_set;
for (auto conflict : smtResults.fdepConflicts) {
for (auto conflict : preResults.fdepConflicts) {
conflict_set.insert(size_t(conflict.first)); conflict_set.insert(size_t(conflict.first));
conflict_set.insert(size_t(conflict.second)); conflict_set.insert(size_t(conflict.second));
} }
@ -113,10 +144,17 @@ void processOptions() {
dft->setDependencyNotInConflict(depId); dft->setDependencyNotInConflict(depId);
} }
} }
#ifdef STORM_HAVE_Z3
if (faultTreeSettings.solveWithSMT()) {
// Solve with SMT
STORM_LOG_DEBUG("Running DFT analysis with use of SMT");
// Set dynamic behavior vector
storm::api::analyzeDFTSMT(*dft, true);
} }
#endif #endif
//Proprocessing
// From now on we analyse DFT via model checking // From now on we analyse DFT via model checking

35
src/storm-dft/api/storm-dft.cpp

@ -43,43 +43,20 @@ namespace storm {
} }
template<> template<>
storm::api::PreprocessingResult
void
analyzeDFTSMT(storm::storage::DFT<double> const &dft, bool printOutput) { analyzeDFTSMT(storm::storage::DFT<double> const &dft, bool printOutput) {
uint64_t solverTimeout = 10; uint64_t solverTimeout = 10;
storm::modelchecker::DFTASFChecker smtChecker(dft); storm::modelchecker::DFTASFChecker smtChecker(dft);
smtChecker.toSolver(); smtChecker.toSolver();
storm::api::PreprocessingResult results;
results.lowerBEBound = storm::dft::utility::FailureBoundFinder::getLeastFailureBound(dft, true,
solverTimeout);
results.upperBEBound = storm::dft::utility::FailureBoundFinder::getAlwaysFailedBound(dft, true,
solverTimeout);
if (printOutput) {
STORM_PRINT("BE FAILURE BOUNDS" << std::endl <<
"========================================" << std::endl <<
"Lower bound: " << std::to_string(results.lowerBEBound) << std::endl <<
"Upper bound: " << std::to_string(results.upperBEBound) << std::endl)
}
results.fdepConflicts = storm::dft::utility::FDEPConflictFinder::getDependencyConflicts(dft, true,
solverTimeout);
if (printOutput) {
STORM_PRINT("========================================" << std::endl <<
"FDEP CONFLICTS" << std::endl <<
"========================================"
<< std::endl)
for (auto pair: results.fdepConflicts) {
STORM_PRINT("Conflict between " << dft.getElement(pair.first)->name() << " and "
<< dft.getElement(pair.second)->name() << std::endl)
}
}
return results;
// Removed bound computation etc. here
smtChecker.setSolverTimeout(solverTimeout);
smtChecker.checkTleNeverFailed();
smtChecker.unsetSolverTimeout();
} }
template<> template<>
storm::api::PreprocessingResult
void
analyzeDFTSMT(storm::storage::DFT<storm::RationalFunction> const &dft, bool printOutput) { analyzeDFTSMT(storm::storage::DFT<storm::RationalFunction> const &dft, bool printOutput) {
STORM_LOG_THROW(false, storm::exceptions::NotSupportedException, STORM_LOG_THROW(false, storm::exceptions::NotSupportedException,
"Analysis by SMT not supported for this data type."); "Analysis by SMT not supported for this data type.");

2
src/storm-dft/api/storm-dft.h

@ -108,7 +108,7 @@ namespace storm {
* @return Result result vector * @return Result result vector
*/ */
template<typename ValueType> template<typename ValueType>
storm::api::PreprocessingResult
void
analyzeDFTSMT(storm::storage::DFT<ValueType> const &dft, bool printOutput); analyzeDFTSMT(storm::storage::DFT<ValueType> const &dft, bool printOutput);
/*! /*!

Loading…
Cancel
Save