Browse Source

Fixed expand flag to avoid expanding too much

tempestpy_adaptions
Matthias Volk 6 years ago
parent
commit
4f376caccb
  1. 2
      src/storm-dft/builder/DftExplorationHeuristic.h
  2. 7
      src/storm-dft/builder/ExplicitDFTModelBuilder.cpp
  3. 1
      src/storm-dft/generator/DftNextStateGenerator.cpp

2
src/storm-dft/builder/DftExplorationHeuristic.h

@ -22,7 +22,7 @@ namespace storm {
class DFTExplorationHeuristic { class DFTExplorationHeuristic {
public: public:
explicit DFTExplorationHeuristic(size_t id) : id(id), expand(true), lowerBound(storm::utility::zero<ValueType>()), upperBound(storm::utility::infinity<ValueType>()), depth(0), probability(storm::utility::one<ValueType>()) {
explicit DFTExplorationHeuristic(size_t id) : id(id), expand(false), lowerBound(storm::utility::zero<ValueType>()), upperBound(storm::utility::infinity<ValueType>()), depth(0), probability(storm::utility::one<ValueType>()) {
// Intentionally left empty // Intentionally left empty
} }

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

@ -383,7 +383,7 @@ namespace storm {
setMarkovian(true); setMarkovian(true);
// Add transition to target state with temporary value 0 // Add transition to target state with temporary value 0
// TODO: what to do when there is no unique target state? // TODO: what to do when there is no unique target state?
STORM_LOG_ASSERT(this->uniqueFailedState, "Approximation only works with unique failed state");
//STORM_LOG_ASSERT(this->uniqueFailedState, "Approximation only works with unique failed state");
matrixBuilder.addTransition(0, storm::utility::zero<ValueType>()); matrixBuilder.addTransition(0, storm::utility::zero<ValueType>());
// Remember skipped state // Remember skipped state
skippedStates[matrixBuilder.getCurrentRowGroup() - 1] = std::make_pair(currentState, currentExplorationHeuristic); skippedStates[matrixBuilder.getCurrentRowGroup() - 1] = std::make_pair(currentState, currentExplorationHeuristic);
@ -425,8 +425,9 @@ namespace storm {
} }
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())) {
// Do not skip absorbing state or if reached by dependencies
//if (state->hasFailed(dft.getTopLevelIndex()) || state->isFailsafe(dft.getTopLevelIndex()) || state->getFailableElements().hasDependencies() || (!state->getFailableElements().hasDependencies() && !state->getFailableElements().hasBEs())) {
if (state->getFailableElements().hasDependencies() || (!state->getFailableElements().hasDependencies() && !state->getFailableElements().hasBEs())) {
// Do not skip absorbing state or if reached by dependencies
iter->second.second->markExpand(); iter->second.second->markExpand();
} }
if (usedHeuristic == storm::builder::ApproximationHeuristic::BOUNDDIFFERENCE) { if (usedHeuristic == storm::builder::ApproximationHeuristic::BOUNDDIFFERENCE) {

1
src/storm-dft/generator/DftNextStateGenerator.cpp

@ -78,6 +78,7 @@ namespace storm {
// Let BE fail // Let BE fail
bool isFirst = true; bool isFirst = true;
while (!state->getFailableElements().isEnd()) { while (!state->getFailableElements().isEnd()) {
//TODO outside
if (storm::settings::getModule<storm::settings::modules::FaultTreeSettings>().isTakeFirstDependency() && exploreDependencies && !isFirst) { if (storm::settings::getModule<storm::settings::modules::FaultTreeSettings>().isTakeFirstDependency() && exploreDependencies && !isFirst) {
// We discard further exploration as we already chose one dependent event // We discard further exploration as we already chose one dependent event
break; break;

Loading…
Cancel
Save