BlockSparseMatrix.h
Go to the documentation of this file.
1 // This file is part of Eigen, a lightweight C++ template library
2 // for linear algebra.
3 //
4 // Copyright (C) 2013 Desire Nuentsa <desire.nuentsa_wakam@inria.fr>
5 // Copyright (C) 2013 Gael Guennebaud <gael.guennebaud@inria.fr>
6 //
7 // This Source Code Form is subject to the terms of the Mozilla
8 // Public License v. 2.0. If a copy of the MPL was not distributed
9 // with this file, You can obtain one at http://mozilla.org/MPL/2.0/.
10 
11 #ifndef EIGEN_SPARSEBLOCKMATRIX_H
12 #define EIGEN_SPARSEBLOCKMATRIX_H
13 
14 namespace Eigen {
54 template<typename _Scalar, int _BlockAtCompileTime=Dynamic, int _Options=ColMajor, typename _StorageIndex=int> class BlockSparseMatrix;
55 
56 template<typename BlockSparseMatrixT> class BlockSparseMatrixView;
57 
58 namespace internal {
59 template<typename _Scalar, int _BlockAtCompileTime, int _Options, typename _Index>
60 struct traits<BlockSparseMatrix<_Scalar,_BlockAtCompileTime,_Options, _Index> >
61 {
62  typedef _Scalar Scalar;
63  typedef _Index Index;
64  typedef Sparse StorageKind; // FIXME Where is it used ??
65  typedef MatrixXpr XprKind;
66  enum {
67  RowsAtCompileTime = Dynamic,
68  ColsAtCompileTime = Dynamic,
69  MaxRowsAtCompileTime = Dynamic,
70  MaxColsAtCompileTime = Dynamic,
71  BlockSize = _BlockAtCompileTime,
72  Flags = _Options | NestByRefBit | LvalueBit,
73  CoeffReadCost = NumTraits<Scalar>::ReadCost,
74  SupportedAccessPatterns = InnerRandomAccessPattern
75  };
76 };
77 template<typename BlockSparseMatrixT>
78 struct traits<BlockSparseMatrixView<BlockSparseMatrixT> >
79 {
82 
83 };
84 
85 // Function object to sort a triplet list
86 template<typename Iterator, bool IsColMajor>
88 {
89  typedef typename Iterator::value_type Triplet;
90  bool operator()(const Triplet& a, const Triplet& b)
91  { if(IsColMajor)
92  return ((a.col() == b.col() && a.row() < b.row()) || (a.col() < b.col()));
93  else
94  return ((a.row() == b.row() && a.col() < b.col()) || (a.row() < b.row()));
95  }
96 };
97 } // end namespace internal
98 
99 
100 /* Proxy to view the block sparse matrix as a regular sparse matrix */
101 template<typename BlockSparseMatrixT>
102 class BlockSparseMatrixView : public SparseMatrixBase<BlockSparseMatrixT>
103 {
104  public:
108  typedef BlockSparseMatrixT Nested;
109  enum {
110  Flags = BlockSparseMatrixT::Options,
111  Options = BlockSparseMatrixT::Options,
112  RowsAtCompileTime = BlockSparseMatrixT::RowsAtCompileTime,
113  ColsAtCompileTime = BlockSparseMatrixT::ColsAtCompileTime,
114  MaxColsAtCompileTime = BlockSparseMatrixT::MaxColsAtCompileTime,
115  MaxRowsAtCompileTime = BlockSparseMatrixT::MaxRowsAtCompileTime
116  };
117  public:
118  BlockSparseMatrixView(const BlockSparseMatrixT& spblockmat)
119  : m_spblockmat(spblockmat)
120  {}
121 
122  Index outerSize() const
123  {
124  return (Flags&RowMajorBit) == 1 ? this->rows() : this->cols();
125  }
126  Index cols() const
127  {
128  return m_spblockmat.blockCols();
129  }
130  Index rows() const
131  {
132  return m_spblockmat.blockRows();
133  }
135  {
136  return m_spblockmat.coeff(row, col);
137  }
139  {
140  return m_spblockmat.coeffRef(row, col);
141  }
142  // Wrapper to iterate over all blocks
143  class InnerIterator : public BlockSparseMatrixT::BlockInnerIterator
144  {
145  public:
147  : BlockSparseMatrixT::BlockInnerIterator(mat.m_spblockmat, outer)
148  {}
149 
150  };
151 
152  protected:
153  const BlockSparseMatrixT& m_spblockmat;
154 };
155 
156 // Proxy to view a regular vector as a block vector
157 template<typename BlockSparseMatrixT, typename VectorType>
159 {
160  public:
161  enum {
162  BlockSize = BlockSparseMatrixT::BlockSize,
163  ColsAtCompileTime = VectorType::ColsAtCompileTime,
164  RowsAtCompileTime = VectorType::RowsAtCompileTime,
165  Flags = VectorType::Flags
166  };
169  public:
170  BlockVectorView(const BlockSparseMatrixT& spblockmat, const VectorType& vec)
171  : m_spblockmat(spblockmat),m_vec(vec)
172  { }
173  inline Index cols() const
174  {
175  return m_vec.cols();
176  }
177  inline Index size() const
178  {
179  return m_spblockmat.blockRows();
180  }
181  inline Scalar coeff(Index bi) const
182  {
183  Index startRow = m_spblockmat.blockRowsIndex(bi);
184  Index rowSize = m_spblockmat.blockRowsIndex(bi+1) - startRow;
185  return m_vec.middleRows(startRow, rowSize);
186  }
187  inline Scalar coeff(Index bi, Index j) const
188  {
189  Index startRow = m_spblockmat.blockRowsIndex(bi);
190  Index rowSize = m_spblockmat.blockRowsIndex(bi+1) - startRow;
191  return m_vec.block(startRow, j, rowSize, 1);
192  }
193  protected:
194  const BlockSparseMatrixT& m_spblockmat;
196 };
197 
198 template<typename VectorType, typename Index> class BlockVectorReturn;
199 
200 
201 // Proxy to view a regular vector as a block vector
202 template<typename BlockSparseMatrixT, typename VectorType>
203 class BlockVectorReturn
204 {
205  public:
206  enum {
207  ColsAtCompileTime = VectorType::ColsAtCompileTime,
208  RowsAtCompileTime = VectorType::RowsAtCompileTime,
209  Flags = VectorType::Flags
210  };
213  public:
214  BlockVectorReturn(const BlockSparseMatrixT& spblockmat, VectorType& vec)
215  : m_spblockmat(spblockmat),m_vec(vec)
216  { }
217  inline Index size() const
218  {
219  return m_spblockmat.blockRows();
220  }
221  inline Scalar coeffRef(Index bi)
222  {
223  Index startRow = m_spblockmat.blockRowsIndex(bi);
224  Index rowSize = m_spblockmat.blockRowsIndex(bi+1) - startRow;
225  return m_vec.middleRows(startRow, rowSize);
226  }
228  {
229  Index startRow = m_spblockmat.blockRowsIndex(bi);
230  Index rowSize = m_spblockmat.blockRowsIndex(bi+1) - startRow;
231  return m_vec.block(startRow, j, rowSize, 1);
232  }
233 
234  protected:
235  const BlockSparseMatrixT& m_spblockmat;
237 };
238 
239 // Block version of the sparse dense product
240 template<typename Lhs, typename Rhs>
242 
243 namespace internal {
244 
245 template<typename BlockSparseMatrixT, typename VecType>
246 struct traits<BlockSparseTimeDenseProduct<BlockSparseMatrixT, VecType> >
247 {
252  enum {
253  RowsAtCompileTime = Dynamic,
254  ColsAtCompileTime = Dynamic,
255  MaxRowsAtCompileTime = Dynamic,
256  MaxColsAtCompileTime = Dynamic,
257  Flags = 0,
259  };
260 };
261 } // end namespace internal
262 
263 template<typename Lhs, typename Rhs>
264 class BlockSparseTimeDenseProduct
265  : public ProductBase<BlockSparseTimeDenseProduct<Lhs,Rhs>, Lhs, Rhs>
266 {
267  public:
268  EIGEN_PRODUCT_PUBLIC_INTERFACE(BlockSparseTimeDenseProduct)
269 
270  BlockSparseTimeDenseProduct(const Lhs& lhs, const Rhs& rhs) : Base(lhs,rhs)
271  {}
272 
273  template<typename Dest> void scaleAndAddTo(Dest& dest, const typename Rhs::Scalar& alpha) const
274  {
275  BlockVectorReturn<Lhs,Dest> tmpDest(m_lhs, dest);
277  }
278 
279  private:
281 };
282 
283 template<typename _Scalar, int _BlockAtCompileTime, int _Options, typename _StorageIndex>
284 class BlockSparseMatrix : public SparseMatrixBase<BlockSparseMatrix<_Scalar,_BlockAtCompileTime, _Options,_StorageIndex> >
285 {
286  public:
287  typedef _Scalar Scalar;
289  typedef _StorageIndex StorageIndex;
291 
292  enum {
293  Options = _Options,
295  BlockSize=_BlockAtCompileTime,
302  };
307  public:
308  // Default constructor
313  { }
314 
315 
321  : m_innerBSize(IsColMajor ? brow : bcol),
322  m_outerBSize(IsColMajor ? bcol : brow),
324  m_values(0),m_blockPtr(0),m_indices(0),
326  { }
327 
335  {
336  // should we allow copying between variable-size blocks and fixed-size blocks ??
337  eigen_assert(m_blockSize == BlockSize && " CAN NOT COPY BETWEEN FIXED-SIZE AND VARIABLE-SIZE BLOCKS");
338 
339  std::copy(other.m_innerOffset, other.m_innerOffset+m_innerBSize+1, m_innerOffset);
340  std::copy(other.m_outerOffset, other.m_outerOffset+m_outerBSize+1, m_outerOffset);
341  std::copy(other.m_values, other.m_values+m_nonzeros, m_values);
342 
343  if(m_blockSize != Dynamic)
344  std::copy(other.m_blockPtr, other.m_blockPtr+m_nonzerosblocks, m_blockPtr);
345 
346  std::copy(other.m_indices, other.m_indices+m_nonzerosblocks, m_indices);
347  std::copy(other.m_outerIndex, other.m_outerIndex+m_outerBSize, m_outerIndex);
348  }
349 
350  friend void swap(BlockSparseMatrix& first, BlockSparseMatrix& second)
351  {
352  std::swap(first.m_innerBSize, second.m_innerBSize);
353  std::swap(first.m_outerBSize, second.m_outerBSize);
354  std::swap(first.m_innerOffset, second.m_innerOffset);
355  std::swap(first.m_outerOffset, second.m_outerOffset);
356  std::swap(first.m_nonzerosblocks, second.m_nonzerosblocks);
357  std::swap(first.m_nonzeros, second.m_nonzeros);
358  std::swap(first.m_values, second.m_values);
359  std::swap(first.m_blockPtr, second.m_blockPtr);
360  std::swap(first.m_indices, second.m_indices);
361  std::swap(first.m_outerIndex, second.m_outerIndex);
362  std::swap(first.m_BlockSize, second.m_blockSize);
363  }
364 
366  {
367  //Copy-and-swap paradigm ... avoid leaked data if thrown
368  swap(*this, other);
369  return *this;
370  }
371 
372  // Destructor
374  {
375  delete[] m_outerIndex;
376  delete[] m_innerOffset;
377  delete[] m_outerOffset;
378  delete[] m_indices;
379  delete[] m_blockPtr;
380  delete[] m_values;
381  }
382 
383 
388  template<typename MatrixType>
390  {
391  EIGEN_STATIC_ASSERT((m_blockSize != Dynamic), THIS_METHOD_IS_ONLY_FOR_FIXED_SIZE);
392 
393  *this = spmat;
394  }
395 
404  template<typename MatrixType>
405  inline BlockSparseMatrix& operator=(const MatrixType& spmat)
406  {
407  eigen_assert((m_innerBSize != 0 && m_outerBSize != 0)
408  && "Trying to assign to a zero-size matrix, call resize() first");
409  eigen_assert(((MatrixType::Options&RowMajorBit) != IsColMajor) && "Wrong storage order");
411  MatrixPatternType blockPattern(blockRows(), blockCols());
412  m_nonzeros = 0;
413 
414  // First, compute the number of nonzero blocks and their locations
415  for(StorageIndex bj = 0; bj < m_outerBSize; ++bj)
416  {
417  // Browse each outer block and compute the structure
418  std::vector<bool> nzblocksFlag(m_innerBSize,false); // Record the existing blocks
419  blockPattern.startVec(bj);
420  for(StorageIndex j = blockOuterIndex(bj); j < blockOuterIndex(bj+1); ++j)
421  {
422  typename MatrixType::InnerIterator it_spmat(spmat, j);
423  for(; it_spmat; ++it_spmat)
424  {
425  StorageIndex bi = innerToBlock(it_spmat.index()); // Index of the current nonzero block
426  if(!nzblocksFlag[bi])
427  {
428  // Save the index of this nonzero block
429  nzblocksFlag[bi] = true;
430  blockPattern.insertBackByOuterInnerUnordered(bj, bi) = true;
431  // Compute the total number of nonzeros (including explicit zeros in blocks)
433  }
434  }
435  } // end current outer block
436  }
437  blockPattern.finalize();
438 
439  // Allocate the internal arrays
440  setBlockStructure(blockPattern);
441 
442  for(StorageIndex nz = 0; nz < m_nonzeros; ++nz) m_values[nz] = Scalar(0);
443  for(StorageIndex bj = 0; bj < m_outerBSize; ++bj)
444  {
445  // Now copy the values
446  for(StorageIndex j = blockOuterIndex(bj); j < blockOuterIndex(bj+1); ++j)
447  {
448  // Browse the outer block column by column (for column-major matrices)
449  typename MatrixType::InnerIterator it_spmat(spmat, j);
450  for(; it_spmat; ++it_spmat)
451  {
452  StorageIndex idx = 0; // Position of this block in the column block
453  StorageIndex bi = innerToBlock(it_spmat.index()); // Index of the current nonzero block
454  // Go to the inner block where this element belongs to
455  while(bi > m_indices[m_outerIndex[bj]+idx]) ++idx; // Not expensive for ordered blocks
456  StorageIndex idxVal;// Get the right position in the array of values for this element
457  if(m_blockSize == Dynamic)
458  {
459  // Offset from all blocks before ...
460  idxVal = m_blockPtr[m_outerIndex[bj]+idx];
461  // ... and offset inside the block
462  idxVal += (j - blockOuterIndex(bj)) * blockOuterSize(bj) + it_spmat.index() - m_innerOffset[bi];
463  }
464  else
465  {
466  // All blocks before
467  idxVal = (m_outerIndex[bj] + idx) * m_blockSize * m_blockSize;
468  // inside the block
469  idxVal += (j - blockOuterIndex(bj)) * m_blockSize + (it_spmat.index()%m_blockSize);
470  }
471  // Insert the value
472  m_values[idxVal] = it_spmat.value();
473  } // end of this column
474  } // end of this block
475  } // end of this outer block
476 
477  return *this;
478  }
479 
497  template<typename MatrixType>
498  void setBlockStructure(const MatrixType& blockPattern)
499  {
500  resize(blockPattern.rows(), blockPattern.cols());
501  reserve(blockPattern.nonZeros());
502 
503  // Browse the block pattern and set up the various pointers
504  m_outerIndex[0] = 0;
505  if(m_blockSize == Dynamic) m_blockPtr[0] = 0;
506  for(StorageIndex nz = 0; nz < m_nonzeros; ++nz) m_values[nz] = Scalar(0);
507  for(StorageIndex bj = 0; bj < m_outerBSize; ++bj)
508  {
509  //Browse each outer block
510 
511  //First, copy and save the indices of nonzero blocks
512  //FIXME : find a way to avoid this ...
513  std::vector<int> nzBlockIdx;
514  typename MatrixType::InnerIterator it(blockPattern, bj);
515  for(; it; ++it)
516  {
517  nzBlockIdx.push_back(it.index());
518  }
519  std::sort(nzBlockIdx.begin(), nzBlockIdx.end());
520 
521  // Now, fill block indices and (eventually) pointers to blocks
522  for(StorageIndex idx = 0; idx < nzBlockIdx.size(); ++idx)
523  {
524  StorageIndex offset = m_outerIndex[bj]+idx; // offset in m_indices
525  m_indices[offset] = nzBlockIdx[idx];
526  if(m_blockSize == Dynamic)
527  m_blockPtr[offset] = m_blockPtr[offset-1] + blockInnerSize(nzBlockIdx[idx]) * blockOuterSize(bj);
528  // There is no blockPtr for fixed-size blocks... not needed !???
529  }
530  // Save the pointer to the next outer block
531  m_outerIndex[bj+1] = m_outerIndex[bj] + nzBlockIdx.size();
532  }
533  }
534 
538  inline void resize(Index brow, Index bcol)
539  {
540  m_innerBSize = IsColMajor ? brow : bcol;
541  m_outerBSize = IsColMajor ? bcol : brow;
542  }
543 
549  inline void setBlockSize(Index blockSize)
550  {
551  m_blockSize = blockSize;
552  }
553 
563  inline void setBlockLayout(const VectorXi& rowBlocks, const VectorXi& colBlocks)
564  {
565  const VectorXi& innerBlocks = IsColMajor ? rowBlocks : colBlocks;
566  const VectorXi& outerBlocks = IsColMajor ? colBlocks : rowBlocks;
567  eigen_assert(m_innerBSize == innerBlocks.size() && "CHECK THE NUMBER OF ROW OR COLUMN BLOCKS");
568  eigen_assert(m_outerBSize == outerBlocks.size() && "CHECK THE NUMBER OF ROW OR COLUMN BLOCKS");
569  m_outerBSize = outerBlocks.size();
570  // starting index of blocks... cumulative sums
573  m_innerOffset[0] = 0;
574  m_outerOffset[0] = 0;
575  std::partial_sum(&innerBlocks[0], &innerBlocks[m_innerBSize-1]+1, &m_innerOffset[1]);
576  std::partial_sum(&outerBlocks[0], &outerBlocks[m_outerBSize-1]+1, &m_outerOffset[1]);
577 
578  // Compute the total number of nonzeros
579  m_nonzeros = 0;
580  for(StorageIndex bj = 0; bj < m_outerBSize; ++bj)
581  for(StorageIndex bi = 0; bi < m_innerBSize; ++bi)
582  m_nonzeros += outerBlocks[bj] * innerBlocks[bi];
583 
584  }
585 
596  inline void reserve(const Index nonzerosblocks)
597  {
598  eigen_assert((m_innerBSize != 0 && m_outerBSize != 0) &&
599  "TRYING TO RESERVE ZERO-SIZE MATRICES, CALL resize() first");
600 
601  //FIXME Should free if already allocated
603 
604  m_nonzerosblocks = nonzerosblocks;
605  if(m_blockSize != Dynamic)
606  {
607  m_nonzeros = nonzerosblocks * (m_blockSize * m_blockSize);
608  m_blockPtr = 0;
609  }
610  else
611  {
612  // m_nonzeros is already computed in setBlockLayout()
614  }
616  m_values = new Scalar[m_nonzeros];
617  }
618 
619 
630  template<typename InputIterator>
631  void setFromTriplets(const InputIterator& begin, const InputIterator& end)
632  {
633  eigen_assert((m_innerBSize!=0 && m_outerBSize !=0) && "ZERO BLOCKS, PLEASE CALL resize() before");
634 
635  /* First, sort the triplet list
636  * FIXME This can be unnecessarily expensive since only the inner indices have to be sorted
637  * The best approach is like in SparseMatrix::setFromTriplets()
638  */
640  std::sort(begin, end, tripletcomp);
641 
642  /* Count the number of rows and column blocks,
643  * and the number of nonzero blocks per outer dimension
644  */
645  VectorXi rowBlocks(m_innerBSize); // Size of each block row
646  VectorXi colBlocks(m_outerBSize); // Size of each block column
647  rowBlocks.setZero(); colBlocks.setZero();
648  VectorXi nzblock_outer(m_outerBSize); // Number of nz blocks per outer vector
649  VectorXi nz_outer(m_outerBSize); // Number of nz per outer vector...for variable-size blocks
650  nzblock_outer.setZero();
651  nz_outer.setZero();
652  for(InputIterator it(begin); it !=end; ++it)
653  {
654  eigen_assert(it->row() >= 0 && it->row() < this->blockRows() && it->col() >= 0 && it->col() < this->blockCols());
655  eigen_assert((it->value().rows() == it->value().cols() && (it->value().rows() == m_blockSize))
656  || (m_blockSize == Dynamic));
657 
658  if(m_blockSize == Dynamic)
659  {
660  eigen_assert((rowBlocks[it->row()] == 0 || rowBlocks[it->row()] == it->value().rows()) &&
661  "NON CORRESPONDING SIZES FOR ROW BLOCKS");
662  eigen_assert((colBlocks[it->col()] == 0 || colBlocks[it->col()] == it->value().cols()) &&
663  "NON CORRESPONDING SIZES FOR COLUMN BLOCKS");
664  rowBlocks[it->row()] =it->value().rows();
665  colBlocks[it->col()] = it->value().cols();
666  }
667  nz_outer(IsColMajor ? it->col() : it->row()) += it->value().rows() * it->value().cols();
668  nzblock_outer(IsColMajor ? it->col() : it->row())++;
669  }
670  // Allocate member arrays
671  if(m_blockSize == Dynamic) setBlockLayout(rowBlocks, colBlocks);
672  StorageIndex nzblocks = nzblock_outer.sum();
673  reserve(nzblocks);
674 
675  // Temporary markers
676  VectorXi block_id(m_outerBSize); // To be used as a block marker during insertion
677 
678  // Setup outer index pointers and markers
679  m_outerIndex[0] = 0;
680  if (m_blockSize == Dynamic) m_blockPtr[0] = 0;
681  for(StorageIndex bj = 0; bj < m_outerBSize; ++bj)
682  {
683  m_outerIndex[bj+1] = m_outerIndex[bj] + nzblock_outer(bj);
684  block_id(bj) = m_outerIndex[bj];
685  if(m_blockSize==Dynamic)
686  {
687  m_blockPtr[m_outerIndex[bj+1]] = m_blockPtr[m_outerIndex[bj]] + nz_outer(bj);
688  }
689  }
690 
691  // Fill the matrix
692  for(InputIterator it(begin); it!=end; ++it)
693  {
694  StorageIndex outer = IsColMajor ? it->col() : it->row();
695  StorageIndex inner = IsColMajor ? it->row() : it->col();
696  m_indices[block_id(outer)] = inner;
697  StorageIndex block_size = it->value().rows()*it->value().cols();
698  StorageIndex nz_marker = blockPtr(block_id[outer]);
699  memcpy(&(m_values[nz_marker]), it->value().data(), block_size * sizeof(Scalar));
700  if(m_blockSize == Dynamic)
701  {
702  m_blockPtr[block_id(outer)+1] = m_blockPtr[block_id(outer)] + block_size;
703  }
704  block_id(outer)++;
705  }
706 
707  // An alternative when the outer indices are sorted...no need to use an array of markers
708 // for(Index bcol = 0; bcol < m_outerBSize; ++bcol)
709 // {
710 // Index id = 0, id_nz = 0, id_nzblock = 0;
711 // for(InputIterator it(begin); it!=end; ++it)
712 // {
713 // while (id<bcol) // one pass should do the job unless there are empty columns
714 // {
715 // id++;
716 // m_outerIndex[id+1]=m_outerIndex[id];
717 // }
718 // m_outerIndex[id+1] += 1;
719 // m_indices[id_nzblock]=brow;
720 // Index block_size = it->value().rows()*it->value().cols();
721 // m_blockPtr[id_nzblock+1] = m_blockPtr[id_nzblock] + block_size;
722 // id_nzblock++;
723 // memcpy(&(m_values[id_nz]),it->value().data(), block_size*sizeof(Scalar));
724 // id_nz += block_size;
725 // }
726 // while(id < m_outerBSize-1) // Empty columns at the end
727 // {
728 // id++;
729 // m_outerIndex[id+1]=m_outerIndex[id];
730 // }
731 // }
732  }
733 
734 
738  inline Index rows() const
739  {
740 // return blockRows();
741  return (IsColMajor ? innerSize() : outerSize());
742  }
743 
747  inline Index cols() const
748  {
749 // return blockCols();
750  return (IsColMajor ? outerSize() : innerSize());
751  }
752 
753  inline Index innerSize() const
754  {
756  else return (m_innerBSize * m_blockSize) ;
757  }
758 
759  inline Index outerSize() const
760  {
762  else return (m_outerBSize * m_blockSize) ;
763  }
765  inline Index blockRows() const
766  {
767  return (IsColMajor ? m_innerBSize : m_outerBSize);
768  }
770  inline Index blockCols() const
771  {
772  return (IsColMajor ? m_outerBSize : m_innerBSize);
773  }
774 
775  inline Index outerBlocks() const { return m_outerBSize; }
776  inline Index innerBlocks() const { return m_innerBSize; }
777 
779  inline Index outerToBlock(Index outer) const
780  {
781  eigen_assert(outer < outerSize() && "OUTER INDEX OUT OF BOUNDS");
782 
783  if(m_blockSize != Dynamic)
784  return (outer / m_blockSize); // Integer division
785 
786  StorageIndex b_outer = 0;
787  while(m_outerOffset[b_outer] <= outer) ++b_outer;
788  return b_outer - 1;
789  }
791  inline Index innerToBlock(Index inner) const
792  {
793  eigen_assert(inner < innerSize() && "OUTER INDEX OUT OF BOUNDS");
794 
795  if(m_blockSize != Dynamic)
796  return (inner / m_blockSize); // Integer division
797 
798  StorageIndex b_inner = 0;
799  while(m_innerOffset[b_inner] <= inner) ++b_inner;
800  return b_inner - 1;
801  }
802 
807  {
808  eigen_assert(brow < blockRows() && "BLOCK ROW INDEX OUT OF BOUNDS");
809  eigen_assert(bcol < blockCols() && "BLOCK nzblocksFlagCOLUMN OUT OF BOUNDS");
810 
811  StorageIndex rsize = IsColMajor ? blockInnerSize(brow): blockOuterSize(bcol);
812  StorageIndex csize = IsColMajor ? blockOuterSize(bcol) : blockInnerSize(brow);
813  StorageIndex inner = IsColMajor ? brow : bcol;
814  StorageIndex outer = IsColMajor ? bcol : brow;
816  while(offset < m_outerIndex[outer+1] && m_indices[offset] != inner)
817  offset++;
818  if(m_indices[offset] == inner)
819  {
820  return Map<BlockScalar>(&(m_values[blockPtr(offset)]), rsize, csize);
821  }
822  else
823  {
824  //FIXME the block does not exist, Insert it !!!!!!!!!
825  eigen_assert("DYNAMIC INSERTION IS NOT YET SUPPORTED");
826  }
827  }
828 
833  {
834  eigen_assert(brow < blockRows() && "BLOCK ROW INDEX OUT OF BOUNDS");
835  eigen_assert(bcol < blockCols() && "BLOCK COLUMN OUT OF BOUNDS");
836 
837  StorageIndex rsize = IsColMajor ? blockInnerSize(brow): blockOuterSize(bcol);
838  StorageIndex csize = IsColMajor ? blockOuterSize(bcol) : blockInnerSize(brow);
839  StorageIndex inner = IsColMajor ? brow : bcol;
840  StorageIndex outer = IsColMajor ? bcol : brow;
842  while(offset < m_outerIndex[outer+1] && m_indices[offset] != inner) offset++;
843  if(m_indices[offset] == inner)
844  {
845  return Map<const BlockScalar> (&(m_values[blockPtr(offset)]), rsize, csize);
846  }
847  else
848 // return BlockScalar::Zero(rsize, csize);
849  eigen_assert("NOT YET SUPPORTED");
850  }
851 
852  // Block Matrix times vector product
853  template<typename VecType>
855  {
857  }
858 
860  inline Index nonZerosBlocks() const { return m_nonzerosblocks; }
862  inline Index nonZeros() const { return m_nonzeros; }
863 
864  inline BlockScalarReturnType *valuePtr() {return static_cast<BlockScalarReturnType *>(m_values);}
865 // inline Scalar *valuePtr(){ return m_values; }
866  inline StorageIndex *innerIndexPtr() {return m_indices; }
867  inline const StorageIndex *innerIndexPtr() const {return m_indices; }
869  inline const StorageIndex* outerIndexPtr() const {return m_outerIndex; }
870 
872  inline bool isCompressed() const {return true;}
876  inline Index blockRowsIndex(Index bi) const
877  {
878  return IsColMajor ? blockInnerIndex(bi) : blockOuterIndex(bi);
879  }
880 
884  inline Index blockColsIndex(Index bj) const
885  {
886  return IsColMajor ? blockOuterIndex(bj) : blockInnerIndex(bj);
887  }
888 
889  inline Index blockOuterIndex(Index bj) const
890  {
891  return (m_blockSize == Dynamic) ? m_outerOffset[bj] : (bj * m_blockSize);
892  }
893  inline Index blockInnerIndex(Index bi) const
894  {
895  return (m_blockSize == Dynamic) ? m_innerOffset[bi] : (bi * m_blockSize);
896  }
897 
898  // Not needed ???
899  inline Index blockInnerSize(Index bi) const
900  {
901  return (m_blockSize == Dynamic) ? (m_innerOffset[bi+1] - m_innerOffset[bi]) : m_blockSize;
902  }
903  inline Index blockOuterSize(Index bj) const
904  {
905  return (m_blockSize == Dynamic) ? (m_outerOffset[bj+1]- m_outerOffset[bj]) : m_blockSize;
906  }
907 
911  class InnerIterator; // Browse column by column
912 
916  class BlockInnerIterator; // Browse block by block
917 
918  friend std::ostream & operator << (std::ostream & s, const BlockSparseMatrix& m)
919  {
920  for (StorageIndex j = 0; j < m.outerBlocks(); ++j)
921  {
922  BlockInnerIterator itb(m, j);
923  for(; itb; ++itb)
924  {
925  s << "("<<itb.row() << ", " << itb.col() << ")\n";
926  s << itb.value() <<"\n";
927  }
928  }
929  s << std::endl;
930  return s;
931  }
932 
936  Index blockPtr(Index id) const
937  {
938  if(m_blockSize == Dynamic) return m_blockPtr[id];
939  else return id * m_blockSize * m_blockSize;
940  //return blockDynIdx(id, typename internal::conditional<(BlockSize==Dynamic), internal::true_type, internal::false_type>::type());
941  }
942 
943 
944  protected:
945 // inline Index blockDynIdx(Index id, internal::true_type) const
946 // {
947 // return m_blockPtr[id];
948 // }
949 // inline Index blockDynIdx(Index id, internal::false_type) const
950 // {
951 // return id * BlockSize * BlockSize;
952 // }
953 
954  // To be implemented
955  // Insert a block at a particular location... need to make a room for that
956  Map<BlockScalar> insert(Index brow, Index bcol);
957 
958  Index m_innerBSize; // Number of block rows
959  Index m_outerBSize; // Number of block columns
960  StorageIndex *m_innerOffset; // Starting index of each inner block (size m_innerBSize+1)
961  StorageIndex *m_outerOffset; // Starting index of each outer block (size m_outerBSize+1)
962  Index m_nonzerosblocks; // Total nonzeros blocks (lower than m_innerBSize x m_outerBSize)
963  Index m_nonzeros; // Total nonzeros elements
964  Scalar *m_values; //Values stored block column after block column (size m_nonzeros)
965  StorageIndex *m_blockPtr; // Pointer to the beginning of each block in m_values, size m_nonzeroblocks ... null for fixed-size blocks
966  StorageIndex *m_indices; //Inner block indices, size m_nonzerosblocks ... OK
967  StorageIndex *m_outerIndex; // Starting pointer of each block column in m_indices (size m_outerBSize)... OK
968  Index m_blockSize; // Size of a block for fixed-size blocks, otherwise -1
969 };
970 
971 template<typename _Scalar, int _BlockAtCompileTime, int _Options, typename _StorageIndex>
972 class BlockSparseMatrix<_Scalar, _BlockAtCompileTime, _Options, _StorageIndex>::BlockInnerIterator
973 {
974  public:
975 
976  enum{
977  Flags = _Options
978  };
979 
981  : m_mat(mat),m_outer(outer),
982  m_id(mat.m_outerIndex[outer]),
983  m_end(mat.m_outerIndex[outer+1])
984  {
985  }
986 
987  inline BlockInnerIterator& operator++() {m_id++; return *this; }
988 
989  inline const Map<const BlockScalar> value() const
990  {
991  return Map<const BlockScalar>(&(m_mat.m_values[m_mat.blockPtr(m_id)]),
992  rows(),cols());
993  }
995  {
996  return Map<BlockScalar>(&(m_mat.m_values[m_mat.blockPtr(m_id)]),
997  rows(),cols());
998  }
999  // Block inner index
1000  inline Index index() const {return m_mat.m_indices[m_id]; }
1001  inline Index outer() const { return m_outer; }
1002  // block row index
1003  inline Index row() const {return index(); }
1004  // block column index
1005  inline Index col() const {return outer(); }
1006  // FIXME Number of rows in the current block
1007  inline Index rows() const { return (m_mat.m_blockSize==Dynamic) ? (m_mat.m_innerOffset[index()+1] - m_mat.m_innerOffset[index()]) : m_mat.m_blockSize; }
1008  // Number of columns in the current block ...
1009  inline Index cols() const { return (m_mat.m_blockSize==Dynamic) ? (m_mat.m_outerOffset[m_outer+1]-m_mat.m_outerOffset[m_outer]) : m_mat.m_blockSize;}
1010  inline operator bool() const { return (m_id < m_end); }
1011 
1012  protected:
1017 };
1018 
1019 template<typename _Scalar, int _BlockAtCompileTime, int _Options, typename _StorageIndex>
1020 class BlockSparseMatrix<_Scalar, _BlockAtCompileTime, _Options, _StorageIndex>::InnerIterator
1021 {
1022  public:
1024  : m_mat(mat),m_outerB(mat.outerToBlock(outer)),m_outer(outer),
1025  itb(mat, mat.outerToBlock(outer)),
1026  m_offset(outer - mat.blockOuterIndex(m_outerB))
1027  {
1028  if (itb)
1029  {
1030  m_id = m_mat.blockInnerIndex(itb.index());
1031  m_start = m_id;
1032  m_end = m_mat.blockInnerIndex(itb.index()+1);
1033  }
1034  }
1036  {
1037  m_id++;
1038  if (m_id >= m_end)
1039  {
1040  ++itb;
1041  if (itb)
1042  {
1043  m_id = m_mat.blockInnerIndex(itb.index());
1044  m_start = m_id;
1045  m_end = m_mat.blockInnerIndex(itb.index()+1);
1046  }
1047  }
1048  return *this;
1049  }
1050  inline const Scalar& value() const
1051  {
1052  return itb.value().coeff(m_id - m_start, m_offset);
1053  }
1054  inline Scalar& valueRef()
1055  {
1056  return itb.valueRef().coeff(m_id - m_start, m_offset);
1057  }
1058  inline Index index() const { return m_id; }
1059  inline Index outer() const {return m_outer; }
1060  inline Index col() const {return outer(); }
1061  inline Index row() const { return index();}
1062  inline operator bool() const
1063  {
1064  return itb;
1065  }
1066  protected:
1070  BlockInnerIterator itb; // Iterator through the blocks
1071  const Index m_offset; // Position of this column in the block
1072  Index m_start; // starting inner index of this block
1073  Index m_id; // current inner index in the block
1074  Index m_end; // starting inner index of the next block
1075 
1076 };
1077 } // end namespace Eigen
1078 
1079 #endif // EIGEN_SPARSEBLOCKMATRIX_H
Eigen::BlockSparseMatrixView::rows
Index rows() const
Definition: BlockSparseMatrix.h:130
Eigen::BlockVectorView::coeff
Scalar coeff(Index bi) const
Definition: BlockSparseMatrix.h:181
Eigen::BlockSparseMatrix::InnerIterator::m_id
Index m_id
Definition: BlockSparseMatrix.h:1073
Eigen::BlockSparseMatrix::cols
Index cols() const
Definition: BlockSparseMatrix.h:747
Eigen::BlockSparseMatrix::m_outerBSize
Index m_outerBSize
Definition: BlockSparseMatrix.h:959
Eigen::internal::Lhs
@ Lhs
Definition: TensorContractionMapper.h:19
Eigen::BlockVectorReturn::Scalar
Ref< Matrix< typename VectorType::Scalar, RowsAtCompileTime, ColsAtCompileTime > > Scalar
Definition: BlockSparseMatrix.h:211
Eigen::BlockSparseMatrixView::RealScalar
Ref< typename BlockSparseMatrixT::BlockRealScalar > RealScalar
Definition: BlockSparseMatrix.h:106
Eigen::BlockSparseMatrix::InnerIterator::row
Index row() const
Definition: BlockSparseMatrix.h:1061
Eigen::internal::traits< BlockSparseTimeDenseProduct< BlockSparseMatrixT, VecType > >::XprKind
MatrixXpr XprKind
Definition: BlockSparseMatrix.h:249
Eigen::BlockSparseMatrix::isCompressed
bool isCompressed() const
for compatibility purposes with the SparseMatrix class
Definition: BlockSparseMatrix.h:872
Eigen::BlockSparseMatrixView::MaxRowsAtCompileTime
@ MaxRowsAtCompileTime
Definition: BlockSparseMatrix.h:115
Eigen::MatrixXpr
Definition: Constants.h:522
Eigen::BlockSparseMatrix::InnerIterator
Definition: BlockSparseMatrix.h:1020
Eigen
Namespace containing all symbols from the Eigen library.
Definition: jet.h:637
Eigen::SparseMatrix
A versatible sparse matrix representation.
Definition: SparseMatrix.h:96
Eigen::internal::traits< BlockSparseTimeDenseProduct< BlockSparseMatrixT, VecType > >::Scalar
BlockSparseMatrixT::Scalar Scalar
Definition: BlockSparseMatrix.h:250
col
m col(1)
Eigen::BlockSparseMatrix::setBlockLayout
void setBlockLayout(const VectorXi &rowBlocks, const VectorXi &colBlocks)
Set the row and column block layouts,.
Definition: BlockSparseMatrix.h:563
Eigen::internal::traits< BlockSparseMatrixView< BlockSparseMatrixT > >::RealScalar
Ref< Matrix< typename BlockSparseMatrixT::RealScalar, BlockSparseMatrixT::BlockSize, BlockSparseMatrixT::BlockSize > > RealScalar
Definition: BlockSparseMatrix.h:81
Eigen::BlockSparseMatrix::~BlockSparseMatrix
~BlockSparseMatrix()
Definition: BlockSparseMatrix.h:373
Eigen::BlockSparseMatrix
A versatile sparse matrix representation where each element is a block.
Definition: BlockSparseMatrix.h:54
alpha
RealScalar alpha
Definition: level1_cplx_impl.h:147
Eigen::BlockVectorView::Flags
@ Flags
Definition: BlockSparseMatrix.h:165
s
RealScalar s
Definition: level1_cplx_impl.h:126
Eigen::BlockSparseMatrix::BlockInnerIterator::m_end
Index m_end
Definition: BlockSparseMatrix.h:1016
MatrixType
MatrixXf MatrixType
Definition: benchmark-blocking-sizes.cpp:52
Eigen::BlockSparseMatrix::Options
@ Options
Definition: BlockSparseMatrix.h:293
Eigen::Sparse
Definition: Constants.h:510
Eigen::BlockSparseMatrix::RealScalar
NumTraits< Scalar >::Real RealScalar
Definition: BlockSparseMatrix.h:288
Eigen::BlockSparseMatrix::InnerIterator::operator++
InnerIterator & operator++()
Definition: BlockSparseMatrix.h:1035
Eigen::BlockVectorReturn::Index
BlockSparseMatrixT::Index Index
Definition: BlockSparseMatrix.h:212
b
Scalar * b
Definition: benchVecAdd.cpp:17
eigen_assert
#define eigen_assert(x)
Definition: Macros.h:1037
Eigen::BlockSparseMatrix::Flags
@ Flags
Definition: BlockSparseMatrix.h:294
pybind_wrapper_test_script.this
this
Definition: pybind_wrapper_test_script.py:38
Eigen::BlockVectorReturn::coeffRef
Scalar coeffRef(Index bi)
Definition: BlockSparseMatrix.h:221
Eigen::BlockSparseMatrix::Nested
internal::ref_selector< BlockSparseMatrix< _Scalar, _BlockAtCompileTime, _Options, _StorageIndex > >::type Nested
Definition: BlockSparseMatrix.h:290
Eigen::BlockSparseMatrixView::m_spblockmat
const BlockSparseMatrixT & m_spblockmat
Definition: BlockSparseMatrix.h:153
Eigen::BlockSparseMatrix::InnerIterator::m_mat
const BlockSparseMatrix & m_mat
Definition: BlockSparseMatrix.h:1067
Eigen::RowMajorBit
const unsigned int RowMajorBit
Definition: Constants.h:66
Eigen::BlockSparseMatrix::resize
void resize(Index brow, Index bcol)
Set the number of rows and columns blocks.
Definition: BlockSparseMatrix.h:538
Eigen::BlockSparseMatrix::BlockInnerIterator::rows
Index rows() const
Definition: BlockSparseMatrix.h:1007
Eigen::BlockSparseMatrixView::Options
@ Options
Definition: BlockSparseMatrix.h:111
Eigen::BlockSparseMatrix::blockRowsIndex
Index blockRowsIndex(Index bi) const
Definition: BlockSparseMatrix.h:876
Eigen::BlockSparseMatrixView::Flags
@ Flags
Definition: BlockSparseMatrix.h:110
Eigen::BlockSparseMatrix::setFromTriplets
void setFromTriplets(const InputIterator &begin, const InputIterator &end)
Fill values in a matrix from a triplet list.
Definition: BlockSparseMatrix.h:631
Eigen::BlockSparseMatrix::PlainObject
BlockSparseMatrix< Scalar, BlockSize, IsColMajor ? ColMajor :RowMajor, StorageIndex > PlainObject
Definition: BlockSparseMatrix.h:306
type
Definition: pytypes.h:1525
Eigen::BlockSparseMatrix::BlockInnerIterator::m_mat
const BlockSparseMatrix< _Scalar, _BlockAtCompileTime, _Options, StorageIndex > & m_mat
Definition: BlockSparseMatrix.h:1013
Eigen::BlockSparseMatrix::BlockSparseMatrix
BlockSparseMatrix(Index brow, Index bcol)
Construct and resize.
Definition: BlockSparseMatrix.h:320
Eigen::BlockSparseMatrixView::RowsAtCompileTime
@ RowsAtCompileTime
Definition: BlockSparseMatrix.h:112
Eigen::BlockSparseMatrix::ColsAtCompileTime
@ ColsAtCompileTime
Definition: BlockSparseMatrix.h:297
mat
MatrixXf mat
Definition: Tutorial_AdvancedInitialization_CommaTemporary.cpp:1
Eigen::BlockSparseMatrix::outerBlocks
Index outerBlocks() const
Definition: BlockSparseMatrix.h:775
Eigen::BlockSparseMatrix::BlockScalar
Matrix< Scalar, _BlockAtCompileTime, _BlockAtCompileTime, IsColMajor ? ColMajor :RowMajor > BlockScalar
Definition: BlockSparseMatrix.h:303
Eigen::BlockSparseMatrix::BlockInnerIterator::value
const Map< const BlockScalar > value() const
Definition: BlockSparseMatrix.h:989
Eigen::BlockVectorReturn::m_spblockmat
const BlockSparseMatrixT & m_spblockmat
Definition: BlockSparseMatrix.h:235
Eigen::BlockSparseMatrix::operator*
BlockSparseTimeDenseProduct< BlockSparseMatrix, VecType > operator*(const VecType &lhs) const
Definition: BlockSparseMatrix.h:854
Eigen::BlockVectorView::m_vec
const VectorType & m_vec
Definition: BlockSparseMatrix.h:195
Eigen::BlockVectorView::RowsAtCompileTime
@ RowsAtCompileTime
Definition: BlockSparseMatrix.h:164
Eigen::BlockSparseMatrix::BlockInnerIterator::m_id
Index m_id
Definition: BlockSparseMatrix.h:1015
Eigen::internal::traits< BlockSparseMatrix< _Scalar, _BlockAtCompileTime, _Options, _Index > >::StorageKind
Sparse StorageKind
Definition: BlockSparseMatrix.h:64
Eigen::BlockSparseMatrix::m_blockSize
Index m_blockSize
Definition: BlockSparseMatrix.h:968
Eigen::BlockSparseMatrixView::Scalar
Ref< typename BlockSparseMatrixT::BlockScalar > Scalar
Definition: BlockSparseMatrix.h:105
Eigen::BlockSparseMatrix::IsColMajor
@ IsColMajor
Definition: BlockSparseMatrix.h:301
Eigen::BlockSparseMatrix::blockPtr
Index blockPtr(Index id) const
Definition: BlockSparseMatrix.h:936
Eigen::BlockSparseMatrixView::InnerIterator
Definition: BlockSparseMatrix.h:143
Eigen::BlockSparseMatrix::IsVectorAtCompileTime
@ IsVectorAtCompileTime
Definition: BlockSparseMatrix.h:300
Eigen::BlockSparseMatrix::BlockInnerIterator::row
Index row() const
Definition: BlockSparseMatrix.h:1003
Eigen::internal::traits< BlockSparseTimeDenseProduct< BlockSparseMatrixT, VecType > >::StorageKind
Dense StorageKind
Definition: BlockSparseMatrix.h:248
Eigen::BlockSparseTimeDenseProduct::operator=
BlockSparseTimeDenseProduct & operator=(const BlockSparseTimeDenseProduct &)
Eigen::BlockSparseMatrix::BlockRealScalar
Matrix< RealScalar, _BlockAtCompileTime, _BlockAtCompileTime, IsColMajor ? ColMajor :RowMajor > BlockRealScalar
Definition: BlockSparseMatrix.h:304
Eigen::BlockVectorView::size
Index size() const
Definition: BlockSparseMatrix.h:177
Eigen::BlockVectorView::m_spblockmat
const BlockSparseMatrixT & m_spblockmat
Definition: BlockSparseMatrix.h:194
Eigen::BlockSparseMatrix::InnerIterator::value
const Scalar & value() const
Definition: BlockSparseMatrix.h:1050
Eigen::internal::true_type
Definition: Meta.h:96
Eigen::BlockSparseMatrix::innerToBlock
Index innerToBlock(Index inner) const
Definition: BlockSparseMatrix.h:791
Eigen::BlockSparseMatrix::BlockSparseMatrix
BlockSparseMatrix(const BlockSparseMatrix &other)
Copy-constructor.
Definition: BlockSparseMatrix.h:331
id
static const Similarity3 id
Definition: testSimilarity3.cpp:44
Eigen::BlockVectorView::Scalar
Ref< const Matrix< typename BlockSparseMatrixT::Scalar,(RowsAtCompileTime==1)? 1 :BlockSize,(ColsAtCompileTime==1)? 1 :BlockSize > > Scalar
Definition: BlockSparseMatrix.h:167
Eigen::BlockSparseTimeDenseProduct::scaleAndAddTo
void scaleAndAddTo(Dest &dest, const typename Rhs::Scalar &alpha) const
Definition: BlockSparseMatrix.h:273
Eigen::BlockVectorView::coeff
Scalar coeff(Index bi, Index j) const
Definition: BlockSparseMatrix.h:187
Eigen::BlockSparseMatrix::operator=
BlockSparseMatrix & operator=(const MatrixType &spmat)
Assignment from a sparse matrix with the same storage order.
Definition: BlockSparseMatrix.h:405
handle
Definition: pytypes.h:226
Eigen::BlockSparseMatrix::coeff
Map< const BlockScalar > coeff(Index brow, Index bcol) const
Definition: BlockSparseMatrix.h:832
j
std::ptrdiff_t j
Definition: tut_arithmetic_redux_minmax.cpp:2
Eigen::BlockSparseMatrix::InnerIterator::m_outerB
const Index m_outerB
Definition: BlockSparseMatrix.h:1069
Eigen::BlockSparseMatrix::m_nonzeros
Index m_nonzeros
Definition: BlockSparseMatrix.h:963
Eigen::BlockSparseMatrix::blockInnerSize
Index blockInnerSize(Index bi) const
Definition: BlockSparseMatrix.h:899
Eigen::BlockSparseTimeDenseProduct::BlockSparseTimeDenseProduct
BlockSparseTimeDenseProduct(const Lhs &lhs, const Rhs &rhs)
Definition: BlockSparseMatrix.h:270
Eigen::LvalueBit
const unsigned int LvalueBit
Definition: Constants.h:144
Eigen::internal::sparse_time_dense_product
void sparse_time_dense_product(const SparseLhsType &lhs, const DenseRhsType &rhs, DenseResType &res, const AlphaType &alpha)
Definition: SparseDenseProduct.h:169
Eigen::BlockSparseMatrix::m_innerOffset
StorageIndex * m_innerOffset
Definition: BlockSparseMatrix.h:960
Eigen::BlockSparseTimeDenseProduct
Definition: BlockSparseMatrix.h:241
Eigen::BlockSparseMatrix::Scalar
_Scalar Scalar
Definition: BlockSparseMatrix.h:287
Eigen::BlockSparseMatrix::BlockSparseMatrix
BlockSparseMatrix()
Definition: BlockSparseMatrix.h:309
Eigen::Dynamic
const int Dynamic
Definition: Constants.h:22
Eigen::BlockSparseMatrix::innerSize
Index innerSize() const
Definition: BlockSparseMatrix.h:753
Eigen::BlockSparseMatrix::nonZerosBlocks
Index nonZerosBlocks() const
Definition: BlockSparseMatrix.h:860
Eigen::BlockSparseMatrix::MaxColsAtCompileTime
@ MaxColsAtCompileTime
Definition: BlockSparseMatrix.h:299
Eigen::BlockSparseMatrix::reserve
void reserve(const Index nonzerosblocks)
Allocate the internal array of pointers to blocks and their inner indices.
Definition: BlockSparseMatrix.h:596
Eigen::BlockSparseMatrix::BlockInnerIterator::BlockInnerIterator
BlockInnerIterator(const BlockSparseMatrix &mat, const Index outer)
Definition: BlockSparseMatrix.h:980
Eigen::BlockSparseMatrixView::Index
BlockSparseMatrixT::Index Index
Definition: BlockSparseMatrix.h:107
Eigen::BlockSparseMatrix::setBlockStructure
void setBlockStructure(const MatrixType &blockPattern)
Set the nonzero block pattern of the matrix.
Definition: BlockSparseMatrix.h:498
Eigen::BlockVectorReturn::m_vec
VectorType & m_vec
Definition: BlockSparseMatrix.h:236
Eigen::BlockVectorView::BlockVectorView
BlockVectorView(const BlockSparseMatrixT &spblockmat, const VectorType &vec)
Definition: BlockSparseMatrix.h:170
std::swap
void swap(GeographicLib::NearestNeighbor< dist_t, pos_t, distfun_t > &a, GeographicLib::NearestNeighbor< dist_t, pos_t, distfun_t > &b)
Definition: NearestNeighbor.hpp:827
Eigen::BlockVectorView::cols
Index cols() const
Definition: BlockSparseMatrix.h:173
Eigen::BlockSparseMatrix::BlockSparseMatrix
BlockSparseMatrix(const MatrixType &spmat)
Constructor from a sparse matrix.
Definition: BlockSparseMatrix.h:389
Eigen::BlockSparseMatrix::BlockScalarReturnType
internal::conditional< _BlockAtCompileTime==Dynamic, Scalar, BlockScalar >::type BlockScalarReturnType
Definition: BlockSparseMatrix.h:305
Eigen::BlockSparseMatrix::BlockInnerIterator
Definition: BlockSparseMatrix.h:972
Eigen::internal::traits< BlockSparseMatrixView< BlockSparseMatrixT > >::Scalar
Ref< Matrix< typename BlockSparseMatrixT::Scalar, BlockSparseMatrixT::BlockSize, BlockSparseMatrixT::BlockSize > > Scalar
Definition: BlockSparseMatrix.h:80
m
Matrix3f m
Definition: AngleAxis_mimic_euler.cpp:1
Eigen::BlockSparseMatrixView::cols
Index cols() const
Definition: BlockSparseMatrix.h:126
Eigen::BlockSparseMatrixView::outerSize
Index outerSize() const
Definition: BlockSparseMatrix.h:122
Eigen::BlockSparseMatrix::blockRows
Index blockRows() const
Definition: BlockSparseMatrix.h:765
Eigen::BlockSparseMatrix::BlockInnerIterator::m_outer
const Index m_outer
Definition: BlockSparseMatrix.h:1014
Eigen::BlockSparseMatrix::blockCols
Index blockCols() const
Definition: BlockSparseMatrix.h:770
Eigen::BlockSparseMatrix::InnerIterator::m_end
Index m_end
Definition: BlockSparseMatrix.h:1074
Eigen::Map
A matrix or vector expression mapping an existing array of data.
Definition: Map.h:94
Eigen::InnerIterator
An InnerIterator allows to loop over the element of any matrix expression.
Definition: CoreIterators.h:33
Eigen::internal::ref_selector
Definition: XprHelper.h:416
Eigen::BlockSparseMatrix::RowsAtCompileTime
@ RowsAtCompileTime
Definition: BlockSparseMatrix.h:296
Eigen::BlockSparseMatrix::blockInnerIndex
Index blockInnerIndex(Index bi) const
Definition: BlockSparseMatrix.h:893
Eigen::BlockSparseMatrix::m_innerBSize
Index m_innerBSize
Definition: BlockSparseMatrix.h:958
Eigen::BlockSparseMatrix::swap
friend void swap(BlockSparseMatrix &first, BlockSparseMatrix &second)
Definition: BlockSparseMatrix.h:350
Eigen::BlockSparseMatrix::InnerIterator::itb
BlockInnerIterator itb
Definition: BlockSparseMatrix.h:1070
offset
set noclip points set clip one set noclip two set bar set border lt lw set xdata set ydata set zdata set x2data set y2data set boxwidth set dummy y set format x g set format y g set format x2 g set format y2 g set format z g set angles radians set nogrid set key title set key left top Right noreverse box linetype linewidth samplen spacing width set nolabel set noarrow set nologscale set logscale x set set pointsize set encoding default set nopolar set noparametric set set set set surface set nocontour set clabel set mapping cartesian set nohidden3d set cntrparam order set cntrparam linear set cntrparam levels auto set cntrparam points set size set set xzeroaxis lt lw set x2zeroaxis lt lw set yzeroaxis lt lw set y2zeroaxis lt lw set tics in set ticslevel set tics set mxtics default set mytics default set mx2tics default set my2tics default set xtics border mirror norotate autofreq set ytics border mirror norotate autofreq set ztics border nomirror norotate autofreq set nox2tics set noy2tics set timestamp bottom norotate offset
Definition: gnuplot_common_settings.hh:64
Eigen::BlockSparseMatrix::setBlockSize
void setBlockSize(Index blockSize)
set the block size at runtime for fixed-size block layout
Definition: BlockSparseMatrix.h:549
Eigen::BlockSparseMatrixView::coeff
Scalar coeff(Index row, Index col)
Definition: BlockSparseMatrix.h:134
Eigen::BlockSparseMatrix::m_values
Scalar * m_values
Definition: BlockSparseMatrix.h:964
Eigen::BlockSparseMatrix::InnerIterator::valueRef
Scalar & valueRef()
Definition: BlockSparseMatrix.h:1054
Eigen::BlockSparseMatrix::operator<<
friend std::ostream & operator<<(std::ostream &s, const BlockSparseMatrix &m)
Definition: BlockSparseMatrix.h:918
Eigen::BlockSparseMatrix::innerIndexPtr
StorageIndex * innerIndexPtr()
Definition: BlockSparseMatrix.h:866
Eigen::BlockSparseMatrix::blockColsIndex
Index blockColsIndex(Index bj) const
Definition: BlockSparseMatrix.h:884
Eigen::BlockSparseMatrix::InnerIterator::col
Index col() const
Definition: BlockSparseMatrix.h:1060
Eigen::BlockSparseMatrix::BlockSize
@ BlockSize
Definition: BlockSparseMatrix.h:295
a
ArrayXXi a
Definition: Array_initializer_list_23_cxx11.cpp:1
Eigen::internal::TripletComp
Definition: BlockSparseMatrix.h:87
Eigen::BlockSparseMatrix::m_outerIndex
StorageIndex * m_outerIndex
Definition: BlockSparseMatrix.h:967
Eigen::BlockVectorView::Index
BlockSparseMatrixT::Index Index
Definition: BlockSparseMatrix.h:168
Eigen::BlockSparseMatrix::InnerIterator::m_offset
const Index m_offset
Definition: BlockSparseMatrix.h:1071
Eigen::internal::traits< BlockSparseTimeDenseProduct< BlockSparseMatrixT, VecType > >::Index
BlockSparseMatrixT::Index Index
Definition: BlockSparseMatrix.h:251
Eigen::BlockSparseMatrixView::ColsAtCompileTime
@ ColsAtCompileTime
Definition: BlockSparseMatrix.h:113
Eigen::internal::traits< BlockSparseMatrix< _Scalar, _BlockAtCompileTime, _Options, _Index > >::XprKind
MatrixXpr XprKind
Definition: BlockSparseMatrix.h:65
Eigen::Ref
A matrix or vector expression mapping an existing expression.
Definition: Ref.h:281
Eigen::BlockSparseMatrix::m_nonzerosblocks
Index m_nonzerosblocks
Definition: BlockSparseMatrix.h:962
Eigen::BlockSparseMatrixView::MaxColsAtCompileTime
@ MaxColsAtCompileTime
Definition: BlockSparseMatrix.h:114
Eigen::BlockSparseMatrix::InnerIterator::InnerIterator
InnerIterator(const BlockSparseMatrix &mat, Index outer)
Definition: BlockSparseMatrix.h:1023
Eigen::BlockSparseMatrix::outerToBlock
Index outerToBlock(Index outer) const
Definition: BlockSparseMatrix.h:779
Eigen::internal::traits
Definition: ForwardDeclarations.h:17
Eigen::BlockSparseMatrixView::BlockSparseMatrixView
BlockSparseMatrixView(const BlockSparseMatrixT &spblockmat)
Definition: BlockSparseMatrix.h:118
Eigen::BlockSparseMatrix::blockOuterSize
Index blockOuterSize(Index bj) const
Definition: BlockSparseMatrix.h:903
Eigen::internal::TripletComp::operator()
bool operator()(const Triplet &a, const Triplet &b)
Definition: BlockSparseMatrix.h:90
EIGEN_STATIC_ASSERT
#define EIGEN_STATIC_ASSERT(CONDITION, MSG)
Definition: StaticAssert.h:127
Eigen::BlockSparseMatrixView::Nested
BlockSparseMatrixT Nested
Definition: BlockSparseMatrix.h:108
Eigen::BlockVectorReturn::RowsAtCompileTime
@ RowsAtCompileTime
Definition: BlockSparseMatrix.h:208
Eigen::internal::Rhs
@ Rhs
Definition: TensorContractionMapper.h:18
Eigen::BlockVectorReturn::Flags
@ Flags
Definition: BlockSparseMatrix.h:209
row
m row(1)
Eigen::BlockSparseMatrix::InnerIterator::outer
Index outer() const
Definition: BlockSparseMatrix.h:1059
Eigen::BlockSparseMatrix::InnerIterator::index
Index index() const
Definition: BlockSparseMatrix.h:1058
Eigen::BlockSparseMatrix::BlockInnerIterator::cols
Index cols() const
Definition: BlockSparseMatrix.h:1009
Eigen::BlockSparseMatrix::innerIndexPtr
const StorageIndex * innerIndexPtr() const
Definition: BlockSparseMatrix.h:867
Eigen::BlockSparseMatrix::insert
Map< BlockScalar > insert(Index brow, Index bcol)
Eigen::BlockSparseMatrix::m_outerOffset
StorageIndex * m_outerOffset
Definition: BlockSparseMatrix.h:961
Eigen::BlockVectorReturn::ColsAtCompileTime
@ ColsAtCompileTime
Definition: BlockSparseMatrix.h:207
Eigen::BlockVectorView::ColsAtCompileTime
@ ColsAtCompileTime
Definition: BlockSparseMatrix.h:163
Eigen::BlockSparseMatrix::operator=
BlockSparseMatrix & operator=(BlockSparseMatrix other)
Definition: BlockSparseMatrix.h:365
Eigen::BlockSparseMatrix::BlockInnerIterator::outer
Index outer() const
Definition: BlockSparseMatrix.h:1001
Eigen::BlockSparseMatrix::outerIndexPtr
const StorageIndex * outerIndexPtr() const
Definition: BlockSparseMatrix.h:869
Eigen::BlockSparseMatrix::BlockInnerIterator::valueRef
Map< BlockScalar > valueRef()
Definition: BlockSparseMatrix.h:994
Eigen::Matrix
The matrix class, also used for vectors and row-vectors.
Definition: 3rdparty/Eigen/Eigen/src/Core/Matrix.h:178
Eigen::BlockSparseMatrix::valuePtr
BlockScalarReturnType * valuePtr()
Definition: BlockSparseMatrix.h:864
Eigen::BlockSparseMatrix::innerBlocks
Index innerBlocks() const
Definition: BlockSparseMatrix.h:776
Eigen::BlockVectorReturn::coeffRef
Scalar coeffRef(Index bi, Index j)
Definition: BlockSparseMatrix.h:227
internal
Definition: BandTriangularSolver.h:13
VectorType
Definition: FFTW.cpp:65
Eigen::internal::traits< BlockSparseMatrix< _Scalar, _BlockAtCompileTime, _Options, _Index > >::Scalar
_Scalar Scalar
Definition: BlockSparseMatrix.h:62
Eigen::BlockSparseMatrix::rows
Index rows() const
Definition: BlockSparseMatrix.h:738
Eigen::InnerRandomAccessPattern
const int InnerRandomAccessPattern
Definition: SparseUtil.h:48
Eigen::placeholders::end
static const EIGEN_DEPRECATED end_t end
Definition: IndexedViewHelper.h:181
Eigen::BlockSparseMatrix::InnerIterator::m_start
Index m_start
Definition: BlockSparseMatrix.h:1072
Eigen::BlockVectorReturn::size
Index size() const
Definition: BlockSparseMatrix.h:217
Base
Definition: test_virtual_functions.cpp:156
Eigen::BlockSparseMatrix::InnerIterator::m_outer
const Index m_outer
Definition: BlockSparseMatrix.h:1068
Eigen::BlockVectorReturn::BlockVectorReturn
BlockVectorReturn(const BlockSparseMatrixT &spblockmat, VectorType &vec)
Definition: BlockSparseMatrix.h:214
Eigen::internal::traits< BlockSparseMatrix< _Scalar, _BlockAtCompileTime, _Options, _Index > >::Index
_Index Index
Definition: BlockSparseMatrix.h:63
Eigen::BlockSparseMatrix::StorageIndex
_StorageIndex StorageIndex
Definition: BlockSparseMatrix.h:289
Eigen::NestByRefBit
const unsigned int NestByRefBit
Definition: Constants.h:169
Eigen::BlockSparseMatrix::BlockInnerIterator::index
Index index() const
Definition: BlockSparseMatrix.h:1000
Eigen::BlockVectorView::BlockSize
@ BlockSize
Definition: BlockSparseMatrix.h:162
Eigen::BlockSparseMatrixView::InnerIterator::InnerIterator
InnerIterator(const BlockSparseMatrixView &mat, Index outer)
Definition: BlockSparseMatrix.h:146
Eigen::NumTraits
Holds information about the various numeric (i.e. scalar) types allowed by Eigen.
Definition: NumTraits.h:232
Eigen::BlockSparseMatrix::m_blockPtr
StorageIndex * m_blockPtr
Definition: BlockSparseMatrix.h:965
Eigen::BlockSparseMatrixView
Definition: BlockSparseMatrix.h:56
pybind_wrapper_test_script.other
other
Definition: pybind_wrapper_test_script.py:42
Eigen::BlockSparseMatrix::outerIndexPtr
StorageIndex * outerIndexPtr()
Definition: BlockSparseMatrix.h:868
Eigen::BlockSparseMatrix::BlockInnerIterator::operator++
BlockInnerIterator & operator++()
Definition: BlockSparseMatrix.h:987
Eigen::BlockSparseMatrix::MaxRowsAtCompileTime
@ MaxRowsAtCompileTime
Definition: BlockSparseMatrix.h:298
Eigen::BlockSparseMatrix::outerSize
Index outerSize() const
Definition: BlockSparseMatrix.h:759
Eigen::BlockSparseMatrix::m_indices
StorageIndex * m_indices
Definition: BlockSparseMatrix.h:966
Eigen::BlockSparseMatrixView::coeffRef
Scalar coeffRef(Index row, Index col)
Definition: BlockSparseMatrix.h:138
Eigen::BlockVectorView
Definition: BlockSparseMatrix.h:158
Eigen::BlockVectorReturn
Definition: BlockSparseMatrix.h:198
Scalar
SCALAR Scalar
Definition: bench_gemm.cpp:46
Eigen::BlockSparseMatrix::coeffRef
Ref< BlockScalar > coeffRef(Index brow, Index bcol)
Definition: BlockSparseMatrix.h:806
Eigen::internal::TripletComp::Triplet
Iterator::value_type Triplet
Definition: BlockSparseMatrix.h:89
Eigen::BlockSparseMatrix::nonZeros
Index nonZeros() const
Definition: BlockSparseMatrix.h:862
Eigen::Index
EIGEN_DEFAULT_DENSE_INDEX_TYPE Index
The Index type as used for the API.
Definition: Meta.h:74
Eigen::BlockSparseMatrix::blockOuterIndex
Index blockOuterIndex(Index bj) const
Definition: BlockSparseMatrix.h:889
Eigen::BlockSparseMatrix::BlockInnerIterator::col
Index col() const
Definition: BlockSparseMatrix.h:1005
Eigen::Dense
Definition: Constants.h:507


gtsam
Author(s):
autogenerated on Wed Jan 22 2025 04:01:08