Browse Source

properly scaling state-action rewards for DTMCs in JANI model now

Former-commit-id: a70c5c3c6e [formerly 8d2a346735]
Former-commit-id: cad11b1b3f
tempestpy_adaptions
dehnert 8 years ago
parent
commit
24e89ecce6
  1. 8
      src/builder/DdJaniModelBuilder.cpp

8
src/builder/DdJaniModelBuilder.cpp

@ -1752,7 +1752,13 @@ namespace storm {
storm::dd::Bdd<Type> postprocessSystem(storm::jani::Model const& model, ComposerResult<Type, ValueType>& system, CompositionVariables<Type, ValueType> const& variables, typename DdJaniModelBuilder<Type, ValueType>::Options const& options) { storm::dd::Bdd<Type> postprocessSystem(storm::jani::Model const& model, ComposerResult<Type, ValueType>& system, CompositionVariables<Type, ValueType> const& variables, typename DdJaniModelBuilder<Type, ValueType>::Options const& options) {
// For DTMCs, we normalize each row to 1 (to account for non-determinism). // For DTMCs, we normalize each row to 1 (to account for non-determinism).
if (model.getModelType() == storm::jani::ModelType::DTMC) { if (model.getModelType() == storm::jani::ModelType::DTMC) {
system.transitions = system.transitions / system.transitions.sumAbstract(variables.columnMetaVariables);
storm::dd::Add<Type, ValueType> stateToNumberOfChoices = system.transitions.sumAbstract(variables.columnMetaVariables);
system.transitions = system.transitions / stateToNumberOfChoices;
// Scale all state-action rewards.
for (auto& entry : system.transientEdgeAssignments) {
entry.second = entry.second / stateToNumberOfChoices;
}
} }
// If we were asked to treat some states as terminal states, we cut away their transitions now. // If we were asked to treat some states as terminal states, we cut away their transitions now.

Loading…
Cancel
Save