diff --git a/src/storm-counterexamples/counterexamples/SMTMinimalLabelSetGenerator.h b/src/storm-counterexamples/counterexamples/SMTMinimalLabelSetGenerator.h index 4d4dd9629..64be9e83d 100644 --- a/src/storm-counterexamples/counterexamples/SMTMinimalLabelSetGenerator.h +++ b/src/storm-counterexamples/counterexamples/SMTMinimalLabelSetGenerator.h @@ -1506,9 +1506,9 @@ namespace storm { * Also returns the Labelsets of the sub-model. */ static std::pair>, std::vector>> restrictModelToLabelSet(storm::models::sparse::Model const& model, storm::storage::FlatSet const& filterLabelSet, boost::optional absorbState = boost::none) { - bool customRowGrouping = model.isOfType(storm::models::ModelType::Mdp); - + STORM_LOG_TRACE("Restrict model to label set " << storm::storage::toString(filterLabelSet)); + std::vector> resultLabelSet; storm::storage::SparseMatrixBuilder transitionMatrixBuilder(0, model.getTransitionMatrix().getColumnCount(), 0, true, customRowGrouping, model.getTransitionMatrix().getRowGroupCount()); @@ -1522,6 +1522,8 @@ namespace storm { // If the choice is valid, copy over all its elements. if (choiceValid) { + STORM_LOG_TRACE("Choice " << choice << " has a valid label set " << storm::storage::toString(choiceLabelSet)); + if (!stateHasValidChoice && customRowGrouping) { transitionMatrixBuilder.newRowGroup(currentRow); } @@ -1563,14 +1565,16 @@ namespace storm { std::vector allStatesResult; - STORM_LOG_DEBUG("Invoking model checker."); + STORM_LOG_DEBUG("Invoking model checker on model with " << model.getNumberOfStates() << " states and " << model.getNumberOfTransitions() << " transitions."); if (model.isOfType(storm::models::ModelType::Dtmc)) { if (rewardName == boost::none) { results.push_back(storm::utility::zero()); allStatesResult = storm::modelchecker::helper::SparseDtmcPrctlHelper::computeUntilProbabilities(env, false, model.getTransitionMatrix(), model.getBackwardTransitions(), phiStates, psiStates, false); for (auto state : model.getInitialStates()) { + STORM_LOG_TRACE("Found probability " << allStatesResult[state]); results.back() = std::max(results.back(), allStatesResult[state]); } + STORM_LOG_TRACE("Final probability " << results.back()); } else { for (auto const &rewName : rewardName.get()) { results.push_back(storm::utility::zero());