|
|
@ -16,6 +16,7 @@ |
|
|
|
#include <boost/functional/hash.hpp> |
|
|
|
#include <map> |
|
|
|
#include <queue> |
|
|
|
#include <set> |
|
|
|
#include <iostream> |
|
|
|
#include <memory> |
|
|
|
#include <list> |
|
|
@ -208,12 +209,8 @@ private: |
|
|
|
* @params state State to be expanded |
|
|
|
* @params res List of |
|
|
|
*/ |
|
|
|
void addUnlabeledTransitions(const StateType* state, std::list<std::map<uint_fast64_t, double>>& res) { |
|
|
|
std::cout << "exploring ( "; |
|
|
|
for (auto it : state->first) std::cout << it << ", "; |
|
|
|
for (auto it : state->second) std::cout << it << ", "; |
|
|
|
std::cout << ")" << std::endl; |
|
|
|
|
|
|
|
void addUnlabeledTransitions(const uint_fast64_t stateID, std::list<std::map<uint_fast64_t, double>>& res) { |
|
|
|
const StateType* state = this->allStates[stateID]; |
|
|
|
// Iterate over all modules. |
|
|
|
for (uint_fast64_t i = 0; i < program->getNumberOfModules(); ++i) { |
|
|
|
storm::ir::Module const& module = program->getModule(i); |
|
|
@ -241,12 +238,69 @@ private: |
|
|
|
(*states)[newStateId] = update.getLikelihoodExpression()->getValueAsDouble(state); |
|
|
|
} else { |
|
|
|
(*states)[newStateId] += update.getLikelihoodExpression()->getValueAsDouble(state); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
void addLabeledTransitions(const uint_fast64_t stateID, std::list<std::map<uint_fast64_t, double>>& res) { |
|
|
|
// Create a copy of the current state, as we will free intermediate states... |
|
|
|
StateType* state = new StateType(*this->allStates[stateID]); |
|
|
|
for (std::string action : this->program->getActions()) { |
|
|
|
std::unique_ptr<std::list<std::list<storm::ir::Command>>> cmds = this->getActiveCommandsByAction(state, action); |
|
|
|
|
|
|
|
// Start with current state |
|
|
|
std::unordered_map<StateType*, double, StateHash, StateCompare> resultStates; |
|
|
|
resultStates[state] = 1.0; |
|
|
|
|
|
|
|
for (std::list<storm::ir::Command> module : *cmds) { |
|
|
|
if (resultStates.size() == 0) break; |
|
|
|
std::unordered_map<StateType*, double, StateHash, StateCompare> newStates; |
|
|
|
|
|
|
|
// Iterate over all commands within this module. |
|
|
|
for (storm::ir::Command command : module) { |
|
|
|
// Iterate over all updates of this command. |
|
|
|
for (uint_fast64_t k = 0; k < command.getNumberOfUpdates(); ++k) { |
|
|
|
storm::ir::Update const& update = command.getUpdate(k); |
|
|
|
|
|
|
|
// Iterate over all resultStates. |
|
|
|
for (auto it : resultStates) { |
|
|
|
// Apply the new update and get resulting state. |
|
|
|
StateType* newState = this->applyUpdate(it.first, update); |
|
|
|
// Insert the new state into newStates array. |
|
|
|
// Take care of calculation of likelihood, combine identical states. |
|
|
|
auto s = newStates.find(newState); |
|
|
|
if (s == newStates.end()) { |
|
|
|
newStates[newState] = it.second * update.getLikelihoodExpression()->getValueAsDouble(it.first); |
|
|
|
} else { |
|
|
|
newStates[newState] += it.second * update.getLikelihoodExpression()->getValueAsDouble(it.first); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
for (auto it: resultStates) { |
|
|
|
delete it.first; |
|
|
|
} |
|
|
|
// Move new states to resultStates. |
|
|
|
resultStates.clear(); |
|
|
|
resultStates.insert(newStates.begin(), newStates.end()); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
res.emplace_back(); |
|
|
|
std::map<uint_fast64_t, double>* states = &res.back(); |
|
|
|
|
|
|
|
// Now add our final result states to our global result. |
|
|
|
for (auto it : resultStates) { |
|
|
|
uint_fast64_t newStateID = this->getOrAddStateId(it.first); |
|
|
|
(*states)[newStateID] = it.second; |
|
|
|
} |
|
|
|
this->numberOfTransitions += states->size(); |
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
void dump(std::map<uint_fast64_t, double>& obj) { |
|
|
|
std::cout << "Some map:" << std::endl; |
|
|
|
for (auto it: obj) { |
|
|
@ -262,6 +316,16 @@ private: |
|
|
|
template<class T> |
|
|
|
std::shared_ptr<storm::storage::SparseMatrix<T>> buildDTMCMatrix(std::map<uint_fast64_t, std::list<std::map<uint_fast64_t, double>>> intermediate) { |
|
|
|
std::shared_ptr<storm::storage::SparseMatrix<T>> result(new storm::storage::SparseMatrix<T>(allStates.size())); |
|
|
|
uint_fast64_t numberOfTransitions = 0; |
|
|
|
for (uint_fast64_t state = 0; state < this->allStates.size(); state++) { |
|
|
|
std::set<uint_fast64_t> set; |
|
|
|
for (auto choice : intermediate[state]) { |
|
|
|
for (auto elem : choice) { |
|
|
|
set.insert(elem.first); |
|
|
|
} |
|
|
|
} |
|
|
|
numberOfTransitions += set.size(); |
|
|
|
} |
|
|
|
result->initialize(numberOfTransitions); |
|
|
|
for (uint_fast64_t state = 0; state < this->allStates.size(); state++) { |
|
|
|
//if (intermediate[state].size() > 1) WARNING; |
|
|
@ -272,6 +336,7 @@ private: |
|
|
|
map[elem.first] += elem.second * factor; |
|
|
|
} |
|
|
|
} |
|
|
|
std::cout << "adding " << map.size() << " elements" << std::endl; |
|
|
|
for (auto it : map) { |
|
|
|
result->addNextValue(state, it.first, it.second); |
|
|
|
} |
|
|
@ -284,6 +349,7 @@ private: |
|
|
|
/*! |
|
|
|
* Create matrix from intermediate mapping, assuming it is a mdp model. |
|
|
|
* @param intermediate Intermediate representation of transition mapping. |
|
|
|
* @param choices Overall number of choices for all nodes. |
|
|
|
* @return result matrix. |
|
|
|
*/ |
|
|
|
template<class T> |
|
|
@ -313,7 +379,8 @@ private: |
|
|
|
std::map<uint_fast64_t, std::list<std::map<uint_fast64_t, double>>> intermediate; |
|
|
|
for (uint_fast64_t curIndex = this->getOrAddStateId(this->buildInitialState()); curIndex < this->allStates.size(); curIndex++) |
|
|
|
{ |
|
|
|
this->addUnlabeledTransitions(this->allStates[curIndex], intermediate[curIndex]); |
|
|
|
this->addUnlabeledTransitions(curIndex, intermediate[curIndex]); |
|
|
|
this->addLabeledTransitions(curIndex, intermediate[curIndex]); |
|
|
|
|
|
|
|
choices += intermediate[curIndex].size(); |
|
|
|
if (intermediate[curIndex].size() == 0) { |
|
|
@ -329,6 +396,7 @@ private: |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
std::cout << "number of Transitions: " << this->numberOfTransitions << std::endl; |
|
|
|
switch (this->program->getModelType()) { |
|
|
|
case storm::ir::Program::DTMC: |
|
|
|
case storm::ir::Program::CTMC: |
|
|
|