Browse Source

Correct initialization of priority queue

tempestpy_adaptions
Matthias Volk 6 years ago
parent
commit
87180e1000
  1. 30
      src/storm-dft/generator/DftNextStateGenerator.cpp
  2. 2
      src/storm-dft/generator/DftNextStateGenerator.h
  3. 8
      src/storm-dft/storage/dft/DFTState.cpp
  4. 3
      src/storm-dft/storage/dft/DFTState.h

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

@ -46,16 +46,19 @@ namespace storm {
template<typename ValueType, typename StateType> template<typename ValueType, typename StateType>
StateBehavior<ValueType, StateType> DftNextStateGenerator<ValueType, StateType>::expand(StateToIdCallback const& stateToIdCallback) { StateBehavior<ValueType, StateType> DftNextStateGenerator<ValueType, StateType>::expand(StateToIdCallback const& stateToIdCallback) {
STORM_LOG_DEBUG("Explore state: " << mDft.getStateString(state)); STORM_LOG_DEBUG("Explore state: " << mDft.getStateString(state));
// Initialization
bool hasDependencies = state->getFailableElements().hasDependencies();
return exploreState(stateToIdCallback, hasDependencies);
}
template<typename ValueType, typename StateType>
StateBehavior<ValueType, StateType> DftNextStateGenerator<ValueType, StateType>::exploreState(StateToIdCallback const& stateToIdCallback, bool exploreDependencies) {
// Prepare the result, in case we return early. // Prepare the result, in case we return early.
StateBehavior<ValueType, StateType> result; StateBehavior<ValueType, StateType> result;
// Initialization
bool hasDependencies = state->getFailableElements().hasDependencies();
//size_t failableCount = hasDependencies ? state->nrFailableDependencies() : state->nrFailableBEs(); //size_t failableCount = hasDependencies ? state->nrFailableDependencies() : state->nrFailableBEs();
//size_t currentFailable = 0; //size_t currentFailable = 0;
state->getFailableElements().init(hasDependencies);
state->getFailableElements().init(exploreDependencies);
// Check for absorbing state // Check for absorbing state
if (mDft.hasFailed(state) || mDft.isFailsafe(state) || state->getFailableElements().isEnd()) { if (mDft.hasFailed(state) || mDft.isFailsafe(state) || state->getFailableElements().isEnd()) {
Choice<ValueType, StateType> choice(0, true); Choice<ValueType, StateType> choice(0, true);
@ -68,12 +71,12 @@ namespace storm {
return result; return result;
} }
Choice<ValueType, StateType> choice(0, !hasDependencies);
Choice<ValueType, StateType> choice(0, !exploreDependencies);
// Let BE fail // Let BE fail
bool isFirst = true; bool isFirst = true;
while (!state->getFailableElements().isEnd()) { while (!state->getFailableElements().isEnd()) {
if (storm::settings::getModule<storm::settings::modules::FaultTreeSettings>().isTakeFirstDependency() && hasDependencies && !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;
} }
@ -82,10 +85,10 @@ namespace storm {
// Construct new state as copy from original one // Construct new state as copy from original one
DFTStatePointer newState = state->copy(); DFTStatePointer newState = state->copy();
std::pair<std::shared_ptr<storm::storage::DFTBE<ValueType> const>, bool> nextBEPair = newState->letNextBEFail(state->getFailableElements().get());
std::pair<std::shared_ptr<storm::storage::DFTBE<ValueType> const>, bool> nextBEPair = newState->letNextBEFail(state->getFailableElements().get(), exploreDependencies);
std::shared_ptr<storm::storage::DFTBE<ValueType> const>& nextBE = nextBEPair.first; std::shared_ptr<storm::storage::DFTBE<ValueType> const>& nextBE = nextBEPair.first;
STORM_LOG_ASSERT(nextBE, "NextBE is null."); STORM_LOG_ASSERT(nextBE, "NextBE is null.");
STORM_LOG_ASSERT(nextBEPair.second == hasDependencies, "Failure due to dependencies does not match.");
STORM_LOG_ASSERT(nextBEPair.second == exploreDependencies, "Failure due to dependencies does not match.");
STORM_LOG_TRACE("With the failure of: " << nextBE->name() << " [" << nextBE->id() << "] in " << mDft.getStateString(state)); STORM_LOG_TRACE("With the failure of: " << nextBE->name() << " [" << nextBE->id() << "] in " << mDft.getStateString(state));
// Propagate // Propagate
@ -149,7 +152,7 @@ namespace storm {
} }
// Set transitions // Set transitions
if (hasDependencies) {
if (exploreDependencies) {
// Failure is due to dependency -> add non-deterministic choice // Failure is due to dependency -> add non-deterministic choice
ValueType probability = mDft.getDependency(state->getFailableElements().get())->probability(); ValueType probability = mDft.getDependency(state->getFailableElements().get())->probability();
choice.addProbability(newStateId, probability); choice.addProbability(newStateId, probability);
@ -185,7 +188,14 @@ namespace storm {
state->getFailableElements().next(); state->getFailableElements().next();
} // end while failing BE } // end while failing BE
if (!hasDependencies) {
if (exploreDependencies) {
if (result.empty()) {
// Dependencies might have been prevented from sequence enforcer
// -> explore BEs now
return exploreState(stateToIdCallback, false);
}
} else {
STORM_LOG_ASSERT(choice.size() > 0, "No transitions were generated");
// Add all rates as one choice // Add all rates as one choice
result.addChoice(std::move(choice)); result.addChoice(std::move(choice));
} }

2
src/storm-dft/generator/DftNextStateGenerator.h

@ -44,6 +44,8 @@ namespace storm {
private: private:
StateBehavior<ValueType, StateType> exploreState(StateToIdCallback const& stateToIdCallback, bool exploreDependencies);
// The dft used for the generation of next states. // The dft used for the generation of next states.
storm::storage::DFT<ValueType> const& mDft; storm::storage::DFT<ValueType> const& mDft;

8
src/storm-dft/storage/dft/DFTState.cpp

@ -196,6 +196,7 @@ namespace storm {
return false; return false;
} }
bool addedFailableDependency = false;
for (auto dependency : mDft.getElement(id)->outgoingDependencies()) { for (auto dependency : mDft.getElement(id)->outgoingDependencies()) {
STORM_LOG_ASSERT(dependency->triggerEvent()->id() == id, "Ids do not match."); STORM_LOG_ASSERT(dependency->triggerEvent()->id() == id, "Ids do not match.");
assert(dependency->dependentEvents().size() == 1); assert(dependency->dependentEvents().size() == 1);
@ -203,9 +204,10 @@ namespace storm {
STORM_LOG_ASSERT(!isFailsafe(dependency->dependentEvents()[0]->id()), "Dependent event is failsafe."); STORM_LOG_ASSERT(!isFailsafe(dependency->dependentEvents()[0]->id()), "Dependent event is failsafe.");
failableElements.addDependency(dependency->id()); failableElements.addDependency(dependency->id());
STORM_LOG_TRACE("New dependency failure: " << dependency->toString()); STORM_LOG_TRACE("New dependency failure: " << dependency->toString());
addedFailableDependency = true;
} }
} }
return failableElements.hasDependencies();
return addedFailableDependency;
} }
template<typename ValueType> template<typename ValueType>
@ -235,9 +237,9 @@ namespace storm {
} }
template<typename ValueType> template<typename ValueType>
std::pair<std::shared_ptr<DFTBE<ValueType> const>, bool> DFTState<ValueType>::letNextBEFail(size_t id) {
std::pair<std::shared_ptr<DFTBE<ValueType> const>, bool> DFTState<ValueType>::letNextBEFail(size_t id, bool dueToDependency) {
STORM_LOG_TRACE("currently failable: " << getCurrentlyFailableString()); STORM_LOG_TRACE("currently failable: " << getCurrentlyFailableString());
if (failableElements.hasDependencies()) {
if (dueToDependency) {
// Consider failure due to dependency // Consider failure due to dependency
std::shared_ptr<DFTDependency<ValueType> const> dependency = mDft.getDependency(id); std::shared_ptr<DFTDependency<ValueType> const> dependency = mDft.getDependency(id);
STORM_LOG_ASSERT(dependency->dependentEvents().size() == 1, "More than one dependent event"); STORM_LOG_ASSERT(dependency->dependentEvents().size() == 1, "More than one dependent event");

3
src/storm-dft/storage/dft/DFTState.h

@ -299,9 +299,10 @@ namespace storm {
/** /**
* Sets the next BE as failed * Sets the next BE as failed
* @param index Index in currentlyFailableBE of BE to fail * @param index Index in currentlyFailableBE of BE to fail
* @param dueToDependency Whether the failure is due to a dependency.
* @return Pair of BE which fails and flag indicating if the failure was due to functional dependencies * @return Pair of BE which fails and flag indicating if the failure was due to functional dependencies
*/ */
std::pair<std::shared_ptr<DFTBE<ValueType> const>, bool> letNextBEFail(size_t index = 0);
std::pair<std::shared_ptr<DFTBE<ValueType> const>, bool> letNextBEFail(size_t index, bool dueToDependency);
/** /**
* Sets the dependency as unsuccesful meaning no BE will fail. * Sets the dependency as unsuccesful meaning no BE will fail.

Loading…
Cancel
Save