|
|
@ -49,6 +49,7 @@ namespace storm { |
|
|
|
} |
|
|
|
|
|
|
|
storm::storage::SparseMatrixBuilder<typename Model::ValueType> builder(0, 0, 0, false, deterministic ? false : true, 0); |
|
|
|
std::size_t curRow = 0; |
|
|
|
while (!todo.empty()) { |
|
|
|
state_type prodIndexFrom = todo.front(); |
|
|
|
todo.pop_front(); |
|
|
@ -79,7 +80,33 @@ namespace storm { |
|
|
|
builder.addNextValue(prodIndexFrom, prodIndexTo, entry.getValue()); |
|
|
|
} |
|
|
|
} else { |
|
|
|
throw std::runtime_error("nondeterministic product not yet supported"); |
|
|
|
std::size_t numRows = originalMatrix.getRowGroupSize(from.first); |
|
|
|
builder.newRowGroup(curRow); |
|
|
|
for (std::size_t i = 0; i < numRows; i++) { |
|
|
|
auto const& row = originalMatrix.getRow(from.first, i); |
|
|
|
for (auto const& entry : row) { |
|
|
|
state_type t = entry.getColumn(); |
|
|
|
state_type p = prodOp.getSuccessor(from.first, from.second, t); |
|
|
|
// std::cout << " p = " << p << "\n"; |
|
|
|
product_state_type t_p(t, p); |
|
|
|
state_type prodIndexTo; |
|
|
|
auto it = productStateToProductIndex.find(t_p); |
|
|
|
if (it == productStateToProductIndex.end()) { |
|
|
|
prodIndexTo = nextState++; |
|
|
|
todo.push_back(prodIndexTo); |
|
|
|
productIndexToProductState.push_back(t_p); |
|
|
|
productStateToProductIndex[t_p] = prodIndexTo; |
|
|
|
// std::cout << " Adding " << t_p.first << "," << t_p.second << " as " << prodIndexTo << "\n"; |
|
|
|
} else { |
|
|
|
prodIndexTo = it->second; |
|
|
|
} |
|
|
|
// std::cout << " " << t_p.first << "," << t_p.second << ": to = " << prodIndexTo << "\n"; |
|
|
|
|
|
|
|
// std::cout << " addNextValue(" << prodIndexFrom << "," << prodIndexTo << "," << entry.getValue() << ")\n"; |
|
|
|
builder.addNextValue(curRow, prodIndexTo, entry.getValue()); |
|
|
|
} |
|
|
|
curRow++; |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|