@ -7,164 +7,164 @@
TEST ( GmmxxMdpPrctModelCheckerTest , Dice ) {
TEST ( GmmxxMdpPrctModelCheckerTest , Dice ) {
storm : : settings : : Settings * s = storm : : settings : : instance ( ) ;
storm : : settings : : Settings * s = storm : : settings : : instance ( ) ;
storm : : parser : : AutoParser < double > parser ( STORM_CPP_TESTS_BASE_PATH " functional/modelchecker/two_dice/two_dice.tra " , STORM_CPP_TESTS_BASE_PATH " /functional/modelchecker/two_dice/two_dice.lab " , " " , STORM_CPP_TESTS_BASE_PATH " /functional/modelchecker/two_dice/two_dice.flip.trans.rew " ) ;
storm : : parser : : AutoParser < double > parser ( STORM_CPP_TESTS_BASE_PATH " / functional/modelchecker/two_dice/two_dice.tra" , STORM_CPP_TESTS_BASE_PATH " /functional/modelchecker/two_dice/two_dice.lab " , " " , STORM_CPP_TESTS_BASE_PATH " /functional/modelchecker/two_dice/two_dice.flip.trans.rew " ) ;
ASSERT_EQ ( parser . getType ( ) , storm : : models : : MDP ) ;
ASSERT_EQ ( parser . getType ( ) , storm : : models : : MDP ) ;
std : : shared_ptr < storm : : models : : Mdp < double > > mdp = parser . getModel < storm : : models : : Mdp < double > > ( ) ;
std : : shared_ptr < storm : : models : : Mdp < double > > mdp = parser . getModel < storm : : models : : Mdp < double > > ( ) ;
ASSERT_EQ ( mdp - > getNumberOfStates ( ) , 169u ) ;
ASSERT_EQ ( mdp - > getNumberOfStates ( ) , 169u ) ;
ASSERT_EQ ( mdp - > getNumberOfTransitions ( ) , 436u ) ;
ASSERT_EQ ( mdp - > getNumberOfTransitions ( ) , 436u ) ;
storm : : modelchecker : : GmmxxMdpPrctlModelChecker < double > mc ( * mdp ) ;
storm : : modelchecker : : GmmxxMdpPrctlModelChecker < double > mc ( * mdp ) ;
storm : : property : : prctl : : Ap < double > * apFormula = new storm : : property : : prctl : : Ap < double > ( " two " ) ;
storm : : property : : prctl : : Ap < double > * apFormula = new storm : : property : : prctl : : Ap < double > ( " two " ) ;
storm : : property : : prctl : : Eventually < double > * eventuallyFormula = new storm : : property : : prctl : : Eventually < double > ( apFormula ) ;
storm : : property : : prctl : : Eventually < double > * eventuallyFormula = new storm : : property : : prctl : : Eventually < double > ( apFormula ) ;
storm : : property : : prctl : : ProbabilisticNoBoundOperator < double > * probFormula = new storm : : property : : prctl : : ProbabilisticNoBoundOperator < double > ( eventuallyFormula , true ) ;
storm : : property : : prctl : : ProbabilisticNoBoundOperator < double > * probFormula = new storm : : property : : prctl : : ProbabilisticNoBoundOperator < double > ( eventuallyFormula , true ) ;
std : : vector < double > * result = mc . checkNoBoundOperator ( * probFormula ) ;
std : : vector < double > * result = mc . checkNoBoundOperator ( * probFormula ) ;
ASSERT_NE ( nullptr , result ) ;
ASSERT_NE ( nullptr , result ) ;
ASSERT_LT ( std : : abs ( ( * result ) [ 0 ] - 0.0277777612209320068 ) , s - > get < double > ( " precision " ) ) ;
ASSERT_LT ( std : : abs ( ( * result ) [ 0 ] - 0.0277777612209320068 ) , s - > get < double > ( " precision " ) ) ;
delete probFormula ;
delete probFormula ;
delete result ;
delete result ;
apFormula = new storm : : property : : prctl : : Ap < double > ( " two " ) ;
apFormula = new storm : : property : : prctl : : Ap < double > ( " two " ) ;
eventuallyFormula = new storm : : property : : prctl : : Eventually < double > ( apFormula ) ;
eventuallyFormula = new storm : : property : : prctl : : Eventually < double > ( apFormula ) ;
probFormula = new storm : : property : : prctl : : ProbabilisticNoBoundOperator < double > ( eventuallyFormula , false ) ;
probFormula = new storm : : property : : prctl : : ProbabilisticNoBoundOperator < double > ( eventuallyFormula , false ) ;
result = mc . checkNoBoundOperator ( * probFormula ) ;
result = mc . checkNoBoundOperator ( * probFormula ) ;
ASSERT_LT ( std : : abs ( ( * result ) [ 0 ] - 0.0277777612209320068 ) , s - > get < double > ( " precision " ) ) ;
ASSERT_LT ( std : : abs ( ( * result ) [ 0 ] - 0.0277777612209320068 ) , s - > get < double > ( " precision " ) ) ;
delete probFormula ;
delete probFormula ;
delete result ;
delete result ;
apFormula = new storm : : property : : prctl : : Ap < double > ( " three " ) ;
apFormula = new storm : : property : : prctl : : Ap < double > ( " three " ) ;
eventuallyFormula = new storm : : property : : prctl : : Eventually < double > ( apFormula ) ;
eventuallyFormula = new storm : : property : : prctl : : Eventually < double > ( apFormula ) ;
probFormula = new storm : : property : : prctl : : ProbabilisticNoBoundOperator < double > ( eventuallyFormula , true ) ;
probFormula = new storm : : property : : prctl : : ProbabilisticNoBoundOperator < double > ( eventuallyFormula , true ) ;
result = mc . checkNoBoundOperator ( * probFormula ) ;
result = mc . checkNoBoundOperator ( * probFormula ) ;
ASSERT_LT ( std : : abs ( ( * result ) [ 0 ] - 0.0555555224418640136 ) , s - > get < double > ( " precision " ) ) ;
ASSERT_LT ( std : : abs ( ( * result ) [ 0 ] - 0.0555555224418640136 ) , s - > get < double > ( " precision " ) ) ;
delete probFormula ;
delete probFormula ;
delete result ;
delete result ;
apFormula = new storm : : property : : prctl : : Ap < double > ( " three " ) ;
apFormula = new storm : : property : : prctl : : Ap < double > ( " three " ) ;
eventuallyFormula = new storm : : property : : prctl : : Eventually < double > ( apFormula ) ;
eventuallyFormula = new storm : : property : : prctl : : Eventually < double > ( apFormula ) ;
probFormula = new storm : : property : : prctl : : ProbabilisticNoBoundOperator < double > ( eventuallyFormula , false ) ;
probFormula = new storm : : property : : prctl : : ProbabilisticNoBoundOperator < double > ( eventuallyFormula , false ) ;
result = mc . checkNoBoundOperator ( * probFormula ) ;
result = mc . checkNoBoundOperator ( * probFormula ) ;
ASSERT_LT ( std : : abs ( ( * result ) [ 0 ] - 0.0555555224418640136 ) , s - > get < double > ( " precision " ) ) ;
ASSERT_LT ( std : : abs ( ( * result ) [ 0 ] - 0.0555555224418640136 ) , s - > get < double > ( " precision " ) ) ;
delete probFormula ;
delete probFormula ;
delete result ;
delete result ;
apFormula = new storm : : property : : prctl : : Ap < double > ( " four " ) ;
apFormula = new storm : : property : : prctl : : Ap < double > ( " four " ) ;
eventuallyFormula = new storm : : property : : prctl : : Eventually < double > ( apFormula ) ;
eventuallyFormula = new storm : : property : : prctl : : Eventually < double > ( apFormula ) ;
probFormula = new storm : : property : : prctl : : ProbabilisticNoBoundOperator < double > ( eventuallyFormula , true ) ;
probFormula = new storm : : property : : prctl : : ProbabilisticNoBoundOperator < double > ( eventuallyFormula , true ) ;
result = mc . checkNoBoundOperator ( * probFormula ) ;
result = mc . checkNoBoundOperator ( * probFormula ) ;
ASSERT_LT ( std : : abs ( ( * result ) [ 0 ] - 0.083333283662796020508 ) , s - > get < double > ( " precision " ) ) ;
ASSERT_LT ( std : : abs ( ( * result ) [ 0 ] - 0.083333283662796020508 ) , s - > get < double > ( " precision " ) ) ;
delete probFormula ;
delete probFormula ;
delete result ;
delete result ;
apFormula = new storm : : property : : prctl : : Ap < double > ( " four " ) ;
apFormula = new storm : : property : : prctl : : Ap < double > ( " four " ) ;
eventuallyFormula = new storm : : property : : prctl : : Eventually < double > ( apFormula ) ;
eventuallyFormula = new storm : : property : : prctl : : Eventually < double > ( apFormula ) ;
probFormula = new storm : : property : : prctl : : ProbabilisticNoBoundOperator < double > ( eventuallyFormula , false ) ;
probFormula = new storm : : property : : prctl : : ProbabilisticNoBoundOperator < double > ( eventuallyFormula , false ) ;
result = mc . checkNoBoundOperator ( * probFormula ) ;
result = mc . checkNoBoundOperator ( * probFormula ) ;
ASSERT_LT ( std : : abs ( ( * result ) [ 0 ] - 0.083333283662796020508 ) , s - > get < double > ( " precision " ) ) ;
ASSERT_LT ( std : : abs ( ( * result ) [ 0 ] - 0.083333283662796020508 ) , s - > get < double > ( " precision " ) ) ;
delete probFormula ;
delete probFormula ;
delete result ;
delete result ;
apFormula = new storm : : property : : prctl : : Ap < double > ( " done " ) ;
apFormula = new storm : : property : : prctl : : Ap < double > ( " done " ) ;
storm : : property : : prctl : : ReachabilityReward < double > * reachabilityRewardFormula = new storm : : property : : prctl : : ReachabilityReward < double > ( apFormula ) ;
storm : : property : : prctl : : ReachabilityReward < double > * reachabilityRewardFormula = new storm : : property : : prctl : : ReachabilityReward < double > ( apFormula ) ;
storm : : property : : prctl : : RewardNoBoundOperator < double > * rewardFormula = new storm : : property : : prctl : : RewardNoBoundOperator < double > ( reachabilityRewardFormula , true ) ;
storm : : property : : prctl : : RewardNoBoundOperator < double > * rewardFormula = new storm : : property : : prctl : : RewardNoBoundOperator < double > ( reachabilityRewardFormula , true ) ;
result = mc . checkNoBoundOperator ( * rewardFormula ) ;
result = mc . checkNoBoundOperator ( * rewardFormula ) ;
ASSERT_LT ( std : : abs ( ( * result ) [ 0 ] - 7.3333294987678527832 ) , s - > get < double > ( " precision " ) ) ;
ASSERT_LT ( std : : abs ( ( * result ) [ 0 ] - 7.3333294987678527832 ) , s - > get < double > ( " precision " ) ) ;
delete rewardFormula ;
delete rewardFormula ;
delete result ;
delete result ;
apFormula = new storm : : property : : prctl : : Ap < double > ( " done " ) ;
apFormula = new storm : : property : : prctl : : Ap < double > ( " done " ) ;
reachabilityRewardFormula = new storm : : property : : prctl : : ReachabilityReward < double > ( apFormula ) ;
reachabilityRewardFormula = new storm : : property : : prctl : : ReachabilityReward < double > ( apFormula ) ;
rewardFormula = new storm : : property : : prctl : : RewardNoBoundOperator < double > ( reachabilityRewardFormula , false ) ;
rewardFormula = new storm : : property : : prctl : : RewardNoBoundOperator < double > ( reachabilityRewardFormula , false ) ;
result = mc . checkNoBoundOperator ( * rewardFormula ) ; ;
result = mc . checkNoBoundOperator ( * rewardFormula ) ; ;
ASSERT_LT ( std : : abs ( ( * result ) [ 0 ] - 7.3333294987678527832 ) , s - > get < double > ( " precision " ) ) ;
ASSERT_LT ( std : : abs ( ( * result ) [ 0 ] - 7.3333294987678527832 ) , s - > get < double > ( " precision " ) ) ;
delete rewardFormula ;
delete rewardFormula ;
delete result ;
delete result ;
storm : : parser : : AutoParser < double > stateRewardParser ( STORM_CPP_TESTS_BASE_PATH " /functional/two_dice/two_dice.tra " , STORM_CPP_TESTS_BASE_PATH " /functional/two_dice/two_dice.lab " , STORM_CPP_TESTS_BASE_PATH " /functional/two_dice/two_dice.flip.state.rew " , " " ) ;
storm : : parser : : AutoParser < double > stateRewardParser ( STORM_CPP_TESTS_BASE_PATH " /functional/modelchecker/ two_dice/two_dice.tra " , STORM_CPP_TESTS_BASE_PATH " /functional/modelchecker/ two_dice/two_dice.lab " , STORM_CPP_TESTS_BASE_PATH " /functional/modelchecker /two_dice/two_dice.flip.state.rew " , " " ) ;
ASSERT_EQ ( stateRewardParser . getType ( ) , storm : : models : : MDP ) ;
ASSERT_EQ ( stateRewardParser . getType ( ) , storm : : models : : MDP ) ;
std : : shared_ptr < storm : : models : : Mdp < double > > stateRewardMdp = stateRewardParser . getModel < storm : : models : : Mdp < double > > ( ) ;
std : : shared_ptr < storm : : models : : Mdp < double > > stateRewardMdp = stateRewardParser . getModel < storm : : models : : Mdp < double > > ( ) ;
storm : : modelchecker : : GmmxxMdpPrctlModelChecker < double > stateRewardModelChecker ( * stateRewardMdp ) ;
storm : : modelchecker : : GmmxxMdpPrctlModelChecker < double > stateRewardModelChecker ( * stateRewardMdp ) ;
apFormula = new storm : : property : : prctl : : Ap < double > ( " done " ) ;
apFormula = new storm : : property : : prctl : : Ap < double > ( " done " ) ;
reachabilityRewardFormula = new storm : : property : : prctl : : ReachabilityReward < double > ( apFormula ) ;
reachabilityRewardFormula = new storm : : property : : prctl : : ReachabilityReward < double > ( apFormula ) ;
rewardFormula = new storm : : property : : prctl : : RewardNoBoundOperator < double > ( reachabilityRewardFormula , true ) ;
rewardFormula = new storm : : property : : prctl : : RewardNoBoundOperator < double > ( reachabilityRewardFormula , true ) ;
result = stateRewardModelChecker . checkNoBoundOperator ( * rewardFormula ) ;
result = stateRewardModelChecker . checkNoBoundOperator ( * rewardFormula ) ;
ASSERT_LT ( std : : abs ( ( * result ) [ 0 ] - 7.3333294987678527832 ) , s - > get < double > ( " precision " ) ) ;
ASSERT_LT ( std : : abs ( ( * result ) [ 0 ] - 7.3333294987678527832 ) , s - > get < double > ( " precision " ) ) ;
delete rewardFormula ;
delete rewardFormula ;
delete result ;
delete result ;
apFormula = new storm : : property : : prctl : : Ap < double > ( " done " ) ;
apFormula = new storm : : property : : prctl : : Ap < double > ( " done " ) ;
reachabilityRewardFormula = new storm : : property : : prctl : : ReachabilityReward < double > ( apFormula ) ;
reachabilityRewardFormula = new storm : : property : : prctl : : ReachabilityReward < double > ( apFormula ) ;
rewardFormula = new storm : : property : : prctl : : RewardNoBoundOperator < double > ( reachabilityRewardFormula , false ) ;
rewardFormula = new storm : : property : : prctl : : RewardNoBoundOperator < double > ( reachabilityRewardFormula , false ) ;
result = stateRewardModelChecker . checkNoBoundOperator ( * rewardFormula ) ;
result = stateRewardModelChecker . checkNoBoundOperator ( * rewardFormula ) ;
ASSERT_LT ( std : : abs ( ( * result ) [ 0 ] - 7.3333294987678527832 ) , s - > get < double > ( " precision " ) ) ;
ASSERT_LT ( std : : abs ( ( * result ) [ 0 ] - 7.3333294987678527832 ) , s - > get < double > ( " precision " ) ) ;
delete rewardFormula ;
delete rewardFormula ;
delete result ;
delete result ;
storm : : parser : : AutoParser < double > stateAndTransitionRewardParser ( STORM_CPP_TESTS_BASE_PATH " /functional/two_dice/two_dice.tra " , STORM_CPP_TESTS_BASE_PATH " /functional/two_dice/two_dice.lab " , STORM_CPP_TESTS_BASE_PATH " /functional/two_dice/two_dice.flip.state.rew " , STORM_CPP_TESTS_BASE_PATH " /functional/two_dice/two_dice.flip.trans.rew " ) ;
storm : : parser : : AutoParser < double > stateAndTransitionRewardParser ( STORM_CPP_TESTS_BASE_PATH " /functional/modelchecker/ two_dice/two_dice.tra " , STORM_CPP_TESTS_BASE_PATH " /functional/modelchecker /two_dice/two_dice.lab " , STORM_CPP_TESTS_BASE_PATH " /functional/modelchecker/ two_dice/two_dice.flip.state.rew " , STORM_CPP_TESTS_BASE_PATH " /functional/modelchecker /two_dice/two_dice.flip.trans.rew " ) ;
ASSERT_EQ ( stateAndTransitionRewardParser . getType ( ) , storm : : models : : MDP ) ;
ASSERT_EQ ( stateAndTransitionRewardParser . getType ( ) , storm : : models : : MDP ) ;
std : : shared_ptr < storm : : models : : Mdp < double > > stateAndTransitionRewardMdp = stateAndTransitionRewardParser . getModel < storm : : models : : Mdp < double > > ( ) ;
std : : shared_ptr < storm : : models : : Mdp < double > > stateAndTransitionRewardMdp = stateAndTransitionRewardParser . getModel < storm : : models : : Mdp < double > > ( ) ;
storm : : modelchecker : : GmmxxMdpPrctlModelChecker < double > stateAndTransitionRewardModelChecker ( * stateAndTransitionRewardMdp ) ;
storm : : modelchecker : : GmmxxMdpPrctlModelChecker < double > stateAndTransitionRewardModelChecker ( * stateAndTransitionRewardMdp ) ;
apFormula = new storm : : property : : prctl : : Ap < double > ( " done " ) ;
apFormula = new storm : : property : : prctl : : Ap < double > ( " done " ) ;
reachabilityRewardFormula = new storm : : property : : prctl : : ReachabilityReward < double > ( apFormula ) ;
reachabilityRewardFormula = new storm : : property : : prctl : : ReachabilityReward < double > ( apFormula ) ;
rewardFormula = new storm : : property : : prctl : : RewardNoBoundOperator < double > ( reachabilityRewardFormula , true ) ;
rewardFormula = new storm : : property : : prctl : : RewardNoBoundOperator < double > ( reachabilityRewardFormula , true ) ;
result = stateAndTransitionRewardModelChecker . checkNoBoundOperator ( * rewardFormula ) ;
result = stateAndTransitionRewardModelChecker . checkNoBoundOperator ( * rewardFormula ) ;
ASSERT_LT ( std : : abs ( ( * result ) [ 0 ] - ( 2 * 7.3333294987678527832 ) ) , s - > get < double > ( " precision " ) ) ;
ASSERT_LT ( std : : abs ( ( * result ) [ 0 ] - ( 2 * 7.3333294987678527832 ) ) , s - > get < double > ( " precision " ) ) ;
delete rewardFormula ;
delete rewardFormula ;
delete result ;
delete result ;
apFormula = new storm : : property : : prctl : : Ap < double > ( " done " ) ;
apFormula = new storm : : property : : prctl : : Ap < double > ( " done " ) ;
reachabilityRewardFormula = new storm : : property : : prctl : : ReachabilityReward < double > ( apFormula ) ;
reachabilityRewardFormula = new storm : : property : : prctl : : ReachabilityReward < double > ( apFormula ) ;
rewardFormula = new storm : : property : : prctl : : RewardNoBoundOperator < double > ( reachabilityRewardFormula , false ) ;
rewardFormula = new storm : : property : : prctl : : RewardNoBoundOperator < double > ( reachabilityRewardFormula , false ) ;
result = stateAndTransitionRewardModelChecker . checkNoBoundOperator ( * rewardFormula ) ;
result = stateAndTransitionRewardModelChecker . checkNoBoundOperator ( * rewardFormula ) ;
ASSERT_LT ( std : : abs ( ( * result ) [ 0 ] - ( 2 * 7.3333294987678527832 ) ) , s - > get < double > ( " precision " ) ) ;
ASSERT_LT ( std : : abs ( ( * result ) [ 0 ] - ( 2 * 7.3333294987678527832 ) ) , s - > get < double > ( " precision " ) ) ;
delete rewardFormula ;
delete rewardFormula ;
delete result ;
delete result ;
}
}