@ -2,19 +2,22 @@ 
		
	
		
			
				
 
		
	
		
			
				# include  <functional> # include  <functional>  
		
	
		
			
				
 
		
	
		
			
				# include  <boost/optional.hpp>  
		
	
		
			
				
 
		
	
		
			
				# include  "storm/modelchecker/results/FilterType.h" # include  "storm/modelchecker/results/FilterType.h"  
		
	
		
			
				# include  "storm/logic/Formulas.h" # include  "storm/logic/Formulas.h"  
		
	
		
			
				# include  "storm/logic/FragmentSpecification.h" # include  "storm/logic/FragmentSpecification.h"  
		
	
		
			
				# include  "storm/logic/CloneVisitor.h" # include  "storm/logic/CloneVisitor.h"  
		
	
		
			
				# include  "storm/logic/ShieldExpression.h"  
		
	
		
			
				
 
		
	
		
			
				# include  "storm/utility/macros.h" # include  "storm/utility/macros.h"  
		
	
		
			
				# include  "storm/exceptions/InvalidArgumentException.h" # include  "storm/exceptions/InvalidArgumentException.h"  
		
	
		
			
				
 
		
	
		
			
				namespace  storm  { namespace  storm  {  
		
	
		
			
				    namespace  jani  {     namespace  jani  {  
		
	
		
			
				          
		
	
		
			
				
  
		
	
		
			
				        /**         /**  
		
	
		
			
				         *   Property  intervals  as  per  Jani  Specification .    
		
	
		
			
				         *   Property  intervals  as  per  Jani  Specification .  
		
	
		
			
				         *   Currently  mainly  used  to  help  parsing .          *   Currently  mainly  used  to  help  parsing .  
		
	
		
			
				         */          */  
		
	
		
			
				        struct  PropertyInterval  {         struct  PropertyInterval  {  
		
	
	
		
			
				
					
					
					
						
							 
					
				 
				@ -22,29 +25,29 @@ namespace storm { 
		
	
		
			
				            bool  lowerBoundStrict  =  false ;             bool  lowerBoundStrict  =  false ;  
		
	
		
			
				            storm : : expressions : : Expression  upperBound ;             storm : : expressions : : Expression  upperBound ;  
		
	
		
			
				            bool  upperBoundStrict  =  false ;             bool  upperBoundStrict  =  false ;  
		
	
		
			
				              
		
	
		
			
				
  
		
	
		
			
				            bool  hasLowerBound ( )  const  {             bool  hasLowerBound ( )  const  {  
		
	
		
			
				                return  lowerBound . isInitialized ( ) ;                 return  lowerBound . isInitialized ( ) ;  
		
	
		
			
				            }             }  
		
	
		
			
				              
		
	
		
			
				
  
		
	
		
			
				            bool  hasUpperBound ( )  const  {             bool  hasUpperBound ( )  const  {  
		
	
		
			
				                return  upperBound . isInitialized ( ) ;                 return  upperBound . isInitialized ( ) ;  
		
	
		
			
				            }             }  
		
	
		
			
				        } ;         } ;  
		
	
		
			
				          
		
	
		
			
				          
		
	
		
			
				
  
		
	
		
			
				
  
		
	
		
			
				        class  FilterExpression  {         class  FilterExpression  {  
		
	
		
			
				        public :         public :  
		
	
		
			
				            FilterExpression ( )  =  default ;             FilterExpression ( )  =  default ;  
		
	
		
			
				              
		
	
		
			
				
  
		
	
		
			
				            explicit  FilterExpression ( std : : shared_ptr < storm : : logic : : Formula  const >  formula ,  storm : : modelchecker : : FilterType  ft  =  storm : : modelchecker : : FilterType : : VALUES ,  std : : shared_ptr < storm : : logic : : Formula  const >  const &  statesFormula  =  std : : make_shared < storm : : logic : : AtomicLabelFormula > ( " init " ) )  :  formula ( formula ) ,  ft ( ft ) ,  statesFormula ( statesFormula )  {             explicit  FilterExpression ( std : : shared_ptr < storm : : logic : : Formula  const >  formula ,  storm : : modelchecker : : FilterType  ft  =  storm : : modelchecker : : FilterType : : VALUES ,  std : : shared_ptr < storm : : logic : : Formula  const >  const &  statesFormula  =  std : : make_shared < storm : : logic : : AtomicLabelFormula > ( " init " ) )  :  formula ( formula ) ,  ft ( ft ) ,  statesFormula ( statesFormula )  {  
		
	
		
			
				                STORM_LOG_THROW ( statesFormula - > isInFragment ( storm : : logic : : propositional ( ) ) ,  storm : : exceptions : : InvalidArgumentException ,  " Can only filter by propositional formula. " ) ;                 STORM_LOG_THROW ( statesFormula - > isInFragment ( storm : : logic : : propositional ( ) ) ,  storm : : exceptions : : InvalidArgumentException ,  " Can only filter by propositional formula. " ) ;  
		
	
		
			
				            }             }  
		
	
		
			
				              
		
	
		
			
				
  
		
	
		
			
				            std : : shared_ptr < storm : : logic : : Formula  const >  const &  getFormula ( )  const  {             std : : shared_ptr < storm : : logic : : Formula  const >  const &  getFormula ( )  const  {  
		
	
		
			
				                return  formula ;                 return  formula ;  
		
	
		
			
				            }             }  
		
	
		
			
				              
		
	
		
			
				
  
		
	
		
			
				            std : : shared_ptr < storm : : logic : : Formula  const >  const &  getStatesFormula ( )  const  {             std : : shared_ptr < storm : : logic : : Formula  const >  const &  getStatesFormula ( )  const  {  
		
	
		
			
				                return  statesFormula ;                 return  statesFormula ;  
		
	
		
			
				            }             }  
		
	
	
		
			
				
					
					
					
						
							 
					
				 
				@ -52,48 +55,48 @@ namespace storm { 
		
	
		
			
				            storm : : modelchecker : : FilterType  getFilterType ( )  const  {             storm : : modelchecker : : FilterType  getFilterType ( )  const  {  
		
	
		
			
				                return  ft ;                 return  ft ;  
		
	
		
			
				            }             }  
		
	
		
			
				              
		
	
		
			
				
  
		
	
		
			
				            bool  isDefault ( )  const  {             bool  isDefault ( )  const  {  
		
	
		
			
				                return  ( ft  = =  storm : : modelchecker : : FilterType : : VALUES )  & &  statesFormula  & &  statesFormula - > isInitialFormula ( ) ;                 return  ( ft  = =  storm : : modelchecker : : FilterType : : VALUES )  & &  statesFormula  & &  statesFormula - > isInitialFormula ( ) ;  
		
	
		
			
				            }             }  
		
	
		
			
				              
		
	
		
			
				
  
		
	
		
			
				            FilterExpression  substitute ( std : : map < storm : : expressions : : Variable ,  storm : : expressions : : Expression >  const &  substitution )  const  {             FilterExpression  substitute ( std : : map < storm : : expressions : : Variable ,  storm : : expressions : : Expression >  const &  substitution )  const  {  
		
	
		
			
				                return  FilterExpression ( formula - > substitute ( substitution ) ,  ft ,  statesFormula - > substitute ( substitution ) ) ;                 return  FilterExpression ( formula - > substitute ( substitution ) ,  ft ,  statesFormula - > substitute ( substitution ) ) ;  
		
	
		
			
				            }             }  
		
	
		
			
				              
		
	
		
			
				
  
		
	
		
			
				            FilterExpression  substitute ( std : : function < storm : : expressions : : Expression ( storm : : expressions : : Expression  const & ) >  const &  substitutionFunction )  const  {             FilterExpression  substitute ( std : : function < storm : : expressions : : Expression ( storm : : expressions : : Expression  const & ) >  const &  substitutionFunction )  const  {  
		
	
		
			
				                return  FilterExpression ( formula - > substitute ( substitutionFunction ) ,  ft ,  statesFormula - > substitute ( substitutionFunction ) ) ;                 return  FilterExpression ( formula - > substitute ( substitutionFunction ) ,  ft ,  statesFormula - > substitute ( substitutionFunction ) ) ;  
		
	
		
			
				            }             }  
		
	
		
			
				              
		
	
		
			
				
  
		
	
		
			
				            FilterExpression  substituteLabels ( std : : map < std : : string ,  std : : string >  const &  labelSubstitution )  const  {             FilterExpression  substituteLabels ( std : : map < std : : string ,  std : : string >  const &  labelSubstitution )  const  {  
		
	
		
			
				                return  FilterExpression ( formula - > substitute ( labelSubstitution ) ,  ft ,  statesFormula - > substitute ( labelSubstitution ) ) ;                 return  FilterExpression ( formula - > substitute ( labelSubstitution ) ,  ft ,  statesFormula - > substitute ( labelSubstitution ) ) ;  
		
	
		
			
				            }             }  
		
	
		
			
				              
		
	
		
			
				
  
		
	
		
			
				            FilterExpression  substituteRewardModelNames ( std : : map < std : : string ,  std : : string >  const &  rewardModelNameSubstitution )  const  {             FilterExpression  substituteRewardModelNames ( std : : map < std : : string ,  std : : string >  const &  rewardModelNameSubstitution )  const  {  
		
	
		
			
				                return  FilterExpression ( formula - > substituteRewardModelNames ( rewardModelNameSubstitution ) ,  ft ,  statesFormula - > substituteRewardModelNames ( rewardModelNameSubstitution ) ) ;                 return  FilterExpression ( formula - > substituteRewardModelNames ( rewardModelNameSubstitution ) ,  ft ,  statesFormula - > substituteRewardModelNames ( rewardModelNameSubstitution ) ) ;  
		
	
		
			
				            }             }  
		
	
		
			
				              
		
	
		
			
				
  
		
	
		
			
				            FilterExpression  clone ( )  const  {             FilterExpression  clone ( )  const  {  
		
	
		
			
				                storm : : logic : : CloneVisitor  cv ;                 storm : : logic : : CloneVisitor  cv ;  
		
	
		
			
				                return  FilterExpression ( cv . clone ( * formula ) ,  ft ,  cv . clone ( * statesFormula ) ) ;                 return  FilterExpression ( cv . clone ( * formula ) ,  ft ,  cv . clone ( * statesFormula ) ) ;  
		
	
		
			
				            }             }  
		
	
		
			
				              
		
	
		
			
				
  
		
	
		
			
				        private :         private :  
		
	
		
			
				            / /  For  now ,  we  assume  that  the  states  are  always  the  initial  states .             / /  For  now ,  we  assume  that  the  states  are  always  the  initial  states .  
		
	
		
			
				            std : : shared_ptr < storm : : logic : : Formula  const >  formula ;             std : : shared_ptr < storm : : logic : : Formula  const >  formula ;  
		
	
		
			
				            storm : : modelchecker : : FilterType  ft ;             storm : : modelchecker : : FilterType  ft ;  
		
	
		
			
				            std : : shared_ptr < storm : : logic : : Formula  const >  statesFormula ;             std : : shared_ptr < storm : : logic : : Formula  const >  statesFormula ;  
		
	
		
			
				        } ;         } ;  
		
	
		
			
				          
		
	
		
			
				          
		
	
		
			
				
  
		
	
		
			
				
  
		
	
		
			
				        std : : ostream &  operator < < ( std : : ostream &  os ,  FilterExpression  const &  fe ) ;         std : : ostream &  operator < < ( std : : ostream &  os ,  FilterExpression  const &  fe ) ;  
		
	
		
			
				          
		
	
		
			
				          
		
	
		
			
				          
		
	
		
			
				
  
		
	
		
			
				
  
		
	
		
			
				
  
		
	
		
			
				        class  Property  {         class  Property  {  
		
	
		
			
				        public :         public :  
		
	
		
			
				            Property ( )  =  default ;             Property ( )  =  default ;  
		
	
		
			
				              
		
	
		
			
				
  
		
	
		
			
				            /**             /**  
		
	
		
			
				             *  Constructs  the  property              *  Constructs  the  property  
		
	
		
			
				             *  @ param  name  the  name              *  @ param  name  the  name  
		
	
	
		
			
				
					
					
					
						
							 
					
				 
				@ -102,7 +105,7 @@ namespace storm { 
		
	
		
			
				             *  @ param  comment  An  optional  comment              *  @ param  comment  An  optional  comment  
		
	
		
			
				             */              */  
		
	
		
			
				            Property ( std : : string  const &  name ,  std : : shared_ptr < storm : : logic : : Formula  const >  const &  formula ,  std : : set < storm : : expressions : : Variable >  const &  undefinedConstants ,  std : : string  const &  comment  =  " " ) ;             Property ( std : : string  const &  name ,  std : : shared_ptr < storm : : logic : : Formula  const >  const &  formula ,  std : : set < storm : : expressions : : Variable >  const &  undefinedConstants ,  std : : string  const &  comment  =  " " ) ;  
		
	
		
			
				              
		
	
		
			
				
  
		
	
		
			
				            /**             /**  
		
	
		
			
				             *  Constructs  the  property              *  Constructs  the  property  
		
	
		
			
				             *  @ param  name  the  name              *  @ param  name  the  name  
		
	
	
		
			
				
					
					
					
						
							 
					
				 
				@ -110,46 +113,59 @@ namespace storm { 
		
	
		
			
				             *  @ param  comment  An  optional  comment              *  @ param  comment  An  optional  comment  
		
	
		
			
				             */              */  
		
	
		
			
				            Property ( std : : string  const &  name ,  FilterExpression  const &  fe ,  std : : set < storm : : expressions : : Variable >  const &  undefinedConstants ,  std : : string  const &  comment  =  " " ) ;             Property ( std : : string  const &  name ,  FilterExpression  const &  fe ,  std : : set < storm : : expressions : : Variable >  const &  undefinedConstants ,  std : : string  const &  comment  =  " " ) ;  
		
	
		
			
				             
		
	
		
			
				
 
		
	
		
			
				            /**  
		
	
		
			
				             *  Constructs  the  property  
		
	
		
			
				             *  @ param  name  the  name  
		
	
		
			
				             *  @ param  formula  the  formula  representation  
		
	
		
			
				             *  @ param  shieldExpression  the  shielding  expression  
		
	
		
			
				             *  @ param  comment  An  optional  comment  
		
	
		
			
				             */  
		
	
		
			
				            Property ( std : : string  const &  name ,  std : : shared_ptr < storm : : logic : : Formula  const >  const &  formula ,  std : : set < storm : : expressions : : Variable >  const &  undefinedConstants ,  storm : : logic : : ShieldExpression  shieldExpression ,  std : : string  const &  comment  =  " " ) ;  
		
	
		
			
				
 
		
	
		
			
				            /**             /**  
		
	
		
			
				             *  Get  the  provided  name              *  Get  the  provided  name  
		
	
		
			
				             *  @ return  the  name              *  @ return  the  name  
		
	
		
			
				             */              */  
		
	
		
			
				            std : : string  const &  getName ( )  const ;             std : : string  const &  getName ( )  const ;  
		
	
		
			
				             
		
	
		
			
				
  
		
	
		
			
				            /**             /**  
		
	
		
			
				             *  Get  the  provided  comment ,  if  any              *  Get  the  provided  comment ,  if  any  
		
	
		
			
				             *  @ return  the  comment              *  @ return  the  comment  
		
	
		
			
				             */              */  
		
	
		
			
				            std : : string  const &  getComment ( )  const ;             std : : string  const &  getComment ( )  const ;  
		
	
		
			
				              
		
	
		
			
				
  
		
	
		
			
				            Property  substitute ( std : : map < storm : : expressions : : Variable ,  storm : : expressions : : Expression >  const &  substitution )  const ;             Property  substitute ( std : : map < storm : : expressions : : Variable ,  storm : : expressions : : Expression >  const &  substitution )  const ;  
		
	
		
			
				            Property  substitute ( std : : function < storm : : expressions : : Expression ( storm : : expressions : : Expression  const & ) >  const &  substitutionFunction )  const ;             Property  substitute ( std : : function < storm : : expressions : : Expression ( storm : : expressions : : Expression  const & ) >  const &  substitutionFunction )  const ;  
		
	
		
			
				            Property  substituteLabels ( std : : map < std : : string ,  std : : string >  const &  labelSubstitution )  const ;             Property  substituteLabels ( std : : map < std : : string ,  std : : string >  const &  labelSubstitution )  const ;  
		
	
		
			
				            Property  substituteRewardModelNames ( std : : map < std : : string ,  std : : string >  const &  rewardModelNameSubstitution )  const ;             Property  substituteRewardModelNames ( std : : map < std : : string ,  std : : string >  const &  rewardModelNameSubstitution )  const ;  
		
	
		
			
				            Property  clone ( )  const ;             Property  clone ( )  const ;  
		
	
		
			
				              
		
	
		
			
				
  
		
	
		
			
				            FilterExpression  const &  getFilter ( )  const ;             FilterExpression  const &  getFilter ( )  const ;  
		
	
		
			
				              
		
	
		
			
				
  
		
	
		
			
				            std : : string  asPrismSyntax ( )  const ;             std : : string  asPrismSyntax ( )  const ;  
		
	
		
			
				              
		
	
		
			
				
  
		
	
		
			
				            std : : set < storm : : expressions : : Variable >  const &  getUndefinedConstants ( )  const ;             std : : set < storm : : expressions : : Variable >  const &  getUndefinedConstants ( )  const ;  
		
	
		
			
				            bool  containsUndefinedConstants ( )  const ;             bool  containsUndefinedConstants ( )  const ;  
		
	
		
			
				            std : : set < storm : : expressions : : Variable >  getUsedVariablesAndConstants ( )  const ;             std : : set < storm : : expressions : : Variable >  getUsedVariablesAndConstants ( )  const ;  
		
	
		
			
				            std : : set < std : : string >  getUsedLabels ( )  const ;             std : : set < std : : string >  getUsedLabels ( )  const ;  
		
	
		
			
				            void  gatherReferencedRewardModels ( std : : set < std : : string > &  rewardModelNames )  const ;             void  gatherReferencedRewardModels ( std : : set < std : : string > &  rewardModelNames )  const ;  
		
	
		
			
				              
		
	
		
			
				
  
		
	
		
			
				            std : : shared_ptr < storm : : logic : : Formula  const >  getRawFormula ( )  const ;             std : : shared_ptr < storm : : logic : : Formula  const >  getRawFormula ( )  const ;  
		
	
		
			
				             
		
	
		
			
				
 
		
	
		
			
				            bool  isShieldingProperty ( )  const ;  
		
	
		
			
				
 
		
	
		
			
				        private :         private :  
		
	
		
			
				            std : : string  name ;             std : : string  name ;  
		
	
		
			
				            std : : string  comment ;             std : : string  comment ;  
		
	
		
			
				            FilterExpression  filterExpression ;             FilterExpression  filterExpression ;  
		
	
		
			
				            std : : set < storm : : expressions : : Variable >  undefinedConstants ;             std : : set < storm : : expressions : : Variable >  undefinedConstants ;  
		
	
		
			
				
 
		
	
		
			
				            / /  TODO  might  need  refactoring ,  this  cannot  be  expressed  by  JANI  yet ,  so  this  is  totally  wrong  here .  
		
	
		
			
				            boost : : optional < storm : : logic : : ShieldExpression >  shieldingExpression ;  
		
	
		
			
				        } ;         } ;  
		
	
		
			
				         
		
	
		
			
				         
		
	
		
			
				
  
		
	
		
			
				
  
		
	
		
			
				        std : : ostream &  operator < < ( std : : ostream &  os ,  Property  const &  p ) ;         std : : ostream &  operator < < ( std : : ostream &  os ,  Property  const &  p ) ;  
		
	
		
			
				    }     }  
		
	
		
			
				} }