@ -157,7 +157,6 @@ namespace storm {
std : : size_t accMECs = 0 ;
std : : size_t accMECs = 0 ;
std : : size_t allMECs = 0 ;
std : : size_t allMECs = 0 ;
std : : size_t i = 0 ;
if ( this - > isProduceSchedulerSet ( ) ) {
if ( this - > isProduceSchedulerSet ( ) ) {
_infSets . emplace ( ) ;
_infSets . emplace ( ) ;
@ -169,10 +168,7 @@ namespace storm {
// Determine the set of states of the subMDP that can satisfy the condition, remove all states that would violate Fins in the conjunction.
// Determine the set of states of the subMDP that can satisfy the condition, remove all states that would violate Fins in the conjunction.
storm : : storage : : BitVector allowed ( transitionMatrix . getRowGroupCount ( ) , true ) ;
storm : : storage : : BitVector allowed ( transitionMatrix . getRowGroupCount ( ) , true ) ;
STORM_LOG_INFO ( " Handle conjunction " < < i ) ;
for ( auto const & literal : conjunction ) {
for ( auto const & literal : conjunction ) {
STORM_LOG_INFO ( " " < < * literal ) ;
if ( literal - > isTRUE ( ) ) {
if ( literal - > isTRUE ( ) ) {
// skip
// skip
} else if ( literal - > isFALSE ( ) ) {
} else if ( literal - > isFALSE ( ) ) {
@ -199,13 +195,10 @@ namespace storm {
continue ;
continue ;
}
}
STORM_LOG_DEBUG ( " Allowed states: " < < allowed ) ;
// Compute MECs in the allowed fragment
// Compute MECs in the allowed fragment
storm : : storage : : MaximalEndComponentDecomposition < ValueType > mecs ( transitionMatrix , backwardTransitions , allowed ) ;
storm : : storage : : MaximalEndComponentDecomposition < ValueType > mecs ( transitionMatrix , backwardTransitions , allowed ) ;
allMECs + = mecs . size ( ) ;
allMECs + = mecs . size ( ) ;
for ( const auto & mec : mecs ) {
for ( const auto & mec : mecs ) {
STORM_LOG_DEBUG ( " Inspect MEC: " < < mec ) ;
bool accepting = true ;
bool accepting = true ;
for ( auto const & literal : conjunction ) {
for ( auto const & literal : conjunction ) {
@ -220,17 +213,12 @@ namespace storm {
const storm : : storage : : BitVector & accSet = acceptance . getAcceptanceSet ( atom . getAcceptanceSet ( ) ) ;
const storm : : storage : : BitVector & accSet = acceptance . getAcceptanceSet ( atom . getAcceptanceSet ( ) ) ;
if ( atom . getType ( ) = = cpphoafparser : : AtomAcceptance : : TEMPORAL_INF ) {
if ( atom . getType ( ) = = cpphoafparser : : AtomAcceptance : : TEMPORAL_INF ) {
if ( atom . isNegated ( ) ) {
if ( atom . isNegated ( ) ) {
STORM_LOG_DEBUG ( " Checking against " < < ~ accSet ) ;
if ( ! mec . containsAnyState ( ~ accSet ) ) {
if ( ! mec . containsAnyState ( ~ accSet ) ) {
STORM_LOG_DEBUG ( " -> not satisfied " ) ;
accepting = false ;
accepting = false ;
break ;
break ;
}
}
} else {
} else {
STORM_LOG_DEBUG ( " Checking against " < < accSet ) ;
if ( ! mec . containsAnyState ( accSet ) ) {
if ( ! mec . containsAnyState ( accSet ) ) {
STORM_LOG_DEBUG ( " -> not satisfied " ) ;
accepting = false ;
accepting = false ;
break ;
break ;
}
}
@ -246,7 +234,6 @@ namespace storm {
if ( accepting ) {
if ( accepting ) {
accMECs + + ;
accMECs + + ;
STORM_LOG_DEBUG ( " MEC is accepting " ) ;
for ( auto const & stateChoicePair : mec ) {
for ( auto const & stateChoicePair : mec ) {
acceptingStates . set ( stateChoicePair . first ) ;
acceptingStates . set ( stateChoicePair . first ) ;
@ -335,7 +322,6 @@ namespace storm {
}
}
}
}
STORM_LOG_DEBUG ( " Accepting states: " < < acceptingStates ) ;
STORM_LOG_INFO ( " Found " < < acceptingStates . getNumberOfSetBits ( ) < < " states in " < < accMECs < < " accepting MECs (considered " < < allMECs < < " MECs). " ) ;
STORM_LOG_INFO ( " Found " < < acceptingStates . getNumberOfSetBits ( ) < < " states in " < < accMECs < < " accepting MECs (considered " < < allMECs < < " MECs). " ) ;
return acceptingStates ;
return acceptingStates ;
@ -513,18 +499,6 @@ namespace storm {
STORM_LOG_INFO ( " Product " + ( Nondeterministic ? std : : string ( " MDP-DA " ) : std : : string ( " DTMC-DA " ) ) + " has " < < product - > getProductModel ( ) . getNumberOfStates ( ) < < " states and "
STORM_LOG_INFO ( " Product " + ( Nondeterministic ? std : : string ( " MDP-DA " ) : std : : string ( " DTMC-DA " ) ) + " has " < < product - > getProductModel ( ) . getNumberOfStates ( ) < < " states and "
< < product - > getProductModel ( ) . getNumberOfTransitions ( ) < < " transitions. " ) ;
< < product - > getProductModel ( ) . getNumberOfTransitions ( ) < < " transitions. " ) ;
if ( storm : : settings : : getModule < storm : : settings : : modules : : DebugSettings > ( ) . isTraceSet ( ) ) {
STORM_LOG_TRACE ( " Writing product model to product.dot " ) ;
std : : ofstream productDot ( " product.dot " ) ;
product - > getProductModel ( ) . writeDotToStream ( productDot ) ;
productDot . close ( ) ;
STORM_LOG_TRACE ( " Product model mapping: " ) ;
std : : stringstream str ;
product - > printMapping ( str ) ;
STORM_LOG_TRACE ( str . str ( ) ) ;
}
// Compute accepting states
// Compute accepting states
storm : : storage : : BitVector acceptingStates ;
storm : : storage : : BitVector acceptingStates ;
if ( Nondeterministic ) {
if ( Nondeterministic ) {