|
|
@ -778,13 +778,13 @@ namespace storm { |
|
|
|
*/ |
|
|
|
template<typename NewValueType> |
|
|
|
SparseMatrix<NewValueType> toValueType() const { |
|
|
|
std::vector<MatrixEntry<NewValueType>> new_columnsAndValues; |
|
|
|
std::vector<uint_fast64_t> new_rowIndications(rowIndications); |
|
|
|
std::vector<uint_fast64_t> new_rowGroupIndices(rowGroupIndices); |
|
|
|
std::vector<MatrixEntry<SparseMatrix::index_type, NewValueType>> new_columnsAndValues; |
|
|
|
std::vector<SparseMatrix::index_type> new_rowIndications(rowIndications); |
|
|
|
std::vector<SparseMatrix::index_type> new_rowGroupIndices(rowGroupIndices); |
|
|
|
|
|
|
|
new_columnsAndValues.resize(columnsAndValues.size()); |
|
|
|
for (size_t i = 0, size = columnsAndValues.size(); i < size; ++i) { |
|
|
|
new_columnsAndValues.at(i) = MatrixEntry<NewValueType>(columnsAndValues.at(i).getColumn(), static_cast<NewValueType>(columnsAndValues.at(i).getValue())); |
|
|
|
new_columnsAndValues.at(i) = MatrixEntry<SparseMatrix::index_type, NewValueType>(columnsAndValues.at(i).getColumn(), static_cast<NewValueType>(columnsAndValues.at(i).getValue())); |
|
|
|
} |
|
|
|
|
|
|
|
return SparseMatrix<NewValueType>(columnCount, std::move(new_rowIndications), std::move(new_columnsAndValues), std::move(new_rowGroupIndices)); |
|
|
|