Browse Source

Fixed off-by-one for our matrix-vector multiplication.

tempestpy_adaptions
dehnert 12 years ago
parent
commit
bba72e452b
  1. 18
      src/storage/SparseMatrix.h

18
src/storage/SparseMatrix.h

@ -955,21 +955,25 @@ public:
*/
void multiplyWithVector(std::vector<T> const& vector, std::vector<T>& result) const {
// Initialize two iterators that
ConstRowsIterator elementIt(*this);
ConstRowsIterator elementIte(*this, 1);
ConstRowsIterator matrixElementIt(*this);
ConstRowsIterator matrixElementIte(*this);
// Iterate over all positions of the result vector and compute its value as the scalar
// product of the corresponding row with the input vector.
// Note that only the end iterator has to be moved by one row, because the other iterator
// is automatically moved forward one row by the inner loop.
for (auto it = result.begin(), ite = result.end(); it != ite; ++it, elementIte.moveToNextRow()) {
*it = storm::utility::constGetZero<T>();
for (auto& element : result) {
// Put the past-the-end iterator to the correct position.
matrixElementIte.moveToNextRow();
// Initialize the result to be 0.
element = storm::utility::constGetZero<T>();
// Perform the scalar product.
for (; elementIt != elementIte; ++elementIt) {
*it += elementIt.value() * vector[elementIt.column()];
for (; matrixElementIt != matrixElementIte; ++matrixElementIt) {
element += matrixElementIt.value() * vector[matrixElementIt.column()];
}
}
}
}
/*!

Loading…
Cancel
Save