@ -206,7 +206,7 @@ namespace {
TYPED_TEST ( SchedulerGenerationMdpPrctlModelCheckerTest , ltl ) {
TYPED_TEST ( SchedulerGenerationMdpPrctlModelCheckerTest , ltl ) {
typedef typename TestFixture : : ValueType ValueType ;
typedef typename TestFixture : : ValueType ValueType ;
std : : string formulasString = " Pmax=? [X X \" target \" ]; Pmin=? [G F \" target \" ]; " ;
std : : string formulasString = " Pmax=? [X X \" target \" ]; Pmin=? [G F \" target \" ]; Pmax=? [(G F s>2) & (F G (!s=3))]; " ;
auto modelFormulas = this - > buildModelFormulas ( STORM_TEST_RESOURCES_DIR " /mdp/scheduler_generation.nm " , formulasString ) ;
auto modelFormulas = this - > buildModelFormulas ( STORM_TEST_RESOURCES_DIR " /mdp/scheduler_generation.nm " , formulasString ) ;
auto mdp = std : : move ( modelFormulas . first ) ;
auto mdp = std : : move ( modelFormulas . first ) ;
auto tasks = this - > getTasks ( modelFormulas . second ) ;
auto tasks = this - > getTasks ( modelFormulas . second ) ;
@ -228,7 +228,7 @@ namespace {
EXPECT_TRUE ( scheduler . isPartialScheduler ( ) ) ;
EXPECT_TRUE ( scheduler . isPartialScheduler ( ) ) ;
auto inducedModel = mdp - > applyScheduler ( scheduler ) ;
auto inducedModel = mdp - > applyScheduler ( scheduler ) ;
ASSERT_EQ ( inducedModel - > getType ( ) , storm : : models : : ModelType : : Mdp ) ;
ASSERT_EQ ( inducedModel - > getType ( ) , storm : : models : : ModelType : : Mdp ) ;
auto const & inducedMdp = inducedModel - > template as < storm : : models : : sparse : : Mdp < ValueType > > ( ) ;
auto const & inducedMdp = inducedModel - > template as < storm : : models : : sparse : : Mdp < ValueType > > ( ) ; // TODO DTMC!
EXPECT_EQ ( inducedMdp - > getNumberOfChoices ( ) , inducedMdp - > getNumberOfStates ( ) ) ;
EXPECT_EQ ( inducedMdp - > getNumberOfChoices ( ) , inducedMdp - > getNumberOfStates ( ) ) ;
storm : : modelchecker : : SparseMdpPrctlModelChecker < storm : : models : : sparse : : Mdp < ValueType > > inducedChecker ( * inducedMdp ) ;
storm : : modelchecker : : SparseMdpPrctlModelChecker < storm : : models : : sparse : : Mdp < ValueType > > inducedChecker ( * inducedMdp ) ;
auto inducedResult = inducedChecker . check ( this - > env ( ) , tasks [ 0 ] ) ;
auto inducedResult = inducedChecker . check ( this - > env ( ) , tasks [ 0 ] ) ;
@ -253,6 +253,26 @@ namespace {
ASSERT_TRUE ( inducedResult - > isExplicitQuantitativeCheckResult ( ) ) ;
ASSERT_TRUE ( inducedResult - > isExplicitQuantitativeCheckResult ( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 1/2 " ) , inducedResult - > template asExplicitQuantitativeCheckResult < ValueType > ( ) [ * mdp - > getInitialStates ( ) . begin ( ) ] , storm : : settings : : getModule < storm : : settings : : modules : : GeneralSettings > ( ) . getPrecision ( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 1/2 " ) , inducedResult - > template asExplicitQuantitativeCheckResult < ValueType > ( ) [ * mdp - > getInitialStates ( ) . begin ( ) ] , storm : : settings : : getModule < storm : : settings : : modules : : GeneralSettings > ( ) . getPrecision ( ) ) ;
}
}
{
auto result = checker . check ( this - > env ( ) , tasks [ 2 ] ) ;
EXPECT_NEAR ( this - > parseNumber ( " 1/2 " ) , result - > template asExplicitQuantitativeCheckResult < ValueType > ( ) [ * mdp - > getInitialStates ( ) . begin ( ) ] , storm : : settings : : getModule < storm : : settings : : modules : : GeneralSettings > ( ) . getPrecision ( ) ) ;
ASSERT_TRUE ( result - > isExplicitQuantitativeCheckResult ( ) ) ;
ASSERT_TRUE ( result - > template asExplicitQuantitativeCheckResult < ValueType > ( ) . hasScheduler ( ) ) ;
storm : : storage : : Scheduler < ValueType > const & scheduler = result - > template asExplicitQuantitativeCheckResult < ValueType > ( ) . getScheduler ( ) ;
EXPECT_TRUE ( scheduler . isDeterministicScheduler ( ) ) ;
EXPECT_TRUE ( ! scheduler . isMemorylessScheduler ( ) ) ;
EXPECT_TRUE ( scheduler . isPartialScheduler ( ) ) ;
auto inducedModel = mdp - > applyScheduler ( scheduler ) ;
ASSERT_EQ ( inducedModel - > getType ( ) , storm : : models : : ModelType : : Mdp ) ;
auto const & inducedMdp = inducedModel - > template as < storm : : models : : sparse : : Mdp < ValueType > > ( ) ;
EXPECT_EQ ( inducedMdp - > getNumberOfChoices ( ) , inducedMdp - > getNumberOfStates ( ) ) ;
storm : : modelchecker : : SparseMdpPrctlModelChecker < storm : : models : : sparse : : Mdp < ValueType > > inducedChecker ( * inducedMdp ) ;
auto inducedResult = inducedChecker . check ( this - > env ( ) , tasks [ 2 ] ) ;
ASSERT_TRUE ( inducedResult - > isExplicitQuantitativeCheckResult ( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 1/2 " ) , inducedResult - > template asExplicitQuantitativeCheckResult < ValueType > ( ) [ * mdp - > getInitialStates ( ) . begin ( ) ] , storm : : settings : : getModule < storm : : settings : : modules : : GeneralSettings > ( ) . getPrecision ( ) ) ;
}
}
}
}
}