MatSetSizes#

Sets the local and global sizes, and checks to determine compatibility

Synopsis#

#include "petscmat.h"  
PetscErrorCode MatSetSizes(Mat A, PetscInt m, PetscInt n, PetscInt M, PetscInt N)

Collective on Mat

Input Parameters#

Notes#

m (n) and M (N) cannot be both PETSC_DECIDE If one processor calls this with M (N) of PETSC_DECIDE then all processors must, otherwise the program will hang.

If PETSC_DECIDE is not used for the arguments ‘m’ and ‘n’, then the user must ensure that they are chosen to be compatible with the vectors. To do this, one first considers the matrix-vector product ‘y = A x’. The ‘m’ that is used in the above routine must match the local size used in the vector creation routine VecCreateMPI() for ‘y’. Likewise, the ‘n’ used must match that used as the local size in VecCreateMPI() for ‘x’.

You cannot change the sizes once they have been set.

The sizes must be set before MatSetUp() or MatXXXSetPreallocation() is called.

See Also#

MatGetSize(), PetscSplitOwnership()

Level#

beginner

Location#

src/mat/utils/gcreate.c

Examples#

src/mat/tutorials/ex15.c.html
src/mat/tutorials/ex15f.F90.html
src/mat/tutorials/ex16.c.html
src/mat/tutorials/ex17.c.html
src/mat/tutorials/ex18.c.html
src/mat/tutorials/ex2.c.html
src/mat/tutorials/ex5k.kokkos.cxx.html
src/mat/tutorials/ex8.c.html
src/ksp/pc/tutorials/ex3.c.html
src/ksp/ksp/tutorials/ex100.c.html
src/ksp/ksp/tutorials/ex100f.F90.html


Edit on GitLab

Index of all Mat routines
Table of Contents for all manual pages
Index of all manual pages