Browse Source

Typos

tempestpy_adaptions
Matthias Volk 7 years ago
parent
commit
ec411ffc78
  1. 6
      src/storm-dft/modelchecker/dft/DFTModelChecker.cpp
  2. 29
      src/storm-dft/storage/dft/DFT.cpp
  3. 14
      src/storm/models/sparse/MarkovAutomaton.cpp

6
src/storm-dft/modelchecker/dft/DFTModelChecker.cpp

@ -54,14 +54,14 @@ namespace storm {
case storm::storage::DFTElementType::AND: case storm::storage::DFTElementType::AND:
STORM_LOG_TRACE("top modularisation called AND"); STORM_LOG_TRACE("top modularisation called AND");
dfts = dft.topModularisation(); dfts = dft.topModularisation();
STORM_LOG_TRACE("Modularsation into " << dfts.size() << " submodules.");
STORM_LOG_TRACE("Modularisation into " << dfts.size() << " submodules.");
nrK = dfts.size(); nrK = dfts.size();
nrM = dfts.size(); nrM = dfts.size();
break; break;
case storm::storage::DFTElementType::OR: case storm::storage::DFTElementType::OR:
STORM_LOG_TRACE("top modularisation called OR"); STORM_LOG_TRACE("top modularisation called OR");
dfts = dft.topModularisation(); dfts = dft.topModularisation();
STORM_LOG_TRACE("Modularsation into " << dfts.size() << " submodules.");
STORM_LOG_TRACE("Modularisation into " << dfts.size() << " submodules.");
nrK = 0; nrK = 0;
nrM = dfts.size(); nrM = dfts.size();
invResults = true; invResults = true;
@ -69,7 +69,7 @@ namespace storm {
case storm::storage::DFTElementType::VOT: case storm::storage::DFTElementType::VOT:
STORM_LOG_TRACE("top modularisation called VOT"); STORM_LOG_TRACE("top modularisation called VOT");
dfts = dft.topModularisation(); dfts = dft.topModularisation();
STORM_LOG_TRACE("Modularsation into " << dfts.size() << " submodules.");
STORM_LOG_TRACE("Modularisation into " << dfts.size() << " submodules.");
nrK = std::static_pointer_cast<storm::storage::DFTVot<ValueType> const>(dft.getTopLevelGate())->threshold(); nrK = std::static_pointer_cast<storm::storage::DFTVot<ValueType> const>(dft.getTopLevelGate())->threshold();
nrM = dfts.size(); nrM = dfts.size();
if(nrK <= nrM/2) { if(nrK <= nrM/2) {

29
src/storm-dft/storage/dft/DFT.cpp

@ -293,22 +293,22 @@ namespace storm {
} }
return max; return max;
} }
template<typename ValueType> template<typename ValueType>
DFT<ValueType> DFT<ValueType>::optimize() const { DFT<ValueType> DFT<ValueType>::optimize() const {
std::vector<size_t> modIdea = findModularisationRewrite(); std::vector<size_t> modIdea = findModularisationRewrite();
STORM_LOG_DEBUG("Modularisation idea: " << storm::utility::vector::toString(modIdea)); STORM_LOG_DEBUG("Modularisation idea: " << storm::utility::vector::toString(modIdea));
if (modIdea.empty()) { if (modIdea.empty()) {
// No rewrite needed // No rewrite needed
return *this; return *this;
} }
std::vector<std::vector<size_t>> rewriteIds; std::vector<std::vector<size_t>> rewriteIds;
rewriteIds.push_back(modIdea); rewriteIds.push_back(modIdea);
storm::builder::DFTBuilder<ValueType> builder; storm::builder::DFTBuilder<ValueType> builder;
// Accumulate elements which must be rewritten // Accumulate elements which must be rewritten
std::set<size_t> rewriteSet; std::set<size_t> rewriteSet;
for (std::vector<size_t> rewrites : rewriteIds) { for (std::vector<size_t> rewrites : rewriteIds) {
@ -320,7 +320,7 @@ namespace storm {
builder.copyElement(elem); builder.copyElement(elem);
} }
} }
// Add rewritten elements // Add rewritten elements
for (std::vector<size_t> rewrites : rewriteIds) { for (std::vector<size_t> rewrites : rewriteIds) {
STORM_LOG_ASSERT(rewrites.size() > 1, "No rewritten elements."); STORM_LOG_ASSERT(rewrites.size() > 1, "No rewritten elements.");
@ -359,7 +359,7 @@ namespace storm {
STORM_LOG_ASSERT(false, "Dft type can not be rewritten."); STORM_LOG_ASSERT(false, "Dft type can not be rewritten.");
break; break;
} }
// Add parent with the new child newParent and all its remaining children // Add parent with the new child newParent and all its remaining children
childrenNames.clear(); childrenNames.clear();
childrenNames.push_back(newParentName); childrenNames.push_back(newParentName);
@ -371,7 +371,7 @@ namespace storm {
} }
builder.copyGate(originalParent, childrenNames); builder.copyGate(originalParent, childrenNames);
} }
builder.setTopLevel(mElements[mTopLevelIndex]->name()); builder.setTopLevel(mElements[mTopLevelIndex]->name());
// TODO use reference? // TODO use reference?
DFT<ValueType> newDft = builder.build(); DFT<ValueType> newDft = builder.build();
@ -750,11 +750,10 @@ namespace storm {
// suitable parent gate! - Lets check the independent submodules of the children // suitable parent gate! - Lets check the independent submodules of the children
auto const& children = std::static_pointer_cast<DFTGate<ValueType>>(e)->children(); auto const& children = std::static_pointer_cast<DFTGate<ValueType>>(e)->children();
for(auto const& child : children) { for(auto const& child : children) {
auto ISD = std::static_pointer_cast<DFTGate<ValueType>>(child)->independentSubDft(true); auto ISD = std::static_pointer_cast<DFTGate<ValueType>>(child)->independentSubDft(true);
// In the ISD, check for other children: // In the ISD, check for other children:
std::vector<size_t> rewrite = {e->id(), child->id()}; std::vector<size_t> rewrite = {e->id(), child->id()};
for(size_t isdElemId : ISD) { for(size_t isdElemId : ISD) {
if(isdElemId == child->id()) continue; if(isdElemId == child->id()) continue;
@ -765,13 +764,13 @@ namespace storm {
if(rewrite.size() > 2 && rewrite.size() < children.size() - 1) { if(rewrite.size() > 2 && rewrite.size() < children.size() - 1) {
return rewrite; return rewrite;
} }
}
}
} }
}
}
return {}; return {};
} }
template<typename ValueType> template<typename ValueType>
std::tuple<std::vector<size_t>, std::vector<size_t>, std::vector<size_t>> DFT<ValueType>::getSortedParentAndDependencyIds(size_t index) const { std::tuple<std::vector<size_t>, std::vector<size_t>, std::vector<size_t>> DFT<ValueType>::getSortedParentAndDependencyIds(size_t index) const {

14
src/storm/models/sparse/MarkovAutomaton.cpp

@ -181,7 +181,7 @@ namespace storm {
// Get number of choices in current state // Get number of choices in current state
uint_fast64_t numberChoices = this->getTransitionMatrix().getRowGroupIndices()[state + 1] - this->getTransitionMatrix().getRowGroupIndices()[state]; uint_fast64_t numberChoices = this->getTransitionMatrix().getRowGroupIndices()[state + 1] - this->getTransitionMatrix().getRowGroupIndices()[state];
if (isMarkovianState(state)) { if (isMarkovianState(state)) {
STORM_LOG_ASSERT(numberChoices == 1, "Wrong number of choices for markovian state.");
STORM_LOG_ASSERT(numberChoices == 1, "Wrong number of choices for Markovian state.");
} }
if (numberChoices > 1) { if (numberChoices > 1) {
STORM_LOG_ASSERT(isProbabilisticState(state), "State is not probabilistic."); STORM_LOG_ASSERT(isProbabilisticState(state), "State is not probabilistic.");
@ -211,7 +211,7 @@ namespace storm {
storm::storage::FlexibleSparseMatrix<ValueType> flexibleMatrix(this->getTransitionMatrix()); storm::storage::FlexibleSparseMatrix<ValueType> flexibleMatrix(this->getTransitionMatrix());
storm::storage::FlexibleSparseMatrix<ValueType> flexibleBackwardTransitions(this->getTransitionMatrix().transpose()); storm::storage::FlexibleSparseMatrix<ValueType> flexibleBackwardTransitions(this->getTransitionMatrix().transpose());
storm::solver::stateelimination::StateEliminator<ValueType> stateEliminator(flexibleMatrix, flexibleBackwardTransitions); storm::solver::stateelimination::StateEliminator<ValueType> stateEliminator(flexibleMatrix, flexibleBackwardTransitions);
for (uint_fast64_t state = 0; state < this->getNumberOfStates(); ++state) { for (uint_fast64_t state = 0; state < this->getNumberOfStates(); ++state) {
STORM_LOG_ASSERT(!this->isHybridState(state), "State is hybrid."); STORM_LOG_ASSERT(!this->isHybridState(state), "State is hybrid.");
if (this->isProbabilisticState(state)) { if (this->isProbabilisticState(state)) {
@ -220,7 +220,7 @@ namespace storm {
STORM_LOG_TRACE("Flexible matrix after eliminating state " << state << ":" << std::endl << flexibleMatrix); STORM_LOG_TRACE("Flexible matrix after eliminating state " << state << ":" << std::endl << flexibleMatrix);
} }
} }
// Create the rate matrix for the CTMC // Create the rate matrix for the CTMC
storm::storage::SparseMatrixBuilder<ValueType> transitionMatrixBuilder(0, 0, 0, false, false); storm::storage::SparseMatrixBuilder<ValueType> transitionMatrixBuilder(0, 0, 0, false, false);
// Remember state to keep // Remember state to keep
@ -230,7 +230,7 @@ namespace storm {
// State is eliminated and can be discarded // State is eliminated and can be discarded
keepStates.set(state, false); keepStates.set(state, false);
} else { } else {
STORM_LOG_ASSERT(this->isMarkovianState(state), "State is not markovian.");
STORM_LOG_ASSERT(this->isMarkovianState(state), "State is not Markovian.");
// Copy transitions // Copy transitions
for (uint_fast64_t row = flexibleMatrix.getRowGroupIndices()[state]; row < flexibleMatrix.getRowGroupIndices()[state + 1]; ++row) { for (uint_fast64_t row = flexibleMatrix.getRowGroupIndices()[state]; row < flexibleMatrix.getRowGroupIndices()[state + 1]; ++row) {
for (auto const& entry : flexibleMatrix.getRow(row)) { for (auto const& entry : flexibleMatrix.getRow(row)) {
@ -240,20 +240,20 @@ namespace storm {
} }
} }
} }
storm::storage::SparseMatrix<ValueType> rateMatrix = transitionMatrixBuilder.build(); storm::storage::SparseMatrix<ValueType> rateMatrix = transitionMatrixBuilder.build();
rateMatrix = rateMatrix.getSubmatrix(false, keepStates, keepStates, false); rateMatrix = rateMatrix.getSubmatrix(false, keepStates, keepStates, false);
STORM_LOG_TRACE("New CTMC matrix:" << std::endl << rateMatrix); STORM_LOG_TRACE("New CTMC matrix:" << std::endl << rateMatrix);
// Construct CTMC // Construct CTMC
storm::models::sparse::StateLabeling stateLabeling = this->getStateLabeling().getSubLabeling(keepStates); storm::models::sparse::StateLabeling stateLabeling = this->getStateLabeling().getSubLabeling(keepStates);
//TODO update reward models and choice labels according to kept states //TODO update reward models and choice labels according to kept states
STORM_LOG_WARN_COND(this->getRewardModels().empty(), "Conversion of MA to CTMC does not preserve rewards."); STORM_LOG_WARN_COND(this->getRewardModels().empty(), "Conversion of MA to CTMC does not preserve rewards.");
std::unordered_map<std::string, RewardModelType> rewardModels = this->getRewardModels(); std::unordered_map<std::string, RewardModelType> rewardModels = this->getRewardModels();
STORM_LOG_WARN_COND(!this->hasChoiceLabeling(), "Conversion of MA to CTMC does not preserve choice labels."); STORM_LOG_WARN_COND(!this->hasChoiceLabeling(), "Conversion of MA to CTMC does not preserve choice labels.");
STORM_LOG_WARN_COND(!this->hasStateValuations(), "Conversion of MA to CTMC does not preserve choice labels."); STORM_LOG_WARN_COND(!this->hasStateValuations(), "Conversion of MA to CTMC does not preserve choice labels.");
STORM_LOG_WARN_COND(!this->hasChoiceOrigins(), "Conversion of MA to CTMC does not preserve choice labels."); STORM_LOG_WARN_COND(!this->hasChoiceOrigins(), "Conversion of MA to CTMC does not preserve choice labels.");
return std::make_shared<storm::models::sparse::Ctmc<ValueType, RewardModelType>>(std::move(rateMatrix), std::move(stateLabeling), std::move(rewardModels)); return std::make_shared<storm::models::sparse::Ctmc<ValueType, RewardModelType>>(std::move(rateMatrix), std::move(stateLabeling), std::move(rewardModels));
} }

Loading…
Cancel
Save