diff --git a/src/storage/dft/DFTState.cpp b/src/storage/dft/DFTState.cpp index b1c9a4fc1..25edf1d38 100644 --- a/src/storage/dft/DFTState.cpp +++ b/src/storage/dft/DFTState.cpp @@ -21,6 +21,7 @@ namespace storm { std::vector alwaysActiveBEs = dft.nonColdBEs(); mIsCurrentlyFailableBE.insert(mIsCurrentlyFailableBE.end(), alwaysActiveBEs.begin(), alwaysActiveBEs.end()); + sortFailableBEs(); } template @@ -41,6 +42,7 @@ namespace storm { STORM_LOG_TRACE("Spare " << index << " uses " << useId); } } + sortFailableBEs(); // Initialize failable dependencies for (size_t dependencyId : mDft.getDependencies()) { @@ -208,7 +210,7 @@ namespace storm { if (nrFailableDependencies() > 0) { // Consider failure due to dependency assert(index < nrFailableDependencies()); - std::shared_ptr const> dependency = mDft.getDependency(getDependencyId(index)); + std::shared_ptr const> dependency = mDft.getDependency(mFailableDependencies[index]); std::pair const>,bool> res(mDft.getBasicElement(dependency->dependentEvent()->id()), true); mFailableDependencies.erase(mFailableDependencies.begin() + index); setFailed(res.first->id()); @@ -260,6 +262,7 @@ namespace storm { propagateActivation(uses(elem)); } } + sortFailableBEs(); } template @@ -354,6 +357,16 @@ namespace storm { } return changed; } + + template + void DFTState::sortFailableBEs() { + std::sort( mIsCurrentlyFailableBE.begin( ), mIsCurrentlyFailableBE.end( ), [&](size_t const& lhs, size_t const& rhs) { + ValueType leftRate = mDft.getBasicElement(lhs)->activeFailureRate(); + ValueType rightRate = mDft.getBasicElement(rhs)->activeFailureRate(); + // Sort decreasing + return rightRate < leftRate; + }); + } // Explicitly instantiate the class. diff --git a/src/storage/dft/DFTState.h b/src/storage/dft/DFTState.h index 5b68d46ae..f647aae17 100644 --- a/src/storage/dft/DFTState.h +++ b/src/storage/dft/DFTState.h @@ -235,6 +235,11 @@ namespace storm { private: void propagateActivation(size_t representativeId); + + /*! + * Sort failable BEs in decreasing order of their active failure rate. + */ + void sortFailableBEs(); };