#include "SymbolicToSparseTransformer.h" #include "storm/storage/dd/DdManager.h" #include "storm/storage/dd/Add.h" #include "storm/storage/dd/Bdd.h" #include "storm/models/symbolic/StandardRewardModel.h" #include "storm/models/sparse/StandardRewardModel.h" namespace storm { namespace transformer { template std::shared_ptr> SymbolicDtmcToSparseDtmcTransformer::translate(storm::models::symbolic::Dtmc const& symbolicDtmc) { this->odd = symbolicDtmc.getReachableStates().createOdd(); storm::storage::SparseMatrix transitionMatrix = symbolicDtmc.getTransitionMatrix().toMatrix(this->odd, this->odd); std::unordered_map> rewardModels; for (auto const& rewardModelNameAndModel : symbolicDtmc.getRewardModels()) { boost::optional> stateRewards; boost::optional> stateActionRewards; boost::optional> transitionRewards; if (rewardModelNameAndModel.second.hasStateRewards()) { stateRewards = rewardModelNameAndModel.second.getStateRewardVector().toVector(this->odd); } if (rewardModelNameAndModel.second.hasStateActionRewards()) { stateActionRewards = rewardModelNameAndModel.second.getStateActionRewardVector().toVector(this->odd); } if (rewardModelNameAndModel.second.hasTransitionRewards()) { transitionRewards = rewardModelNameAndModel.second.getTransitionRewardMatrix().toMatrix(this->odd, this->odd); } rewardModels.emplace(rewardModelNameAndModel.first,storm::models::sparse::StandardRewardModel(stateRewards, stateActionRewards, transitionRewards)); } storm::models::sparse::StateLabeling labelling(transitionMatrix.getRowGroupCount()); labelling.addLabel("init", symbolicDtmc.getInitialStates().toVector(this->odd)); labelling.addLabel("deadlock", symbolicDtmc.getDeadlockStates().toVector(this->odd)); for(auto const& label : symbolicDtmc.getLabels()) { labelling.addLabel(label, symbolicDtmc.getStates(label).toVector(this->odd)); } return std::make_shared>(transitionMatrix, labelling, rewardModels); } template storm::dd::Odd const& SymbolicDtmcToSparseDtmcTransformer::getOdd() const { return this->odd; } template std::shared_ptr> SymbolicMdpToSparseMdpTransformer::translate(storm::models::symbolic::Mdp const& symbolicMdp) { storm::dd::Odd odd = symbolicMdp.getReachableStates().createOdd(); storm::storage::SparseMatrix transitionMatrix = symbolicMdp.getTransitionMatrix().toMatrix(symbolicMdp.getNondeterminismVariables(), odd, odd); std::unordered_map> rewardModels; for (auto const& rewardModelNameAndModel : symbolicMdp.getRewardModels()) { boost::optional> stateRewards; boost::optional> stateActionRewards; boost::optional> transitionRewards; if (rewardModelNameAndModel.second.hasStateRewards()) { stateRewards = rewardModelNameAndModel.second.getStateRewardVector().toVector(odd); } if (rewardModelNameAndModel.second.hasStateActionRewards()) { stateActionRewards = rewardModelNameAndModel.second.getStateActionRewardVector().toVector(odd); } if (rewardModelNameAndModel.second.hasTransitionRewards()) { transitionRewards = rewardModelNameAndModel.second.getTransitionRewardMatrix().toMatrix(symbolicMdp.getNondeterminismVariables(), odd, odd); } rewardModels.emplace(rewardModelNameAndModel.first,storm::models::sparse::StandardRewardModel(stateRewards, stateActionRewards, transitionRewards)); } storm::models::sparse::StateLabeling labelling(transitionMatrix.getRowGroupCount()); labelling.addLabel("init", symbolicMdp.getInitialStates().toVector(odd)); labelling.addLabel("deadlock", symbolicMdp.getDeadlockStates().toVector(odd)); for(auto const& label : symbolicMdp.getLabels()) { labelling.addLabel(label, symbolicMdp.getStates(label).toVector(odd)); } return std::make_shared>(transitionMatrix, labelling, rewardModels); } template std::shared_ptr> SymbolicCtmcToSparseCtmcTransformer::translate( storm::models::symbolic::Ctmc const& symbolicCtmc) { storm::dd::Odd odd = symbolicCtmc.getReachableStates().createOdd(); storm::storage::SparseMatrix transitionMatrix = symbolicCtmc.getTransitionMatrix().toMatrix(odd, odd); std::unordered_map> rewardModels; for (auto const& rewardModelNameAndModel : symbolicCtmc.getRewardModels()) { boost::optional> stateRewards; boost::optional> stateActionRewards; boost::optional> transitionRewards; if (rewardModelNameAndModel.second.hasStateRewards()) { stateRewards = rewardModelNameAndModel.second.getStateRewardVector().toVector(odd); } if (rewardModelNameAndModel.second.hasStateActionRewards()) { stateActionRewards = rewardModelNameAndModel.second.getStateActionRewardVector().toVector(odd); } if (rewardModelNameAndModel.second.hasTransitionRewards()) { transitionRewards = rewardModelNameAndModel.second.getTransitionRewardMatrix().toMatrix(odd, odd); } rewardModels.emplace(rewardModelNameAndModel.first,storm::models::sparse::StandardRewardModel(stateRewards, stateActionRewards, transitionRewards)); } storm::models::sparse::StateLabeling labelling(transitionMatrix.getRowGroupCount()); labelling.addLabel("init", symbolicCtmc.getInitialStates().toVector(odd)); labelling.addLabel("deadlock", symbolicCtmc.getDeadlockStates().toVector(odd)); for(auto const& label : symbolicCtmc.getLabels()) { labelling.addLabel(label, symbolicCtmc.getStates(label).toVector(odd)); } return std::make_shared>(transitionMatrix, labelling, rewardModels); } template class SymbolicDtmcToSparseDtmcTransformer; template class SymbolicDtmcToSparseDtmcTransformer; template class SymbolicDtmcToSparseDtmcTransformer; template class SymbolicDtmcToSparseDtmcTransformer; template class SymbolicMdpToSparseMdpTransformer; template class SymbolicMdpToSparseMdpTransformer; template class SymbolicMdpToSparseMdpTransformer; template class SymbolicCtmcToSparseCtmcTransformer; template class SymbolicCtmcToSparseCtmcTransformer; template class SymbolicCtmcToSparseCtmcTransformer; } }