Browse Source

update sparse matrix with duplicate row detection within rowgroups

Former-commit-id: 282803c02f
tempestpy_adaptions
sjunges 9 years ago
parent
commit
c8d9ec5535
  1. 43
      src/storage/SparseMatrix.cpp
  2. 15
      src/storage/SparseMatrix.h

43
src/storage/SparseMatrix.cpp

@ -65,6 +65,17 @@ namespace storm {
return MatrixEntry(this->getColumn(), this->getValue() * factor);
}
template<typename IndexType, typename ValueType>
bool MatrixEntry<IndexType, ValueType>::operator==(MatrixEntry<IndexType, ValueType> const& other) const {
return this->entry.first == other.entry.first && this->entry.second == other.entry.second;
}
template<typename IndexType, typename ValueType>
bool MatrixEntry<IndexType, ValueType>::operator!=(MatrixEntry<IndexType, ValueType> const& other) const {
return !(*this == other);
}
template<typename IndexTypePrime, typename ValueTypePrime>
std::ostream& operator<<(std::ostream& out, MatrixEntry<IndexTypePrime, ValueTypePrime> const& entry) {
out << "(" << entry.getColumn() << ", " << entry.getValue() << ")";
@ -487,6 +498,38 @@ namespace storm {
}
}
template<typename ValueType>
bool SparseMatrix<ValueType>::compareRows(index_type i1, index_type i2) const {
const_iterator end1 = this->end(i1);
const_iterator end2 = this->end(i2);
const_iterator it1 = this->begin(i1);
const_iterator it2 = this->begin(i2);
for(;it1 != end1 && it2 != end2; ++it1, ++it2 ) {
if(*it1 != *it2) {
return false;
}
}
if(it1 == end1 && it2 == end2) {
return true;
}
return false;
}
template<typename ValueType>
BitVector SparseMatrix<ValueType>::duplicateRowsInRowgroups() const {
BitVector bv(this->getRowCount());
for(size_t rowgroup = 0; rowgroup < this->getRowGroupCount(); ++rowgroup) {
for(size_t row1 = this->getRowGroupIndices().at(rowgroup); row1 < this->getRowGroupIndices().at(rowgroup+1); ++row1) {
for(size_t row2 = row1; row2 < this->getRowGroupIndices().at(rowgroup+1); ++row2) {
if(compareRows(row1, row2)) {
bv.set(row2);
}
}
}
}
return bv;
}
template<typename ValueType>
ValueType SparseMatrix<ValueType>::getConstrainedRowSum(index_type row, storm::storage::BitVector const& constraint) const {
ValueType result = storm::utility::zero<ValueType>();

15
src/storage/SparseMatrix.h

@ -107,6 +107,9 @@ namespace storm {
*/
MatrixEntry operator*(value_type factor) const;
bool operator==(MatrixEntry const& other) const;
bool operator!=(MatrixEntry const& other) const;
template<typename IndexTypePrime, typename ValueTypePrime>
friend std::ostream& operator<<(std::ostream& out, MatrixEntry<IndexTypePrime, ValueTypePrime> const& entry);
private:
@ -628,6 +631,18 @@ namespace storm {
*/
SparseMatrix restrictRows(storm::storage::BitVector const& rowsToKeep) const;
/**
* Compares two rows.
* @param i1 Index of first row
* @param i2 Index of second row
* @return True if the rows have identical entries.
*/
bool compareRows(index_type i1, index_type i2) const;
/*!
* Finds duplicate rows in a rowgroup.
*/
BitVector duplicateRowsInRowgroups() const;
/*!
* Selects exactly one row from each row group of this matrix and returns the resulting matrix.
*

Loading…
Cancel
Save