:orphan: # MatDuplicateOption Indicates if a duplicated sparse matrix should have its numerical values copied over or just its nonzero structure. ## Synopsis ``` typedef enum { MAT_DO_NOT_COPY_VALUES, MAT_COPY_VALUES, MAT_SHARE_NONZERO_PATTERN } MatDuplicateOption; ``` ## Values - ***`MAT_DO_NOT_COPY_VALUES` -*** Create a matrix using the same nonzero pattern as the original matrix, with zeros for the numerical values - ***`MAT_COPY_VALUES` -*** Create a matrix with the same nonzero pattern as the original matrix and with the same numerical values. - ***`MAT_SHARE_NONZERO_PATTERN` -*** Create a matrix that shares the nonzero structure with the previous matrix and does not copy it, using zeros for the numerical values. The parent and child matrices will share their index (i and j) arrays, and you cannot insert new nonzero entries into either matrix ## Note Many matrix types (including `MATSEQAIJ`) do not support the `MAT_SHARE_NONZERO_PATTERN` optimization; in this case the behavior is as if `MAT_DO_NOT_COPY_VALUES` has been specified. ## See Also [](ch_matrices), `Mat`, `MatDuplicate()` ## Level beginner ## Location include/petscmat.h ## Examples src/ksp/ksp/tutorials/ex42.c
src/ksp/ksp/tutorials/ex5.c
src/ksp/ksp/tutorials/ex5f.F90
src/ksp/ksp/tutorials/ex76.c
src/ksp/ksp/tutorials/ex81.c
src/tao/pde_constrained/tutorials/elliptic.c
src/tao/pde_constrained/tutorials/hyperbolic.c
src/tao/pde_constrained/tutorials/parabolic.c
src/tao/tutorials/ex4.c
src/tao/unconstrained/tutorials/burgers_spectral.c
src/tao/unconstrained/tutorials/spectraladjointassimilation.c
--- [Edit on GitLab](https://gitlab.com/petsc/petsc/-/edit/release/include/petscmat.h) [Index of all Mat routines](index.md) [Table of Contents for all manual pages](/manualpages/index.md) [Index of all manual pages](/manualpages/singleindex.md)