Browse Source

Adapted subsystem generation to the use of the new subsystem checking method using bit vectors.

Compiles now.
Next up: Setting up the control flow to make it actually generate a critical subsystem.


Former-commit-id: a05fd42071
tempestpy_adaptions
masawei 11 years ago
parent
commit
b55932b212
  1. 21
      src/counterexamples/PathBasedSubsystemGenerator.h
  2. 1
      src/modelchecker/prctl/AbstractModelChecker.h
  3. 1
      src/storm.cpp

21
src/counterexamples/PathBasedSubsystemGenerator.h

@ -10,6 +10,8 @@
#include "src/models/Dtmc.h" #include "src/models/Dtmc.h"
#include "src/models/AbstractModel.h" #include "src/models/AbstractModel.h"
#include "src/modelchecker/prctl/SparseDtmcPrctlModelChecker.h"
#include "src/solver/GmmxxLinearEquationSolver.h"
#include "src/storage/BitVector.h" #include "src/storage/BitVector.h"
#include "log4cplus/logger.h" #include "log4cplus/logger.h"
@ -508,7 +510,7 @@ public:
/*! /*!
* *
*/ */
static void computeCriticalSubsystem(storm::modelchecker::prctl::AbstractModelChecker<T>& modelCheck, storm::property::prctl::AbstractStateFormula<T> const& stateFormula) {
static void computeCriticalSubsystem(storm::models::Dtmc<T> const model, storm::property::prctl::AbstractStateFormula<T> const& stateFormula) {
//------------------------------------------------------------- //-------------------------------------------------------------
// 1. Strip and handle formulas // 1. Strip and handle formulas
@ -519,8 +521,9 @@ public:
#endif #endif
LOG4CPLUS_INFO(logger, "Start finding critical subsystem."); LOG4CPLUS_INFO(logger, "Start finding critical subsystem.");
//get dtmc (model) from model checker
storm::models::Dtmc<T> model = modelCheck.template getModel<storm::models::Dtmc<T>>();
//make model checker
//TODO: Implement and use generic Model Checker factory.
storm::modelchecker::prctl::SparseDtmcPrctlModelChecker<T> modelCheck {model, new storm::solver::GmmxxLinearEquationSolver<T>()};
//init bit vector to contain the subsystem //init bit vector to contain the subsystem
storm::storage::BitVector subSys(model.getNumberOfStates()); storm::storage::BitVector subSys(model.getNumberOfStates());
@ -618,9 +621,6 @@ public:
} }
pathCount++; pathCount++;
// set bigger sub system
modelCheck.setSubSystem(&subSys);
// Get estimate (upper bound) of new sub system probability // Get estimate (upper bound) of new sub system probability
// That is: prob(target) * cost(path) * (mean(prob(inits))/prob(source)) // That is: prob(target) * cost(path) * (mean(prob(inits))/prob(source))
subSysProb += trueProbs[shortestPath[0]] * pathProb * trueProb / trueProbs[shortestPath.back()]; subSysProb += trueProbs[shortestPath[0]] * pathProb * trueProb / trueProbs[shortestPath.back()];
@ -639,9 +639,6 @@ public:
subSys.set(shortestPath[i], true); subSys.set(shortestPath[i], true);
} }
// set bigger sub system
modelCheck.setSubSystem(&subSys);
// Get estimate (upper bound) of new sub system probability // Get estimate (upper bound) of new sub system probability
// That is: prob(target) * cost(path) * (mean(prob(inits))/prob(source)) // That is: prob(target) * cost(path) * (mean(prob(inits))/prob(source))
//subSysProb += (trueProbs[shortestPath.back()] == 0 ? 0 : trueProbs[shortestPath[0]] * pathProb * trueProb / trueProbs[shortestPath.back()]); //subSysProb += (trueProbs[shortestPath.back()] == 0 ? 0 : trueProbs[shortestPath[0]] * pathProb * trueProb / trueProbs[shortestPath.back()]);
@ -651,7 +648,7 @@ public:
if((pathCount % precision == 0) && subSysProb >= bound) { if((pathCount % precision == 0) && subSysProb >= bound) {
//get probabilities //get probabilities
subSysProbs = pathFormulaPtr->check(modelCheck, false);
subSysProbs = modelCheck.checkUntil(allowedStates & subSys, targetStates & subSys, false);
//T diff = subSysProb; //T diff = subSysProb;
//std::cout << "Est. prob: " << diff << std::endl; //std::cout << "Est. prob: " << diff << std::endl;
@ -670,7 +667,6 @@ public:
//std::cout << "Path count: " << pathCount << std::endl; //std::cout << "Path count: " << pathCount << std::endl;
//Are we critical? //Are we critical?
//if(!modelCheck.check(stateFormula)) break;
if(subSysProb >= bound){ if(subSysProb >= bound){
break; break;
} }
@ -680,9 +676,6 @@ public:
} }
} }
// To be sure the model checker ignores subsystems for future calls.
modelCheck.setSubSystem(nullptr);
#ifdef BENCHMARK #ifdef BENCHMARK
LOG4CPLUS_INFO(logger, "Critical subsystem found."); LOG4CPLUS_INFO(logger, "Critical subsystem found.");
LOG4CPLUS_INFO(logger, "Paths needed: " << pathCount); LOG4CPLUS_INFO(logger, "Paths needed: " << pathCount);

1
src/modelchecker/prctl/AbstractModelChecker.h

@ -21,7 +21,6 @@ namespace prctl {
#include "src/formula/Prctl.h" #include "src/formula/Prctl.h"
#include "src/storage/BitVector.h" #include "src/storage/BitVector.h"
#include "src/models/AbstractModel.h" #include "src/models/AbstractModel.h"
#include "src/counterexamples/PathBasedSubsystemGenerator.h"
#include "src/settings/Settings.h" #include "src/settings/Settings.h"
#include "log4cplus/logger.h" #include "log4cplus/logger.h"

1
src/storm.cpp

@ -28,6 +28,7 @@
#include "src/solver/GmmxxNondeterministicLinearEquationSolver.h" #include "src/solver/GmmxxNondeterministicLinearEquationSolver.h"
#include "src/counterexamples/MILPMinimalLabelSetGenerator.h" #include "src/counterexamples/MILPMinimalLabelSetGenerator.h"
#include "src/counterexamples/SMTMinimalCommandSetGenerator.h" #include "src/counterexamples/SMTMinimalCommandSetGenerator.h"
#include "src/counterexamples/PathBasedSubsystemGenerator.h"
#include "src/parser/AutoParser.h" #include "src/parser/AutoParser.h"
#include "src/parser/PrctlParser.h" #include "src/parser/PrctlParser.h"
#include "src/utility/ErrorHandling.h" #include "src/utility/ErrorHandling.h"

Loading…
Cancel
Save