@ -1,6 +1,15 @@
# include "gtest/gtest.h"
# include "gtest/gtest.h"
# include "test/storm_gtest.h"
# include "storm-config.h"
# include "storm-config.h"
# include "storm/api/builder.h"
# include "storm-conv/api/storm-conv.h"
# include "storm-parsers/api/model_descriptions.h"
# include "storm/api/properties.h"
# include "storm-parsers/api/properties.h"
# include "storm-parsers/parser/FormulaParser.h"
# include "storm-parsers/parser/FormulaParser.h"
# include "storm/logic/Formulas.h"
# include "storm/logic/Formulas.h"
# include "storm/solver/StandardMinMaxLinearEquationSolver.h"
# include "storm/solver/StandardMinMaxLinearEquationSolver.h"
@ -13,86 +22,174 @@
# include "storm/settings/modules/NativeEquationSolverSettings.h"
# include "storm/settings/modules/NativeEquationSolverSettings.h"
# include "storm-parsers/parser/AutoParser.h"
# include "storm-parsers/parser/AutoParser.h"
# include "storm/environment/solver/MinMaxSolverEnvironment.h"
namespace {
class SparseValueTypeValueIterationEnvironment {
public :
static const bool isExact = false ;
typedef double ValueType ;
typedef storm : : models : : sparse : : Mdp < ValueType > ModelType ;
static storm : : Environment createEnvironment ( ) {
storm : : Environment env ;
env . solver ( ) . minMax ( ) . setLraMethod ( storm : : solver : : LraMethod : : ValueIteration ) ;
env . solver ( ) . minMax ( ) . setPrecision ( storm : : utility : : convertNumber < storm : : RationalNumber > ( 1e-10 ) ) ;
return env ;
}
} ;
class SparseValueTypeLinearProgrammingEnvironment {
public :
static const bool isExact = false ;
typedef double ValueType ;
typedef storm : : models : : sparse : : Mdp < ValueType > ModelType ;
static storm : : Environment createEnvironment ( ) {
storm : : Environment env ;
env . solver ( ) . minMax ( ) . setLraMethod ( storm : : solver : : LraMethod : : LinearProgramming ) ;
env . solver ( ) . minMax ( ) . setPrecision ( storm : : utility : : convertNumber < storm : : RationalNumber > ( 1e-10 ) ) ;
return env ;
}
} ;
class SparseRationalLinearProgrammingEnvironment {
public :
static const bool isExact = true ;
typedef storm : : RationalNumber ValueType ;
typedef storm : : models : : sparse : : Mdp < ValueType > ModelType ;
static storm : : Environment createEnvironment ( ) {
storm : : Environment env ;
env . solver ( ) . minMax ( ) . setLraMethod ( storm : : solver : : LraMethod : : LinearProgramming ) ;
return env ;
}
} ;
template < typename TestType >
class LraMdpPrctlModelCheckerTest : public : : testing : : Test {
public :
typedef typename TestType : : ValueType ValueType ;
typedef typename storm : : models : : sparse : : Mdp < ValueType > SparseModelType ;
LraMdpPrctlModelCheckerTest ( ) : _environment ( TestType : : createEnvironment ( ) ) { }
storm : : Environment const & env ( ) const { return _environment ; }
ValueType parseNumber ( std : : string const & input ) const { return storm : : utility : : convertNumber < ValueType > ( input ) ; }
ValueType precision ( ) const { return TestType : : isExact ? parseNumber ( " 0 " ) : parseNumber ( " 1e-6 " ) ; }
bool isSparseModel ( ) const { return std : : is_same < typename TestType : : ModelType , SparseModelType > : : value ; }
std : : pair < std : : shared_ptr < SparseModelType > , std : : vector < std : : shared_ptr < storm : : logic : : Formula const > > > buildModelFormulas ( std : : string const & pathToPrismFile , std : : string const & formulasAsString , std : : string const & constantDefinitionString = " " ) const {
std : : pair < std : : shared_ptr < SparseModelType > , std : : vector < std : : shared_ptr < storm : : logic : : Formula const > > > result ;
storm : : prism : : Program program = storm : : api : : parseProgram ( pathToPrismFile ) ;
program = storm : : utility : : prism : : preprocess ( program , constantDefinitionString ) ;
result . second = storm : : api : : extractFormulasFromProperties ( storm : : api : : parsePropertiesForPrismProgram ( formulasAsString , program ) ) ;
result . first = storm : : api : : buildSparseModel < ValueType > ( program , result . second ) - > template as < SparseModelType > ( ) ;
return result ;
}
std : : vector < storm : : modelchecker : : CheckTask < storm : : logic : : Formula , ValueType > > getTasks ( std : : vector < std : : shared_ptr < storm : : logic : : Formula const > > const & formulas ) const {
std : : vector < storm : : modelchecker : : CheckTask < storm : : logic : : Formula , ValueType > > result ;
for ( auto const & f : formulas ) {
result . emplace_back ( * f ) ;
}
return result ;
}
private :
storm : : Environment _environment ;
} ;
typedef : : testing : : Types <
SparseValueTypeValueIterationEnvironment ,
SparseValueTypeLinearProgrammingEnvironment
# ifdef STORM_HAVE_Z3_OPTIMIZE
, SparseRationalLinearProgrammingEnvironment
# endif
> TestingTypes ;
TEST ( LraMdpPrctlModelCheckerTest , LRA_SingleMec ) {
storm : : storage : : SparseMatrixBuilder < double > matrixBuilder ;
std : : shared_ptr < storm : : models : : sparse : : Mdp < double > > mdp ;
TYPED_TEST_CASE ( LraMdpPrctlModelCheckerTest , TestingTypes ) ;
TYPED_TEST ( LraMdpPrctlModelCheckerTest , LRA_SingleMec ) {
typedef typename TestFixture : : ValueType ValueType ;
storm : : storage : : SparseMatrixBuilder < ValueType > matrixBuilder ;
std : : shared_ptr < storm : : models : : sparse : : Mdp < ValueType > > mdp ;
// A parser that we use for conveniently constructing the formulas.
// A parser that we use for conveniently constructing the formulas.
storm : : parser : : FormulaParser formulaParser ;
storm : : parser : : FormulaParser formulaParser ;
{
{
matrixBuilder = storm : : storage : : SparseMatrixBuilder < double > ( 2 , 2 , 2 ) ;
matrixBuilder . addNextValue ( 0 , 1 , 1. ) ;
matrixBuilder . addNextValue ( 1 , 0 , 1. ) ;
storm : : storage : : SparseMatrix < double > transitionMatrix = matrixBuilder . build ( ) ;
matrixBuilder = storm : : storage : : SparseMatrixBuilder < ValueTyp e> ( 2 , 2 , 2 ) ;
matrixBuilder . addNextValue ( 0 , 1 , this - > parseNumber ( " 1 " ) ) ;
matrixBuilder . addNextValue ( 1 , 0 , this - > parseNumber ( " 1 " ) ) ;
storm : : storage : : SparseMatrix < ValueTyp e> transitionMatrix = matrixBuilder . build ( ) ;
storm : : models : : sparse : : StateLabeling ap ( 2 ) ;
storm : : models : : sparse : : StateLabeling ap ( 2 ) ;
ap . addLabel ( " a " ) ;
ap . addLabel ( " a " ) ;
ap . addLabelToState ( " a " , 1 ) ;
ap . addLabelToState ( " a " , 1 ) ;
mdp . reset ( new storm : : models : : sparse : : Mdp < double > ( transitionMatrix , ap ) ) ;
mdp . reset ( new storm : : models : : sparse : : Mdp < ValueTyp e> ( transitionMatrix , ap ) ) ;
storm : : modelchecker : : SparseMdpPrctlModelChecker < storm : : models : : sparse : : Mdp < double > > checker ( * mdp ) ;
storm : : modelchecker : : SparseMdpPrctlModelChecker < storm : : models : : sparse : : Mdp < ValueTyp e> > checker ( * mdp ) ;
std : : shared_ptr < storm : : logic : : Formula const > formula = formulaParser . parseSingleFormulaFromString ( " LRAmax=? [ \" a \" ] " ) ;
std : : shared_ptr < storm : : logic : : Formula const > formula = formulaParser . parseSingleFormulaFromString ( " LRAmax=? [ \" a \" ] " ) ;
std : : unique_ptr < storm : : modelchecker : : CheckResult > result = checker . check ( * formula ) ;
storm : : modelchecker : : ExplicitQuantitativeCheckResult < double > & quantitativeResult1 = result - > asExplicitQuantitativeCheckResult < double > ( ) ;
std : : unique_ptr < storm : : modelchecker : : CheckResult > result = checker . check ( this - > env ( ) , * formula ) ;
storm : : modelchecker : : ExplicitQuantitativeCheckResult < ValueTyp e> & quantitativeResult1 = result - > asExplicitQuantitativeCheckResult < ValueTyp e> ( ) ;
EXPECT_NEAR ( .5 , quantitativeResult1 [ 0 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getPrecision ( ) ) ;
EXPECT_NEAR ( .5 , quantitativeResult1 [ 1 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getPrecision ( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 0.5 " ) , quantitativeResult1 [ 0 ] , this - > p recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 0.5 " ) , quantitativeResult1 [ 1 ] , this - > p recision( ) ) ;
formula = formulaParser . parseSingleFormulaFromString ( " LRAmin=? [ \" a \" ] " ) ;
formula = formulaParser . parseSingleFormulaFromString ( " LRAmin=? [ \" a \" ] " ) ;
result = checker . check ( * formula ) ;
storm : : modelchecker : : ExplicitQuantitativeCheckResult < double > & quantitativeResult2 = result - > asExplicitQuantitativeCheckResult < double > ( ) ;
result = checker . check ( this - > env ( ) , * formula ) ;
storm : : modelchecker : : ExplicitQuantitativeCheckResult < ValueTyp e> & quantitativeResult2 = result - > asExplicitQuantitativeCheckResult < ValueTyp e> ( ) ;
EXPECT_NEAR ( .5 , quantitativeResult2 [ 0 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getPrecision ( ) ) ;
EXPECT_NEAR ( .5 , quantitativeResult2 [ 1 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getPrecision ( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 0.5 " ) , quantitativeResult2 [ 0 ] , this - > p recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 0.5 " ) , quantitativeResult2 [ 1 ] , this - > p recision( ) ) ;
}
}
{
{
matrixBuilder = storm : : storage : : SparseMatrixBuilder < double > ( 2 , 2 , 4 ) ;
matrixBuilder . addNextValue ( 0 , 0 , .5 ) ;
matrixBuilder . addNextValue ( 0 , 1 , .5 ) ;
matrixBuilder . addNextValue ( 1 , 0 , .5 ) ;
matrixBuilder . addNextValue ( 1 , 1 , .5 ) ;
storm : : storage : : SparseMatrix < double > transitionMatrix = matrixBuilder . build ( ) ;
matrixBuilder = storm : : storage : : SparseMatrixBuilder < ValueTyp e> ( 2 , 2 , 4 ) ;
matrixBuilder . addNextValue ( 0 , 0 , this - > parseNumber ( " 0.5 " ) ) ;
matrixBuilder . addNextValue ( 0 , 1 , this - > parseNumber ( " 0.5 " ) ) ;
matrixBuilder . addNextValue ( 1 , 0 , this - > parseNumber ( " 0.5 " ) ) ;
matrixBuilder . addNextValue ( 1 , 1 , this - > parseNumber ( " 0.5 " ) ) ;
storm : : storage : : SparseMatrix < ValueTyp e> transitionMatrix = matrixBuilder . build ( ) ;
storm : : models : : sparse : : StateLabeling ap ( 2 ) ;
storm : : models : : sparse : : StateLabeling ap ( 2 ) ;
ap . addLabel ( " a " ) ;
ap . addLabel ( " a " ) ;
ap . addLabelToState ( " a " , 1 ) ;
ap . addLabelToState ( " a " , 1 ) ;
mdp . reset ( new storm : : models : : sparse : : Mdp < double > ( transitionMatrix , ap ) ) ;
mdp . reset ( new storm : : models : : sparse : : Mdp < ValueTyp e> ( transitionMatrix , ap ) ) ;
storm : : modelchecker : : SparseMdpPrctlModelChecker < storm : : models : : sparse : : Mdp < double > > checker ( * mdp ) ;
storm : : modelchecker : : SparseMdpPrctlModelChecker < storm : : models : : sparse : : Mdp < ValueTyp e> > checker ( * mdp ) ;
std : : shared_ptr < storm : : logic : : Formula const > formula = formulaParser . parseSingleFormulaFromString ( " LRAmax=? [ \" a \" ] " ) ;
std : : shared_ptr < storm : : logic : : Formula const > formula = formulaParser . parseSingleFormulaFromString ( " LRAmax=? [ \" a \" ] " ) ;
std : : unique_ptr < storm : : modelchecker : : CheckResult > result = checker . check ( * formula ) ;
storm : : modelchecker : : ExplicitQuantitativeCheckResult < double > & quantitativeResult1 = result - > asExplicitQuantitativeCheckResult < double > ( ) ;
std : : unique_ptr < storm : : modelchecker : : CheckResult > result = checker . check ( this - > env ( ) , * formula ) ;
storm : : modelchecker : : ExplicitQuantitativeCheckResult < ValueTyp e> & quantitativeResult1 = result - > asExplicitQuantitativeCheckResult < ValueTyp e> ( ) ;
EXPECT_NEAR ( .5 , quantitativeResult1 [ 0 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getPrecision ( ) ) ;
EXPECT_NEAR ( .5 , quantitativeResult1 [ 1 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getPrecision ( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 0.5 " ) , quantitativeResult1 [ 0 ] , this - > p recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 0.5 " ) , quantitativeResult1 [ 1 ] , this - > p recision( ) ) ;
formula = formulaParser . parseSingleFormulaFromString ( " LRAmin=? [ \" a \" ] " ) ;
formula = formulaParser . parseSingleFormulaFromString ( " LRAmin=? [ \" a \" ] " ) ;
result = checker . check ( * formula ) ;
storm : : modelchecker : : ExplicitQuantitativeCheckResult < double > & quantitativeResult2 = result - > asExplicitQuantitativeCheckResult < double > ( ) ;
result = checker . check ( this - > env ( ) , * formula ) ;
storm : : modelchecker : : ExplicitQuantitativeCheckResult < ValueTyp e> & quantitativeResult2 = result - > asExplicitQuantitativeCheckResult < ValueTyp e> ( ) ;
EXPECT_NEAR ( .5 , quantitativeResult2 [ 0 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getPrecision ( ) ) ;
EXPECT_NEAR ( .5 , quantitativeResult2 [ 1 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getPrecision ( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 0.5 " ) , quantitativeResult2 [ 0 ] , this - > p recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 0.5 " ) , quantitativeResult2 [ 1 ] , this - > p recision( ) ) ;
}
}
{
{
matrixBuilder = storm : : storage : : SparseMatrixBuilder < double > ( 4 , 3 , 4 , true , true , 3 ) ;
matrixBuilder = storm : : storage : : SparseMatrixBuilder < ValueTyp e> ( 4 , 3 , 4 , true , true , 3 ) ;
matrixBuilder . newRowGroup ( 0 ) ;
matrixBuilder . newRowGroup ( 0 ) ;
matrixBuilder . addNextValue ( 0 , 1 , 1 ) ;
matrixBuilder . addNextValue ( 0 , 1 , this - > parseNumber ( " 1 " ) ) ;
matrixBuilder . newRowGroup ( 1 ) ;
matrixBuilder . newRowGroup ( 1 ) ;
matrixBuilder . addNextValue ( 1 , 0 , 1 ) ;
matrixBuilder . addNextValue ( 2 , 2 , 1 ) ;
matrixBuilder . addNextValue ( 1 , 0 , this - > parseNumber ( " 1 " ) ) ;
matrixBuilder . addNextValue ( 2 , 2 , this - > parseNumber ( " 1 " ) ) ;
matrixBuilder . newRowGroup ( 3 ) ;
matrixBuilder . newRowGroup ( 3 ) ;
matrixBuilder . addNextValue ( 3 , 0 , 1 ) ;
storm : : storage : : SparseMatrix < double > transitionMatrix = matrixBuilder . build ( ) ;
matrixBuilder . addNextValue ( 3 , 0 , this - > parseNumber ( " 1 " ) ) ;
storm : : storage : : SparseMatrix < ValueTyp e> transitionMatrix = matrixBuilder . build ( ) ;
storm : : models : : sparse : : StateLabeling ap ( 3 ) ;
storm : : models : : sparse : : StateLabeling ap ( 3 ) ;
ap . addLabel ( " a " ) ;
ap . addLabel ( " a " ) ;
@ -103,83 +200,85 @@ TEST(LraMdpPrctlModelCheckerTest, LRA_SingleMec) {
ap . addLabelToState ( " c " , 0 ) ;
ap . addLabelToState ( " c " , 0 ) ;
ap . addLabelToState ( " c " , 2 ) ;
ap . addLabelToState ( " c " , 2 ) ;
mdp . reset ( new storm : : models : : sparse : : Mdp < doubl e> ( transitionMatrix , ap ) ) ;
mdp . reset ( new storm : : models : : sparse : : Mdp < ValueTyp e> ( transitionMatrix , ap ) ) ;
storm : : modelchecker : : SparseMdpPrctlModelChecker < storm : : models : : sparse : : Mdp < doubl e> > checker ( * mdp ) ;
storm : : modelchecker : : SparseMdpPrctlModelChecker < storm : : models : : sparse : : Mdp < ValueTyp e> > checker ( * mdp ) ;
std : : shared_ptr < storm : : logic : : Formula const > formula = formulaParser . parseSingleFormulaFromString ( " LRAmax=? [ \" a \" ] " ) ;
std : : shared_ptr < storm : : logic : : Formula const > formula = formulaParser . parseSingleFormulaFromString ( " LRAmax=? [ \" a \" ] " ) ;
std : : unique_ptr < storm : : modelchecker : : CheckResult > result = checker . check ( * formula ) ;
storm : : modelchecker : : ExplicitQuantitativeCheckResult < doubl e> & quantitativeResult1 = result - > asExplicitQuantitativeCheckResult < doubl e> ( ) ;
std : : unique_ptr < storm : : modelchecker : : CheckResult > result = checker . check ( this - > env ( ) , * formula ) ;
storm : : modelchecker : : ExplicitQuantitativeCheckResult < ValueTyp e> & quantitativeResult1 = result - > asExplicitQuantitativeCheckResult < ValueTyp e> ( ) ;
EXPECT_NEAR ( 1. / 3. , quantitativeResult1 [ 0 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( 1. / 3. , quantitativeResult1 [ 1 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( 1. / 3. , quantitativeResult1 [ 2 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 1/3 " ) , quantitativeResult1 [ 0 ] , this - > p recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 1/3 " ) , quantitativeResult1 [ 1 ] , this - > p recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 1/3 " ) , quantitativeResult1 [ 2 ] , this - > p recision( ) ) ;
formula = formulaParser . parseSingleFormulaFromString ( " LRAmin=? [ \" a \" ] " ) ;
formula = formulaParser . parseSingleFormulaFromString ( " LRAmin=? [ \" a \" ] " ) ;
result = checker . check ( * formula ) ;
storm : : modelchecker : : ExplicitQuantitativeCheckResult < doubl e> & quantitativeResult2 = result - > asExplicitQuantitativeCheckResult < doubl e> ( ) ;
result = checker . check ( this - > env ( ) , * formula ) ;
storm : : modelchecker : : ExplicitQuantitativeCheckResult < ValueTyp e> & quantitativeResult2 = result - > asExplicitQuantitativeCheckResult < ValueTyp e> ( ) ;
EXPECT_NEAR ( 0.0 , quantitativeResult2 [ 0 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( 0.0 , quantitativeResult2 [ 1 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( 0.0 , quantitativeResult2 [ 2 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 0 " ) , quantitativeResult2 [ 0 ] , this - > p recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 0 " ) , quantitativeResult2 [ 1 ] , this - > p recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 0 " ) , quantitativeResult2 [ 2 ] , this - > p recision( ) ) ;
formula = formulaParser . parseSingleFormulaFromString ( " LRAmax=? [ \" b \" ] " ) ;
formula = formulaParser . parseSingleFormulaFromString ( " LRAmax=? [ \" b \" ] " ) ;
result = checker . check ( * formula ) ;
storm : : modelchecker : : ExplicitQuantitativeCheckResult < doubl e> & quantitativeResult3 = result - > asExplicitQuantitativeCheckResult < doubl e> ( ) ;
result = checker . check ( this - > env ( ) , * formula ) ;
storm : : modelchecker : : ExplicitQuantitativeCheckResult < ValueTyp e> & quantitativeResult3 = result - > asExplicitQuantitativeCheckResult < ValueTyp e> ( ) ;
EXPECT_NEAR ( 0.5 , quantitativeResult3 [ 0 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( 0.5 , quantitativeResult3 [ 1 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( 0.5 , quantitativeResult3 [ 2 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 0.5 " ) , quantitativeResult3 [ 0 ] , this - > p recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 0.5 " ) , quantitativeResult3 [ 1 ] , this - > p recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 0.5 " ) , quantitativeResult3 [ 2 ] , this - > p recision( ) ) ;
formula = formulaParser . parseSingleFormulaFromString ( " LRAmin=? [ \" b \" ] " ) ;
formula = formulaParser . parseSingleFormulaFromString ( " LRAmin=? [ \" b \" ] " ) ;
result = checker . check ( * formula ) ;
storm : : modelchecker : : ExplicitQuantitativeCheckResult < doubl e> & quantitativeResult4 = result - > asExplicitQuantitativeCheckResult < doubl e> ( ) ;
result = checker . check ( this - > env ( ) , * formula ) ;
storm : : modelchecker : : ExplicitQuantitativeCheckResult < ValueTyp e> & quantitativeResult4 = result - > asExplicitQuantitativeCheckResult < ValueTyp e> ( ) ;
EXPECT_NEAR ( 1. / 3. , quantitativeResult4 [ 0 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( 1. / 3. , quantitativeResult4 [ 1 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( 1. / 3. , quantitativeResult4 [ 2 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 1/3 " ) , quantitativeResult4 [ 0 ] , this - > p recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 1/3 " ) , quantitativeResult4 [ 1 ] , this - > p recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 1/3 " ) , quantitativeResult4 [ 2 ] , this - > p recision( ) ) ;
formula = formulaParser . parseSingleFormulaFromString ( " LRAmax=? [ \" c \" ] " ) ;
formula = formulaParser . parseSingleFormulaFromString ( " LRAmax=? [ \" c \" ] " ) ;
result = checker . check ( * formula ) ;
storm : : modelchecker : : ExplicitQuantitativeCheckResult < doubl e> & quantitativeResult5 = result - > asExplicitQuantitativeCheckResult < doubl e> ( ) ;
result = checker . check ( this - > env ( ) , * formula ) ;
storm : : modelchecker : : ExplicitQuantitativeCheckResult < ValueTyp e> & quantitativeResult5 = result - > asExplicitQuantitativeCheckResult < ValueTyp e> ( ) ;
EXPECT_NEAR ( 2. / 3. , quantitativeResult5 [ 0 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( 2. / 3. , quantitativeResult5 [ 1 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( 2. / 3. , quantitativeResult5 [ 2 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 2/3 " ) , quantitativeResult5 [ 0 ] , this - > p recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 2/3 " ) , quantitativeResult5 [ 1 ] , this - > p recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 2/3 " ) , quantitativeResult5 [ 2 ] , this - > p recision( ) ) ;
formula = formulaParser . parseSingleFormulaFromString ( " LRAmin=? [ \" c \" ] " ) ;
formula = formulaParser . parseSingleFormulaFromString ( " LRAmin=? [ \" c \" ] " ) ;
result = checker . check ( * formula ) ;
storm : : modelchecker : : ExplicitQuantitativeCheckResult < doubl e> & quantitativeResult6 = result - > asExplicitQuantitativeCheckResult < doubl e> ( ) ;
result = checker . check ( this - > env ( ) , * formula ) ;
storm : : modelchecker : : ExplicitQuantitativeCheckResult < ValueTyp e> & quantitativeResult6 = result - > asExplicitQuantitativeCheckResult < ValueTyp e> ( ) ;
EXPECT_NEAR ( 0.5 , quantitativeResult6 [ 0 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( 0.5 , quantitativeResult6 [ 1 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( 0.5 , quantitativeResult6 [ 2 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 0.5 " ) , quantitativeResult6 [ 0 ] , this - > p recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 0.5 " ) , quantitativeResult6 [ 1 ] , this - > p recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 0.5 " ) , quantitativeResult6 [ 2 ] , this - > p recision( ) ) ;
}
}
}
}
TEST ( LraMdpPrctlModelCheckerTest , LRA ) {
storm : : storage : : SparseMatrixBuilder < double > matrixBuilder ;
std : : shared_ptr < storm : : models : : sparse : : Mdp < double > > mdp ;
TYPED_TEST ( LraMdpPrctlModelCheckerTest , LRA ) {
typedef typename TestFixture : : ValueType ValueType ;
storm : : storage : : SparseMatrixBuilder < ValueType > matrixBuilder ;
std : : shared_ptr < storm : : models : : sparse : : Mdp < ValueType > > mdp ;
// A parser that we use for conveniently constructing the formulas.
// A parser that we use for conveniently constructing the formulas.
storm : : parser : : FormulaParser formulaParser ;
storm : : parser : : FormulaParser formulaParser ;
{
{
matrixBuilder = storm : : storage : : SparseMatrixBuilder < doubl e> ( 4 , 3 , 4 , true , true , 3 ) ;
matrixBuilder = storm : : storage : : SparseMatrixBuilder < ValueTyp e> ( 4 , 3 , 4 , true , true , 3 ) ;
matrixBuilder . newRowGroup ( 0 ) ;
matrixBuilder . newRowGroup ( 0 ) ;
matrixBuilder . addNextValue ( 0 , 1 , 1 ) ;
matrixBuilder . addNextValue ( 0 , 1 , this - > parseNumber ( " 1 " ) ) ;
matrixBuilder . newRowGroup ( 1 ) ;
matrixBuilder . newRowGroup ( 1 ) ;
matrixBuilder . addNextValue ( 1 , 1 , 1 ) ;
matrixBuilder . addNextValue ( 2 , 2 , 1 ) ;
matrixBuilder . addNextValue ( 1 , 1 , this - > parseNumber ( " 1 " ) ) ;
matrixBuilder . addNextValue ( 2 , 2 , this - > parseNumber ( " 1 " ) ) ;
matrixBuilder . newRowGroup ( 3 ) ;
matrixBuilder . newRowGroup ( 3 ) ;
matrixBuilder . addNextValue ( 3 , 2 , 1 ) ;
storm : : storage : : SparseMatrix < doubl e> transitionMatrix = matrixBuilder . build ( ) ;
matrixBuilder . addNextValue ( 3 , 2 , this - > parseNumber ( " 1 " ) ) ;
storm : : storage : : SparseMatrix < ValueTyp e> transitionMatrix = matrixBuilder . build ( ) ;
storm : : models : : sparse : : StateLabeling ap ( 3 ) ;
storm : : models : : sparse : : StateLabeling ap ( 3 ) ;
ap . addLabel ( " a " ) ;
ap . addLabel ( " a " ) ;
@ -189,117 +288,117 @@ TEST(LraMdpPrctlModelCheckerTest, LRA) {
ap . addLabel ( " c " ) ;
ap . addLabel ( " c " ) ;
ap . addLabelToState ( " c " , 2 ) ;
ap . addLabelToState ( " c " , 2 ) ;
mdp . reset ( new storm : : models : : sparse : : Mdp < doubl e> ( transitionMatrix , ap ) ) ;
mdp . reset ( new storm : : models : : sparse : : Mdp < ValueTyp e> ( transitionMatrix , ap ) ) ;
storm : : modelchecker : : SparseMdpPrctlModelChecker < storm : : models : : sparse : : Mdp < doubl e> > checker ( * mdp ) ;
storm : : modelchecker : : SparseMdpPrctlModelChecker < storm : : models : : sparse : : Mdp < ValueTyp e> > checker ( * mdp ) ;
std : : shared_ptr < storm : : logic : : Formula const > formula = formulaParser . parseSingleFormulaFromString ( " LRAmax=? [ \" a \" ] " ) ;
std : : shared_ptr < storm : : logic : : Formula const > formula = formulaParser . parseSingleFormulaFromString ( " LRAmax=? [ \" a \" ] " ) ;
std : : unique_ptr < storm : : modelchecker : : CheckResult > result = checker . check ( * formula ) ;
storm : : modelchecker : : ExplicitQuantitativeCheckResult < doubl e> & quantitativeResult1 = result - > asExplicitQuantitativeCheckResult < doubl e> ( ) ;
std : : unique_ptr < storm : : modelchecker : : CheckResult > result = checker . check ( this - > env ( ) , * formula ) ;
storm : : modelchecker : : ExplicitQuantitativeCheckResult < ValueTyp e> & quantitativeResult1 = result - > asExplicitQuantitativeCheckResult < ValueTyp e> ( ) ;
EXPECT_NEAR ( 0.0 , quantitativeResult1 [ 0 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( 0.0 , quantitativeResult1 [ 1 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( 0.0 , quantitativeResult1 [ 2 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 0 " ) , quantitativeResult1 [ 0 ] , this - > p recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 0 " ) , quantitativeResult1 [ 1 ] , this - > p recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 0 " ) , quantitativeResult1 [ 2 ] , this - > p recision( ) ) ;
formula = formulaParser . parseSingleFormulaFromString ( " LRAmin=? [ \" a \" ] " ) ;
formula = formulaParser . parseSingleFormulaFromString ( " LRAmin=? [ \" a \" ] " ) ;
result = checker . check ( * formula ) ;
storm : : modelchecker : : ExplicitQuantitativeCheckResult < doubl e> & quantitativeResult2 = result - > asExplicitQuantitativeCheckResult < doubl e> ( ) ;
result = checker . check ( this - > env ( ) , * formula ) ;
storm : : modelchecker : : ExplicitQuantitativeCheckResult < ValueTyp e> & quantitativeResult2 = result - > asExplicitQuantitativeCheckResult < ValueTyp e> ( ) ;
EXPECT_NEAR ( 0.0 , quantitativeResult2 [ 0 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( 0.0 , quantitativeResult2 [ 1 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( 0.0 , quantitativeResult2 [ 2 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 0 " ) , quantitativeResult2 [ 0 ] , this - > p recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 0 " ) , quantitativeResult2 [ 1 ] , this - > p recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 0 " ) , quantitativeResult2 [ 2 ] , this - > p recision( ) ) ;
formula = formulaParser . parseSingleFormulaFromString ( " LRAmax=? [ \" b \" ] " ) ;
formula = formulaParser . parseSingleFormulaFromString ( " LRAmax=? [ \" b \" ] " ) ;
result = checker . check ( * formula ) ;
storm : : modelchecker : : ExplicitQuantitativeCheckResult < doubl e> & quantitativeResult3 = result - > asExplicitQuantitativeCheckResult < doubl e> ( ) ;
result = checker . check ( this - > env ( ) , * formula ) ;
storm : : modelchecker : : ExplicitQuantitativeCheckResult < ValueTyp e> & quantitativeResult3 = result - > asExplicitQuantitativeCheckResult < ValueTyp e> ( ) ;
EXPECT_NEAR ( 1.0 , quantitativeResult3 [ 0 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( 1.0 , quantitativeResult3 [ 1 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( 0.0 , quantitativeResult3 [ 2 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 1 " ) , quantitativeResult3 [ 0 ] , this - > p recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 1 " ) , quantitativeResult3 [ 1 ] , this - > p recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 0 " ) , quantitativeResult3 [ 2 ] , this - > p recision( ) ) ;
formula = formulaParser . parseSingleFormulaFromString ( " LRAmin=? [ \" b \" ] " ) ;
formula = formulaParser . parseSingleFormulaFromString ( " LRAmin=? [ \" b \" ] " ) ;
result = checker . check ( * formula ) ;
storm : : modelchecker : : ExplicitQuantitativeCheckResult < doubl e> & quantitativeResult4 = result - > asExplicitQuantitativeCheckResult < doubl e> ( ) ;
result = checker . check ( this - > env ( ) , * formula ) ;
storm : : modelchecker : : ExplicitQuantitativeCheckResult < ValueTyp e> & quantitativeResult4 = result - > asExplicitQuantitativeCheckResult < ValueTyp e> ( ) ;
EXPECT_NEAR ( 0.0 , quantitativeResult4 [ 0 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( 0.0 , quantitativeResult4 [ 1 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( 0.0 , quantitativeResult4 [ 2 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 0 " ) , quantitativeResult4 [ 0 ] , this - > p recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 0 " ) , quantitativeResult4 [ 1 ] , this - > p recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 0 " ) , quantitativeResult4 [ 2 ] , this - > p recision( ) ) ;
formula = formulaParser . parseSingleFormulaFromString ( " LRAmax=? [ \" c \" ] " ) ;
formula = formulaParser . parseSingleFormulaFromString ( " LRAmax=? [ \" c \" ] " ) ;
result = checker . check ( * formula ) ;
storm : : modelchecker : : ExplicitQuantitativeCheckResult < doubl e> & quantitativeResult5 = result - > asExplicitQuantitativeCheckResult < doubl e> ( ) ;
result = checker . check ( this - > env ( ) , * formula ) ;
storm : : modelchecker : : ExplicitQuantitativeCheckResult < ValueTyp e> & quantitativeResult5 = result - > asExplicitQuantitativeCheckResult < ValueTyp e> ( ) ;
EXPECT_NEAR ( 1.0 , quantitativeResult5 [ 0 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( 1.0 , quantitativeResult5 [ 1 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( 1.0 , quantitativeResult5 [ 2 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 1 " ) , quantitativeResult5 [ 0 ] , this - > p recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 1 " ) , quantitativeResult5 [ 1 ] , this - > p recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 1 " ) , quantitativeResult5 [ 2 ] , this - > p recision( ) ) ;
formula = formulaParser . parseSingleFormulaFromString ( " LRAmin=? [ \" c \" ] " ) ;
formula = formulaParser . parseSingleFormulaFromString ( " LRAmin=? [ \" c \" ] " ) ;
result = checker . check ( * formula ) ;
storm : : modelchecker : : ExplicitQuantitativeCheckResult < doubl e> & quantitativeResult6 = result - > asExplicitQuantitativeCheckResult < doubl e> ( ) ;
result = checker . check ( this - > env ( ) , * formula ) ;
storm : : modelchecker : : ExplicitQuantitativeCheckResult < ValueTyp e> & quantitativeResult6 = result - > asExplicitQuantitativeCheckResult < ValueTyp e> ( ) ;
EXPECT_NEAR ( 0.0 , quantitativeResult6 [ 0 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( 0.0 , quantitativeResult6 [ 1 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( 1.0 , quantitativeResult6 [ 2 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 0 " ) , quantitativeResult6 [ 0 ] , this - > p recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 0 " ) , quantitativeResult6 [ 1 ] , this - > p recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 1 " ) , quantitativeResult6 [ 2 ] , this - > p recision( ) ) ;
}
}
{
{
matrixBuilder = storm : : storage : : SparseMatrixBuilder < doubl e> ( 22 , 15 , 28 , true , true , 15 ) ;
matrixBuilder = storm : : storage : : SparseMatrixBuilder < ValueTyp e> ( 22 , 15 , 28 , true , true , 15 ) ;
matrixBuilder . newRowGroup ( 0 ) ;
matrixBuilder . newRowGroup ( 0 ) ;
matrixBuilder . addNextValue ( 0 , 1 , 1 ) ;
matrixBuilder . addNextValue ( 0 , 1 , this - > parseNumber ( " 1 " ) ) ;
matrixBuilder . newRowGroup ( 1 ) ;
matrixBuilder . newRowGroup ( 1 ) ;
matrixBuilder . addNextValue ( 1 , 0 , 1 ) ;
matrixBuilder . addNextValue ( 2 , 2 , 1 ) ;
matrixBuilder . addNextValue ( 3 , 4 , 0.7 ) ;
matrixBuilder . addNextValue ( 3 , 6 , 0.3 ) ;
matrixBuilder . addNextValue ( 1 , 0 , this - > parseNumber ( " 1 " ) ) ;
matrixBuilder . addNextValue ( 2 , 2 , this - > parseNumber ( " 1 " ) ) ;
matrixBuilder . addNextValue ( 3 , 4 , this - > parseNumber ( " 0.7 " ) ) ;
matrixBuilder . addNextValue ( 3 , 6 , this - > parseNumber ( " 0.3 " ) ) ;
matrixBuilder . newRowGroup ( 4 ) ;
matrixBuilder . newRowGroup ( 4 ) ;
matrixBuilder . addNextValue ( 4 , 0 , 1 ) ;
matrixBuilder . addNextValue ( 4 , 0 , this - > parseNumber ( " 1 " ) ) ;
matrixBuilder . newRowGroup ( 5 ) ;
matrixBuilder . newRowGroup ( 5 ) ;
matrixBuilder . addNextValue ( 5 , 4 , 1 ) ;
matrixBuilder . addNextValue ( 6 , 5 , 0.8 ) ;
matrixBuilder . addNextValue ( 6 , 9 , 0.2 ) ;
matrixBuilder . addNextValue ( 5 , 4 , this - > parseNumber ( " 1 " ) ) ;
matrixBuilder . addNextValue ( 6 , 5 , this - > parseNumber ( " 0.8 " ) ) ;
matrixBuilder . addNextValue ( 6 , 9 , this - > parseNumber ( " 0.2 " ) ) ;
matrixBuilder . newRowGroup ( 7 ) ;
matrixBuilder . newRowGroup ( 7 ) ;
matrixBuilder . addNextValue ( 7 , 3 , 1 ) ;
matrixBuilder . addNextValue ( 8 , 5 , 1 ) ;
matrixBuilder . addNextValue ( 7 , 3 , this - > parseNumber ( " 1 " ) ) ;
matrixBuilder . addNextValue ( 8 , 5 , this - > parseNumber ( " 1 " ) ) ;
matrixBuilder . newRowGroup ( 9 ) ;
matrixBuilder . newRowGroup ( 9 ) ;
matrixBuilder . addNextValue ( 9 , 3 , 1 ) ;
matrixBuilder . addNextValue ( 9 , 3 , this - > parseNumber ( " 1 " ) ) ;
matrixBuilder . newRowGroup ( 10 ) ;
matrixBuilder . newRowGroup ( 10 ) ;
matrixBuilder . addNextValue ( 10 , 7 , 1 ) ;
matrixBuilder . addNextValue ( 10 , 7 , this - > parseNumber ( " 1 " ) ) ;
matrixBuilder . newRowGroup ( 11 ) ;
matrixBuilder . newRowGroup ( 11 ) ;
matrixBuilder . addNextValue ( 11 , 6 , 1 ) ;
matrixBuilder . addNextValue ( 12 , 8 , 1 ) ;
matrixBuilder . addNextValue ( 11 , 6 , this - > parseNumber ( " 1 " ) ) ;
matrixBuilder . addNextValue ( 12 , 8 , this - > parseNumber ( " 1 " ) ) ;
matrixBuilder . newRowGroup ( 13 ) ;
matrixBuilder . newRowGroup ( 13 ) ;
matrixBuilder . addNextValue ( 13 , 6 , 1 ) ;
matrixBuilder . addNextValue ( 13 , 6 , this - > parseNumber ( " 1 " ) ) ;
matrixBuilder . newRowGroup ( 14 ) ;
matrixBuilder . newRowGroup ( 14 ) ;
matrixBuilder . addNextValue ( 14 , 10 , 1 ) ;
matrixBuilder . addNextValue ( 14 , 10 , this - > parseNumber ( " 1 " ) ) ;
matrixBuilder . newRowGroup ( 15 ) ;
matrixBuilder . newRowGroup ( 15 ) ;
matrixBuilder . addNextValue ( 15 , 9 , 1 ) ;
matrixBuilder . addNextValue ( 16 , 11 , 1 ) ;
matrixBuilder . addNextValue ( 15 , 9 , this - > parseNumber ( " 1 " ) ) ;
matrixBuilder . addNextValue ( 16 , 11 , this - > parseNumber ( " 1 " ) ) ;
matrixBuilder . newRowGroup ( 17 ) ;
matrixBuilder . newRowGroup ( 17 ) ;
matrixBuilder . addNextValue ( 17 , 9 , 1 ) ;
matrixBuilder . addNextValue ( 17 , 9 , this - > parseNumber ( " 1 " ) ) ;
matrixBuilder . newRowGroup ( 18 ) ;
matrixBuilder . newRowGroup ( 18 ) ;
matrixBuilder . addNextValue ( 18 , 5 , 0.4 ) ;
matrixBuilder . addNextValue ( 18 , 8 , 0.3 ) ;
matrixBuilder . addNextValue ( 18 , 11 , 0.3 ) ;
matrixBuilder . addNextValue ( 18 , 5 , this - > parseNumber ( " 0.4 " ) ) ;
matrixBuilder . addNextValue ( 18 , 8 , this - > parseNumber ( " 0.3 " ) ) ;
matrixBuilder . addNextValue ( 18 , 11 , this - > parseNumber ( " 0.3 " ) ) ;
matrixBuilder . newRowGroup ( 19 ) ;
matrixBuilder . newRowGroup ( 19 ) ;
matrixBuilder . addNextValue ( 19 , 7 , 0.7 ) ;
matrixBuilder . addNextValue ( 19 , 12 , 0.3 ) ;
matrixBuilder . addNextValue ( 19 , 7 , this - > parseNumber ( " 0.7 " ) ) ;
matrixBuilder . addNextValue ( 19 , 12 , this - > parseNumber ( " 0.3 " ) ) ;
matrixBuilder . newRowGroup ( 20 ) ;
matrixBuilder . newRowGroup ( 20 ) ;
matrixBuilder . addNextValue ( 20 , 12 , 0.1 ) ;
matrixBuilder . addNextValue ( 20 , 13 , 0.9 ) ;
matrixBuilder . addNextValue ( 21 , 12 , 1 ) ;
matrixBuilder . addNextValue ( 20 , 12 , this - > parseNumber ( " 0.1 " ) ) ;
matrixBuilder . addNextValue ( 20 , 13 , this - > parseNumber ( " 0.9 " ) ) ;
matrixBuilder . addNextValue ( 21 , 12 , this - > parseNumber ( " 1 " ) ) ;
storm : : storage : : SparseMatrix < doubl e> transitionMatrix = matrixBuilder . build ( ) ;
storm : : storage : : SparseMatrix < ValueTyp e> transitionMatrix = matrixBuilder . build ( ) ;
storm : : models : : sparse : : StateLabeling ap ( 15 ) ;
storm : : models : : sparse : : StateLabeling ap ( 15 ) ;
ap . addLabel ( " a " ) ;
ap . addLabel ( " a " ) ;
@ -311,34 +410,59 @@ TEST(LraMdpPrctlModelCheckerTest, LRA) {
ap . addLabelToState ( " a " , 13 ) ;
ap . addLabelToState ( " a " , 13 ) ;
ap . addLabelToState ( " a " , 14 ) ;
ap . addLabelToState ( " a " , 14 ) ;
mdp . reset ( new storm : : models : : sparse : : Mdp < doubl e> ( transitionMatrix , ap ) ) ;
mdp . reset ( new storm : : models : : sparse : : Mdp < ValueTyp e> ( transitionMatrix , ap ) ) ;
storm : : modelchecker : : SparseMdpPrctlModelChecker < storm : : models : : sparse : : Mdp < doubl e> > checker ( * mdp ) ;
storm : : modelchecker : : SparseMdpPrctlModelChecker < storm : : models : : sparse : : Mdp < ValueTyp e> > checker ( * mdp ) ;
std : : shared_ptr < storm : : logic : : Formula const > formula = formulaParser . parseSingleFormulaFromString ( " LRAmax=? [ \" a \" ] " ) ;
std : : shared_ptr < storm : : logic : : Formula const > formula = formulaParser . parseSingleFormulaFromString ( " LRAmax=? [ \" a \" ] " ) ;
std : : unique_ptr < storm : : modelchecker : : CheckResult > result = checker . check ( * formula ) ;
storm : : modelchecker : : ExplicitQuantitativeCheckResult < doubl e> & quantitativeResult1 = result - > asExplicitQuantitativeCheckResult < doubl e> ( ) ;
std : : unique_ptr < storm : : modelchecker : : CheckResult > result = checker . check ( this - > env ( ) , * formula ) ;
storm : : modelchecker : : ExplicitQuantitativeCheckResult < ValueTyp e> & quantitativeResult1 = result - > asExplicitQuantitativeCheckResult < ValueTyp e> ( ) ;
EXPECT_NEAR ( 37. / 60. , quantitativeResult1 [ 0 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( 2. / 3. , quantitativeResult1 [ 3 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( 0.5 , quantitativeResult1 [ 6 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( 1. / 3. , quantitativeResult1 [ 9 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( 31. / 60. , quantitativeResult1 [ 12 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( 101. / 200. , quantitativeResult1 [ 13 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( 31. / 60. , quantitativeResult1 [ 14 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getP recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 37 / 60 " ) , quantitativeResult1 [ 0 ] , this - > p recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 2/3 " ) , quantitativeResult1 [ 3 ] , this - > p recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 0.5 " ) , quantitativeResult1 [ 6 ] , this - > p recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 1/3 " ) , quantitativeResult1 [ 9 ] , this - > p recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 31 / 60 " ) , quantitativeResult1 [ 12 ] , this - > p recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 101 / 200 " ) , quantitativeResult1 [ 13 ] , this - > p recision( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 31 / 60 " ) , quantitativeResult1 [ 14 ] , this - > p recision( ) ) ;
formula = formulaParser . parseSingleFormulaFromString ( " LRAmin=? [ \" a \" ] " ) ;
formula = formulaParser . parseSingleFormulaFromString ( " LRAmin=? [ \" a \" ] " ) ;
result = checker . check ( * formula ) ;
storm : : modelchecker : : ExplicitQuantitativeCheckResult < double > & quantitativeResult2 = result - > asExplicitQuantitativeCheckResult < double > ( ) ;
result = checker . check ( this - > env ( ) , * formula ) ;
storm : : modelchecker : : ExplicitQuantitativeCheckResult < ValueType > & quantitativeResult2 = result - > asExplicitQuantitativeCheckResult < ValueType > ( ) ;
EXPECT_NEAR ( this - > parseNumber ( " 0.1 " ) , quantitativeResult2 [ 0 ] , this - > precision ( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 0 " ) , quantitativeResult2 [ 3 ] , this - > precision ( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 1/3 " ) , quantitativeResult2 [ 6 ] , this - > precision ( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 0 " ) , quantitativeResult2 [ 9 ] , this - > precision ( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 0.1 " ) , quantitativeResult2 [ 12 ] , this - > precision ( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 79 / 300 " ) , quantitativeResult2 [ 13 ] , this - > precision ( ) ) ;
EXPECT_NEAR ( this - > parseNumber ( " 0.1 " ) , quantitativeResult2 [ 14 ] , this - > precision ( ) ) ;
}
}
TYPED_TEST ( LraMdpPrctlModelCheckerTest , cs_nfail ) {
typedef typename TestFixture : : ValueType ValueType ;
std : : string formulasString = " R{ \" grants \" }max=? [ MP ] " ;
auto modelFormulas = this - > buildModelFormulas ( STORM_TEST_RESOURCES_DIR " /mdp/cs_nfail3.nm " , formulasString ) ;
auto model = std : : move ( modelFormulas . first ) ;
auto tasks = this - > getTasks ( modelFormulas . second ) ;
EXPECT_EQ ( 184ul , model - > getNumberOfStates ( ) ) ;
EXPECT_EQ ( 541ul , model - > getNumberOfTransitions ( ) ) ;
ASSERT_EQ ( model - > getType ( ) , storm : : models : : ModelType : : Mdp ) ;
auto mdp = model - > template as < storm : : models : : sparse : : Mdp < ValueType > > ( ) ;
storm : : modelchecker : : SparseMdpPrctlModelChecker < storm : : models : : sparse : : Mdp < ValueType > > checker ( * mdp ) ;
std : : unique_ptr < storm : : modelchecker : : CheckResult > result ;
result = checker . check ( this - > env ( ) , tasks [ 0 ] ) ;
storm : : modelchecker : : ExplicitQuantitativeCheckResult < ValueType > & quantitativeResult = result - > asExplicitQuantitativeCheckResult < ValueType > ( ) ;
EXPECT_NEAR ( this - > parseNumber ( " 333/1000 " ) , quantitativeResult [ * mdp - > getInitialStates ( ) . begin ( ) ] , this - > precision ( ) ) ;
EXPECT_NEAR ( 0.3 / 3. , quantitativeResult2 [ 0 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getPrecision ( ) ) ;
EXPECT_NEAR ( 0.0 , quantitativeResult2 [ 3 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getPrecision ( ) ) ;
EXPECT_NEAR ( 1. / 3. , quantitativeResult2 [ 6 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getPrecision ( ) ) ;
EXPECT_NEAR ( 0.0 , quantitativeResult2 [ 9 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getPrecision ( ) ) ;
EXPECT_NEAR ( 0.3 / 3. , quantitativeResult2 [ 12 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getPrecision ( ) ) ;
EXPECT_NEAR ( .79 / 3. , quantitativeResult2 [ 13 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getPrecision ( ) ) ;
EXPECT_NEAR ( 0.3 / 3. , quantitativeResult2 [ 14 ] , storm : : settings : : getModule < storm : : settings : : modules : : NativeEquationSolverSettings > ( ) . getPrecision ( ) ) ;
}
}
}
}