@ -4,6 +4,7 @@
# include <storm-pomdp/transformer/BinaryPomdpTransformer.h>
# include <storm-pomdp/transformer/BinaryPomdpTransformer.h>
# include <storm-pomdp/transformer/ApplyFiniteSchedulerToPomdp.h>
# include <storm-pomdp/transformer/ApplyFiniteSchedulerToPomdp.h>
# include <storm-pomdp/transformer/ObservationTraceUnfolder.h>
# include <storm-pomdp/transformer/ObservationTraceUnfolder.h>
# include <storm/storage/expressions/ExpressionManager.h>
template < typename ValueType >
template < typename ValueType >
std : : shared_ptr < storm : : models : : sparse : : Pomdp < ValueType > > make_canonic ( storm : : models : : sparse : : Pomdp < ValueType > const & pomdp ) {
std : : shared_ptr < storm : : models : : sparse : : Pomdp < ValueType > > make_canonic ( storm : : models : : sparse : : Pomdp < ValueType > const & pomdp ) {
@ -30,8 +31,8 @@ std::shared_ptr<storm::models::sparse::Model<storm::RationalFunction>> apply_unk
}
}
template < typename ValueType >
template < typename ValueType >
std : : shared_ptr < storm : : models : : sparse : : Mdp < ValueType > > unfold_trace ( storm : : models : : sparse : : Pomdp < ValueType > const & pomdp , std : : vector < uint32_t > const & observationTrace , std : : vector < ValueType > const & riskDef ) {
storm : : pomdp : : ObservationTraceUnfolder < ValueType > transformer ( pomdp ) ;
std : : shared_ptr < storm : : models : : sparse : : Mdp < ValueType > > unfold_trace ( storm : : models : : sparse : : Pomdp < ValueType > const & pomdp , std : : shared_ptr < storm : : expressions : : ExpressionManager > & exprManager , std : : vector < uint32_t > const & observationTrace , std : : vector < ValueType > const & riskDef ) {
storm : : pomdp : : ObservationTraceUnfolder < ValueType > transformer ( pomdp , exprManager ) ;
return transformer . transform ( observationTrace , riskDef ) ;
return transformer . transform ( observationTrace , riskDef ) ;
}
}
@ -53,7 +54,7 @@ void define_transformations(py::module& m, std::string const& vtSuffix) {
m . def ( ( " _unfold_memory_ " + vtSuffix ) . c_str ( ) , & unfold_memory < ValueType > , " Unfold memory into a POMDP " , py : : arg ( " pomdp " ) , py : : arg ( " memorystructure " ) , py : : arg ( " memorylabels " ) = false , py : : arg ( " keep_state_valuations " ) = false ) ;
m . def ( ( " _unfold_memory_ " + vtSuffix ) . c_str ( ) , & unfold_memory < ValueType > , " Unfold memory into a POMDP " , py : : arg ( " pomdp " ) , py : : arg ( " memorystructure " ) , py : : arg ( " memorylabels " ) = false , py : : arg ( " keep_state_valuations " ) = false ) ;
m . def ( ( " _make_simple_ " + vtSuffix ) . c_str ( ) , & make_simple < ValueType > , " Make POMDP simple " , py : : arg ( " pomdp " ) , py : : arg ( " keep_state_valuations " ) = false ) ;
m . def ( ( " _make_simple_ " + vtSuffix ) . c_str ( ) , & make_simple < ValueType > , " Make POMDP simple " , py : : arg ( " pomdp " ) , py : : arg ( " keep_state_valuations " ) = false ) ;
m . def ( ( " _apply_unknown_fsc_ " + vtSuffix ) . c_str ( ) , & apply_unknown_fsc < ValueType > , " Apply unknown FSC " , py : : arg ( " pomdp " ) , py : : arg ( " application_mode " ) = storm : : transformer : : PomdpFscApplicationMode : : SIMPLE_LINEAR ) ;
m . def ( ( " _apply_unknown_fsc_ " + vtSuffix ) . c_str ( ) , & apply_unknown_fsc < ValueType > , " Apply unknown FSC " , py : : arg ( " pomdp " ) , py : : arg ( " application_mode " ) = storm : : transformer : : PomdpFscApplicationMode : : SIMPLE_LINEAR ) ;
m . def ( ( " _unfold_trace_ " + vtSuffix ) . c_str ( ) , & unfold_trace < ValueType > , " Unfold observed trace " , py : : arg ( " pomdp " ) , py : : arg ( " observation_trace " ) , py : : arg ( " risk_definition " ) ) ;
m . def ( ( " _unfold_trace_ " + vtSuffix ) . c_str ( ) , & unfold_trace < ValueType > , " Unfold observed trace " , py : : arg ( " pomdp " ) , py : : arg ( " expression_manager " ) , py : : arg ( " observation_trace " ) , py : : arg ( " risk_definition " ) ) ;
}
}
template void define_transformations < double > ( py : : module & m , std : : string const & vtSuffix ) ;
template void define_transformations < double > ( py : : module & m , std : : string const & vtSuffix ) ;