@ -139,8 +139,8 @@ namespace storm {
return iDecl ;
return iDecl ;
}
}
modernjson : : json FormulaToJaniJson : : translate ( storm : : logic : : Formula const & formula , bool continuousTime ) {
FormulaToJaniJson translator ( continuousTime ) ;
modernjson : : json FormulaToJaniJson : : translate ( storm : : logic : : Formula const & formula , storm : : jani : : Model const & model ) {
FormulaToJaniJson translator ( model ) ;
return boost : : any_cast < modernjson : : json > ( formula . accept ( translator ) ) ;
return boost : : any_cast < modernjson : : json > ( formula . accept ( translator ) ) ;
}
}
@ -334,35 +334,37 @@ namespace storm {
boost : : any FormulaToJaniJson : : visit ( storm : : logic : : RewardOperatorFormula const & f , boost : : any const & data ) const {
boost : : any FormulaToJaniJson : : visit ( storm : : logic : : RewardOperatorFormula const & f , boost : : any const & data ) const {
modernjson : : json opDecl ;
modernjson : : json opDecl ;
std : : vector < std : : string > accvec ;
std : : vector < std : : string > accvec ;
if ( continuous ) {
accvec . push_back ( " time " ) ;
} else {
if ( model . isDiscreteTimeModel ( ) ) {
accvec . push_back ( " steps " ) ;
accvec . push_back ( " steps " ) ;
} else {
accvec . push_back ( " time " ) ;
}
}
if ( f . hasBound ( ) ) {
if ( f . hasBound ( ) ) {
auto bound = f . getBound ( ) ;
auto bound = f . getBound ( ) ;
opDecl [ " op " ] = comparisonTypeToJani ( bound . comparisonType ) ;
opDecl [ " op " ] = comparisonTypeToJani ( bound . comparisonType ) ;
if ( f . hasOptimalityType ( ) ) {
if ( f . hasOptimalityType ( ) ) {
opDecl [ " left " ] [ " op " ] = f . getOptimalityType ( ) = = storm : : solver : : OptimizationDirection : : Minimize ? " Emin " : " Emax " ;
opDecl [ " left " ] [ " op " ] = f . getOptimalityType ( ) = = storm : : solver : : OptimizationDirection : : Minimize ? " Emin " : " Emax " ;
opDecl [ " left " ] [ " reach " ] = boost : : any_cast < modernjson : : json > ( f . getSubformula ( ) . accept ( * this , boost : : none ) ) ;
opDecl [ " left " ] [ " reach " ] = boost : : any_cast < modernjson : : json > ( f . getSubformula ( ) . asEventuallyFormula ( ) . getSubformula ( ) . a ccept ( * this , boost : : none ) ) ;
} else {
} else {
opDecl [ " left " ] [ " op " ] = ( bound . comparisonType = = storm : : logic : : ComparisonType : : Less | | bound . comparisonType = = storm : : logic : : ComparisonType : : LessEqual ) ? " Emax " : " Emin " ;
opDecl [ " left " ] [ " op " ] = ( bound . comparisonType = = storm : : logic : : ComparisonType : : Less | | bound . comparisonType = = storm : : logic : : ComparisonType : : LessEqual ) ? " Emax " : " Emin " ;
opDecl [ " left " ] [ " reach " ] = boost : : any_cast < modernjson : : json > ( f . getSubformula ( ) . accept ( * this , boost : : none ) ) ;
opDecl [ " left " ] [ " reach " ] = boost : : any_cast < modernjson : : json > ( f . getSubformula ( ) . asEventuallyFormula ( ) . getSubformula ( ) . a ccept ( * this , boost : : none ) ) ;
}
}
opDecl [ " left " ] [ " exp " ] = f . hasRewardModelName ( ) ? f . getRewardModelName ( ) : " DEFAULT " ;
STORM_LOG_THROW ( f . hasRewardModelName ( ) , storm : : exceptions : : NotSupportedException , " Reward name has to be specified for Jani-conversion " ) ;
opDecl [ " left " ] [ " exp " ] = f . getRewardModelName ( ) ;
opDecl [ " left " ] [ " accumulate " ] = modernjson : : json ( accvec ) ;
opDecl [ " left " ] [ " accumulate " ] = modernjson : : json ( accvec ) ;
opDecl [ " right " ] = numberToJson ( bound . threshold ) ;
opDecl [ " right " ] = numberToJson ( bound . threshold ) ;
} else {
} else {
if ( f . hasOptimalityType ( ) ) {
if ( f . hasOptimalityType ( ) ) {
opDecl [ " op " ] = f . getOptimalityType ( ) = = storm : : solver : : OptimizationDirection : : Minimize ? " Emin " : " Emax " ;
opDecl [ " op " ] = f . getOptimalityType ( ) = = storm : : solver : : OptimizationDirection : : Minimize ? " Emin " : " Emax " ;
opDecl [ " reach " ] = boost : : any_cast < modernjson : : json > ( f . getSubformula ( ) . accept ( * this , boost : : none ) ) ;
opDecl [ " reach " ] = boost : : any_cast < modernjson : : json > ( f . getSubformula ( ) . asEventuallyFormula ( ) . getSubformula ( ) . a ccept ( * this , boost : : none ) ) ;
} else {
} else {
// TODO add checks
// TODO add checks
opDecl [ " op " ] = " Emin " ;
opDecl [ " op " ] = " Emin " ;
opDecl [ " reach " ] = boost : : any_cast < modernjson : : json > ( f . getSubformula ( ) . accept ( * this , boost : : none ) ) ;
opDecl [ " reach " ] = boost : : any_cast < modernjson : : json > ( f . getSubformula ( ) . asEventuallyFormula ( ) . getSubformula ( ) . a ccept ( * this , boost : : none ) ) ;
}
}
opDecl [ " exp " ] = f . hasRewardModelName ( ) ? f . getRewardModelName ( ) : " DEFAULT " ;
STORM_LOG_THROW ( f . hasRewardModelName ( ) , storm : : exceptions : : NotSupportedException , " Reward name has to be specified for Jani-conversion " ) ;
opDecl [ " exp " ] = f . getRewardModelName ( ) ;
opDecl [ " accumulate " ] = modernjson : : json ( accvec ) ;
opDecl [ " accumulate " ] = modernjson : : json ( accvec ) ;
}
}
return opDecl ;
return opDecl ;
@ -520,7 +522,7 @@ namespace storm {
}
}
JsonExporter exporter ;
JsonExporter exporter ;
exporter . convertModel ( janiModel ) ;
exporter . convertModel ( janiModel ) ;
exporter . convertProperties ( formulas , ! janiModel . isDiscreteTimeModel ( ) ) ;
exporter . convertProperties ( formulas , janiModel ) ;
os < < exporter . finalize ( ) . dump ( 4 ) < < std : : endl ;
os < < exporter . finalize ( ) . dump ( 4 ) < < std : : endl ;
}
}
@ -732,23 +734,23 @@ namespace storm {
}
}
}
}
modernjson : : json convertFilterExpression ( storm : : jani : : FilterExpression const & fe , bool continuousM odel) {
modernjson : : json convertFilterExpression ( storm : : jani : : FilterExpression const & fe , storm : : jani : : Model const & m odel) {
modernjson : : json propDecl ;
modernjson : : json propDecl ;
propDecl [ " states " ] [ " op " ] = " initial " ;
propDecl [ " states " ] [ " op " ] = " initial " ;
propDecl [ " op " ] = " filter " ;
propDecl [ " op " ] = " filter " ;
propDecl [ " fun " ] = janiFilterTypeString ( fe . getFilterType ( ) ) ;
propDecl [ " fun " ] = janiFilterTypeString ( fe . getFilterType ( ) ) ;
propDecl [ " values " ] = FormulaToJaniJson : : translate ( * fe . getFormula ( ) , continuousM odel) ;
propDecl [ " values " ] = FormulaToJaniJson : : translate ( * fe . getFormula ( ) , m odel) ;
return propDecl ;
return propDecl ;
}
}
void JsonExporter : : convertProperties ( std : : vector < std : : shared_ptr < storm : : logic : : Formula const > > const & formulas , bool continuousM odel) {
void JsonExporter : : convertProperties ( std : : vector < std : : shared_ptr < storm : : logic : : Formula const > > const & formulas , storm : : jani : : Model const & m odel) {
std : : vector < modernjson : : json > properties ;
std : : vector < modernjson : : json > properties ;
uint64_t index = 0 ;
uint64_t index = 0 ;
for ( auto const & f : formulas ) {
for ( auto const & f : formulas ) {
modernjson : : json propDecl ;
modernjson : : json propDecl ;
propDecl [ " name " ] = " prop " + std : : to_string ( index ) ;
propDecl [ " name " ] = " prop " + std : : to_string ( index ) ;
propDecl [ " expression " ] = convertFilterExpression ( storm : : jani : : FilterExpression ( f ) , continuousM odel) ;
propDecl [ " expression " ] = convertFilterExpression ( storm : : jani : : FilterExpression ( f ) , m odel) ;
+ + index ;
+ + index ;
properties . push_back ( propDecl ) ;
properties . push_back ( propDecl ) ;
}
}