You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							41 lines
						
					
					
						
							1.2 KiB
						
					
					
				
			
		
		
		
			
			
			
				
					
				
				
					
				
			
		
		
	
	
							41 lines
						
					
					
						
							1.2 KiB
						
					
					
				| import stormpy | |
| import stormpy.core | |
| import stormpy.simulator | |
| 
 | |
| 
 | |
| import stormpy.shields | |
| 
 | |
| import stormpy.examples | |
| import stormpy.examples.files | |
| 
 | |
| 
 | |
| """ | |
| Example of exporting a Optimal Shield | |
| to a file | |
| """ | |
| 
 | |
| def optimal_shield_export(): | |
|     path = stormpy.examples.files.prism_smg_lights | |
|     formula_str = "<<shield>> R{\"differenceWithInterferenceCost\"}min=? [ LRA ]" | |
| 
 | |
|     program = stormpy.parse_prism_program(path) | |
|     formulas = stormpy.parse_properties_for_prism_program(formula_str, program) | |
| 
 | |
|     options = stormpy.BuilderOptions([p.raw_formula for p in formulas]) | |
|     options.set_build_state_valuations(True) | |
|     options.set_build_choice_labels(True) | |
|     options.set_build_all_labels() | |
|     model = stormpy.build_sparse_model_with_options(program, options) | |
|     | |
|     shield_specification = stormpy.logic.ShieldExpression(stormpy.logic.ShieldingType.OPTIMAL) | |
|     result = stormpy.model_checking(model, formulas[0], extract_scheduler=True, shield_expression=shield_specification) | |
|     assert result.has_scheduler | |
|     assert result.has_shield | |
| 
 | |
|     shield = result.shield | |
|      | |
|     stormpy.shields.export_shield(model, shield, "optimal.shield") | |
| 
 | |
| 
 | |
| if __name__ == '__main__': | |
|     optimal_shield_export() |