petsc-3.9.4 2018-09-11
MatZeroRows
Zeros all entries (except possibly the main diagonal) of a set of rows of a matrix.
Synopsis
#include "petscmat.h"
PetscErrorCode MatZeroRows(Mat mat,PetscInt numRows,const PetscInt rows[],PetscScalar diag,Vec x,Vec b)
Collective on Mat
Input Parameters
| mat | - the matrix
|
| numRows | - the number of rows to remove
|
| rows | - the global row indices
|
| diag | - value put in all diagonals of eliminated rows (0.0 will even eliminate diagonal entry)
|
| x | - optional vector of solutions for zeroed rows (other entries in vector are not used)
|
| b | - optional vector of right hand side, that will be adjusted by provided solution
|
Notes
For the AIJ and BAIJ matrix formats this removes the old nonzero structure,
but does not release memory. For the dense and block diagonal
formats this does not alter the nonzero structure.
If the option MatSetOption(mat,MAT_KEEP_NONZERO_PATTERN,PETSC_TRUE) the nonzero structure
of the matrix is not changed (even for AIJ and BAIJ matrices) the values are
merely zeroed.
The user can set a value in the diagonal entry (or for the AIJ and
row formats can optionally remove the main diagonal entry from the
nonzero structure as well, by passing 0.0 as the final argument).
For the parallel case, all processes that share the matrix (i.e.,
those in the communicator used for matrix creation) MUST call this
routine, regardless of whether any rows being zeroed are owned by
them.
Each processor can indicate any rows in the entire matrix to be zeroed (i.e. each process does NOT have to
list only rows local to itself).
You can call MatSetOption(mat,MAT_NO_OFF_PROC_ZERO_ROWS,PETSC_TRUE) if each process indicates only rows it
owns that are to be zeroed. This saves a global synchronization in the implementation.
See Also
MatZeroRowsIS(), MatZeroRowsColumns(), MatZeroRowsLocalIS(), MatZeroRowsStencil(), MatZeroEntries(), MatZeroRowsLocal(), MatSetOption(),
MatZeroRowsColumnsLocal(), MatZeroRowsColumnsLocalIS(), MatZeroRowsColumnsIS(), MatZeroRowsColumnsStencil()
Level
intermediate
Location
src/mat/interface/matrix.c
Examples
src/ksp/ksp/examples/tutorials/ex3.c.html
src/ksp/ksp/examples/tutorials/ex49.c.html
src/ksp/ksp/examples/tutorials/ex51.c.html
src/ksp/ksp/examples/tutorials/ex72.c.html
Implementations
MatZeroRows_MPIAIJ in src/mat/impls/aij/mpi/mpiaij.c
MatZeroRows_SeqAIJ in src/mat/impls/aij/seq/aij.c
MatZeroRows_MPIBAIJ in src/mat/impls/baij/mpi/mpibaij.c
MatZeroRows_SeqBAIJ_Check_Blocks in src/mat/impls/baij/seq/baij.c
MatZeroRows_SeqBAIJ in src/mat/impls/baij/seq/baij.c
MatZeroRows_MPIDense in src/mat/impls/dense/mpi/mpidense.c
MatZeroRows_SeqDense in src/mat/impls/dense/seq/dense.c
MatZeroRows_HYPRE_CSRMatrix in src/mat/impls/hypre/mhypre.c
MatZeroRows_HYPRE in src/mat/impls/hypre/mhypre.c
MatZeroRows_IS in src/mat/impls/is/matis.c
MatZeroRows_SeqSBAIJ_Check_Blocks in src/mat/impls/sbaij/seq/sbaij.c
Index of all Mat routines
Table of Contents for all manual pages
Index of all manual pages