Browse Source

Make exploration heuristic choosable

tempestpy_adaptions
Matthias Volk 6 years ago
parent
commit
0904c01828
  1. 40
      src/storm-dft/builder/ExplicitDFTModelBuilder.cpp
  2. 5
      src/storm-dft/builder/ExplicitDFTModelBuilder.h

40
src/storm-dft/builder/ExplicitDFTModelBuilder.cpp

@ -60,14 +60,9 @@ namespace storm {
generator(dft, *stateGenerationInfo, enableDC, mergeFailedStates), generator(dft, *stateGenerationInfo, enableDC, mergeFailedStates),
matrixBuilder(!generator.isDeterministicModel()), matrixBuilder(!generator.isDeterministicModel()),
stateStorage(dft.stateBitVectorSize()), stateStorage(dft.stateBitVectorSize()),
// TODO Matthias: make choosable
//explorationQueue(dft.nrElements()+1, 0, 1) //explorationQueue(dft.nrElements()+1, 0, 1)
explorationQueue(200, 0, 0.9, false) explorationQueue(200, 0, 0.9, false)
{ {
// Intentionally left empty.
// TODO Matthias: remove again
usedHeuristic = storm::builder::ApproximationHeuristic::DEPTH;
// Compute independent subtrees // Compute independent subtrees
if (dft.topLevelType() == storm::storage::DFTElementType::OR) { if (dft.topLevelType() == storm::storage::DFTElementType::OR) {
// We only support this for approximation with top level element OR // We only support this for approximation with top level element OR
@ -163,7 +158,21 @@ namespace storm {
STORM_LOG_TRACE("Initial state: " << initialStateIndex); STORM_LOG_TRACE("Initial state: " << initialStateIndex);
// Initialize heuristic values for inital state // Initialize heuristic values for inital state
STORM_LOG_ASSERT(!statesNotExplored.at(initialStateIndex).second, "Heuristic for initial state is already initialized"); STORM_LOG_ASSERT(!statesNotExplored.at(initialStateIndex).second, "Heuristic for initial state is already initialized");
ExplorationHeuristicPointer heuristic = std::make_shared<ExplorationHeuristic>(initialStateIndex);
ExplorationHeuristicPointer heuristic;
switch (usedHeuristic) {
case storm::builder::ApproximationHeuristic::NONE:
heuristic = std::make_shared<DFTExplorationHeuristicNone<ValueType>>(initialStateIndex);
break;
case storm::builder::ApproximationHeuristic::DEPTH:
heuristic = std::make_shared<DFTExplorationHeuristicDepth<ValueType>>(initialStateIndex);
break;
case storm::builder::ApproximationHeuristic::PROBABILITY:
heuristic = std::make_shared<DFTExplorationHeuristicProbability<ValueType>>(initialStateIndex);
break;
case storm::builder::ApproximationHeuristic::BOUNDDIFFERENCE:
heuristic = std::make_shared<DFTExplorationHeuristicBoundDifference<ValueType>>(initialStateIndex);
break;
}
heuristic->markExpand(); heuristic->markExpand();
statesNotExplored[initialStateIndex].second = heuristic; statesNotExplored[initialStateIndex].second = heuristic;
explorationQueue.push(heuristic); explorationQueue.push(heuristic);
@ -171,7 +180,7 @@ namespace storm {
initializeNextIteration(); initializeNextIteration();
} }
if (approximationThreshold > 0) {
if (approximationThreshold > 0.0) {
switch (usedHeuristic) { switch (usedHeuristic) {
case storm::builder::ApproximationHeuristic::NONE: case storm::builder::ApproximationHeuristic::NONE:
// Do not change anything // Do not change anything
@ -385,7 +394,22 @@ namespace storm {
DFTStatePointer state = iter->second.first; DFTStatePointer state = iter->second.first;
if (!iter->second.second) { if (!iter->second.second) {
// Initialize heuristic values // Initialize heuristic values
ExplorationHeuristicPointer heuristic = std::make_shared<ExplorationHeuristic>(stateProbabilityPair.first, *currentExplorationHeuristic, stateProbabilityPair.second, choice.getTotalMass());
ExplorationHeuristicPointer heuristic;
switch (usedHeuristic) {
case storm::builder::ApproximationHeuristic::NONE:
heuristic = std::make_shared<DFTExplorationHeuristicNone<ValueType>>(stateProbabilityPair.first, *currentExplorationHeuristic, stateProbabilityPair.second, choice.getTotalMass());
break;
case storm::builder::ApproximationHeuristic::DEPTH:
heuristic = std::make_shared<DFTExplorationHeuristicDepth<ValueType>>(stateProbabilityPair.first, *currentExplorationHeuristic, stateProbabilityPair.second, choice.getTotalMass());
break;
case storm::builder::ApproximationHeuristic::PROBABILITY:
heuristic = std::make_shared<DFTExplorationHeuristicProbability<ValueType>>(stateProbabilityPair.first, *currentExplorationHeuristic, stateProbabilityPair.second, choice.getTotalMass());
break;
case storm::builder::ApproximationHeuristic::BOUNDDIFFERENCE:
heuristic = std::make_shared<DFTExplorationHeuristicBoundDifference<ValueType>>(stateProbabilityPair.first, *currentExplorationHeuristic, stateProbabilityPair.second, choice.getTotalMass());
break;
}
iter->second.second = heuristic; iter->second.second = heuristic;
if (state->hasFailed(dft.getTopLevelIndex()) || state->isFailsafe(dft.getTopLevelIndex()) || state->getFailableElements().hasDependencies() || (!state->getFailableElements().hasDependencies() && state->getFailableElements().hasBEs())) { if (state->hasFailed(dft.getTopLevelIndex()) || state->isFailsafe(dft.getTopLevelIndex()) || state->getFailableElements().hasDependencies() || (!state->getFailableElements().hasDependencies() && state->getFailableElements().hasBEs())) {
// Do not skip absorbing state or if reached by dependencies // Do not skip absorbing state or if reached by dependencies

5
src/storm-dft/builder/ExplicitDFTModelBuilder.h

@ -29,8 +29,7 @@ namespace storm {
class ExplicitDFTModelBuilder { class ExplicitDFTModelBuilder {
using DFTStatePointer = std::shared_ptr<storm::storage::DFTState<ValueType>>; using DFTStatePointer = std::shared_ptr<storm::storage::DFTState<ValueType>>;
// TODO Matthias: make choosable
using ExplorationHeuristic = DFTExplorationHeuristicDepth<ValueType>;
using ExplorationHeuristic = DFTExplorationHeuristic<ValueType>;
using ExplorationHeuristicPointer = std::shared_ptr<ExplorationHeuristic>; using ExplorationHeuristicPointer = std::shared_ptr<ExplorationHeuristic>;
@ -343,7 +342,7 @@ namespace storm {
storm::storage::sparse::StateStorage<StateType> stateStorage; storm::storage::sparse::StateStorage<StateType> stateStorage;
// A priority queue of states that still need to be explored. // A priority queue of states that still need to be explored.
storm::storage::BucketPriorityQueue<ValueType> explorationQueue;
storm::storage::BucketPriorityQueue<ExplorationHeuristic> explorationQueue;
// A mapping of not yet explored states from the id to the tuple (state object, heuristic values). // A mapping of not yet explored states from the id to the tuple (state object, heuristic values).
std::map<StateType, std::pair<DFTStatePointer, ExplorationHeuristicPointer>> statesNotExplored; std::map<StateType, std::pair<DFTStatePointer, ExplorationHeuristicPointer>> statesNotExplored;

Loading…
Cancel
Save