From 7e1f5bf2ac742ac090b7d3e9c7dd00692b644cea Mon Sep 17 00:00:00 2001 From: Matthias Volk Date: Mon, 20 Apr 2020 20:36:06 +0200 Subject: [PATCH] Fixed handling of constant BE in approximation --- .../builder/ExplicitDFTModelBuilder.cpp | 38 +++++++++---------- 1 file changed, 18 insertions(+), 20 deletions(-) diff --git a/src/storm-dft/builder/ExplicitDFTModelBuilder.cpp b/src/storm-dft/builder/ExplicitDFTModelBuilder.cpp index a1bd445d4..1f5f3c18f 100644 --- a/src/storm-dft/builder/ExplicitDFTModelBuilder.cpp +++ b/src/storm-dft/builder/ExplicitDFTModelBuilder.cpp @@ -745,37 +745,35 @@ namespace storm { storm::storage::BitVector coldBEs(subtree.size(), false); for (size_t i = 0; i < subtree.size(); ++i) { size_t id = subtree[i]; + // Consider only still operational BEs if (state->isOperational(id)) { - // Get BE rate - ValueType rate = state->getBERate(id); - if (storm::utility::isZero(rate)) { - // Get active failure rate for cold BE - auto be = dft.getBasicElement(id); - switch (be->type()) { - case storm::storage::DFTElementType::BE_EXP: - { + auto be = dft.getBasicElement(id); + switch (be->type()) { + case storm::storage::DFTElementType::BE_EXP: + { + // Get BE rate + ValueType rate = state->getBERate(id); + if (storm::utility::isZero(rate)) { + // Get active failure rate for cold BE auto beExp = std::static_pointer_cast const>(be); rate = beExp->activeFailureRate(); STORM_LOG_ASSERT(!storm::utility::isZero(rate), "Failure rate should not be zero."); // Mark BE as cold coldBEs.set(i, true); - break; } - case storm::storage::DFTElementType::BE_CONST: - { - // Ignore BE which cannot fail - continue; - } - default: - STORM_LOG_THROW(false, storm::exceptions::InvalidArgumentException, "BE of type '" << be->type() << "' is not known."); - break; + rates.push_back(rate); + rateSum += rate; + break; } + case storm::storage::DFTElementType::BE_CONST: + // Ignore BE which cannot fail + continue; + default: + STORM_LOG_THROW(false, storm::exceptions::InvalidArgumentException, "BE of type '" << be->type() << "' is not known."); + break; } - rates.push_back(rate); - rateSum += rate; } } - STORM_LOG_ASSERT(rates.size() > 0, "No rates failable"); // Sort rates