|
@ -745,37 +745,35 @@ namespace storm { |
|
|
storm::storage::BitVector coldBEs(subtree.size(), false); |
|
|
storm::storage::BitVector coldBEs(subtree.size(), false); |
|
|
for (size_t i = 0; i < subtree.size(); ++i) { |
|
|
for (size_t i = 0; i < subtree.size(); ++i) { |
|
|
size_t id = subtree[i]; |
|
|
size_t id = subtree[i]; |
|
|
|
|
|
// Consider only still operational BEs
|
|
|
if (state->isOperational(id)) { |
|
|
if (state->isOperational(id)) { |
|
|
// Get BE rate
|
|
|
|
|
|
ValueType rate = state->getBERate(id); |
|
|
|
|
|
if (storm::utility::isZero<ValueType>(rate)) { |
|
|
|
|
|
// Get active failure rate for cold BE
|
|
|
|
|
|
auto be = dft.getBasicElement(id); |
|
|
auto be = dft.getBasicElement(id); |
|
|
switch (be->type()) { |
|
|
switch (be->type()) { |
|
|
case storm::storage::DFTElementType::BE_EXP: |
|
|
case storm::storage::DFTElementType::BE_EXP: |
|
|
{ |
|
|
{ |
|
|
|
|
|
// Get BE rate
|
|
|
|
|
|
ValueType rate = state->getBERate(id); |
|
|
|
|
|
if (storm::utility::isZero<ValueType>(rate)) { |
|
|
|
|
|
// Get active failure rate for cold BE
|
|
|
auto beExp = std::static_pointer_cast<storm::storage::BEExponential<ValueType> const>(be); |
|
|
auto beExp = std::static_pointer_cast<storm::storage::BEExponential<ValueType> const>(be); |
|
|
rate = beExp->activeFailureRate(); |
|
|
rate = beExp->activeFailureRate(); |
|
|
STORM_LOG_ASSERT(!storm::utility::isZero<ValueType>(rate), "Failure rate should not be zero."); |
|
|
STORM_LOG_ASSERT(!storm::utility::isZero<ValueType>(rate), "Failure rate should not be zero."); |
|
|
// Mark BE as cold
|
|
|
// Mark BE as cold
|
|
|
coldBEs.set(i, true); |
|
|
coldBEs.set(i, true); |
|
|
|
|
|
} |
|
|
|
|
|
rates.push_back(rate); |
|
|
|
|
|
rateSum += rate; |
|
|
break; |
|
|
break; |
|
|
} |
|
|
} |
|
|
case storm::storage::DFTElementType::BE_CONST: |
|
|
case storm::storage::DFTElementType::BE_CONST: |
|
|
{ |
|
|
|
|
|
// Ignore BE which cannot fail
|
|
|
// Ignore BE which cannot fail
|
|
|
continue; |
|
|
continue; |
|
|
} |
|
|
|
|
|
default: |
|
|
default: |
|
|
STORM_LOG_THROW(false, storm::exceptions::InvalidArgumentException, "BE of type '" << be->type() << "' is not known."); |
|
|
STORM_LOG_THROW(false, storm::exceptions::InvalidArgumentException, "BE of type '" << be->type() << "' is not known."); |
|
|
break; |
|
|
break; |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
rates.push_back(rate); |
|
|
|
|
|
rateSum += rate; |
|
|
|
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
STORM_LOG_ASSERT(rates.size() > 0, "No rates failable"); |
|
|
STORM_LOG_ASSERT(rates.size() > 0, "No rates failable"); |
|
|
|
|
|
|
|
|
// Sort rates
|
|
|
// Sort rates
|
|
|