18 std::set<storm::expressions::Variable>
const& rowVariables,
20 std::set<storm::expressions::Variable>
const& columnVariables,
21 std::vector<std::pair<storm::expressions::Variable, storm::expressions::Variable>>
const& rowColumnMetaVariablePairs,
22 std::map<std::string, storm::expressions::Expression> labelToExpressionMap,
23 std::unordered_map<std::string, RewardModelType>
const& rewardModels)
25 rowVariables, rowExpressionAdapter, columnVariables, rowColumnMetaVariablePairs, labelToExpressionMap, rewardModels) {
32 std::set<storm::expressions::Variable>
const& rowVariables, std::set<storm::expressions::Variable>
const& columnVariables,
33 std::vector<std::pair<storm::expressions::Variable, storm::expressions::Variable>>
const& rowColumnMetaVariablePairs,
34 std::map<std::string,
storm::dd::Bdd<Type>> labelToBddMap, std::unordered_map<std::string, RewardModelType>
const& rewardModels)
36 rowVariables, columnVariables, rowColumnMetaVariablePairs, labelToBddMap, rewardModels) {
51 std::unordered_map<std::string, NewRewardModelType> newRewardModels;
53 for (
auto const& e : this->getRewardModels()) {
54 newRewardModels.emplace(e.first, e.second.template toValueType<NewValueType>());
57 auto newLabelToBddMap = this->getLabelToBddMap();
58 newLabelToBddMap.erase(
"init");
59 newLabelToBddMap.erase(
"deadlock");
61 return std::make_shared<Dtmc<Type, NewValueType>>(this->getManagerAsSharedPointer(), this->getReachableStates(), this->getInitialStates(),
62 this->getDeadlockStates(), this->getTransitionMatrix().template toValueType<NewValueType>(),
63 this->getRowVariables(), this->getColumnVariables(), this->getRowColumnMetaVariablePairs(),
64 newLabelToBddMap, newRewardModels);
Dtmc(storm::storage::SparseMatrix< ValueType > const &transitionMatrix, storm::models::sparse::StateLabeling const &stateLabeling, std::unordered_map< std::string, RewardModelType > const &rewardModels=std::unordered_map< std::string, RewardModelType >())
Constructs a model from the given data.