Actual source code: ex181.c
petsc-3.13.6 2020-09-29
2: static char help[] = "Tests MatCreateSubmatrix() with entire matrix, modified from ex59.c.";
4: #include <petscmat.h>
6: int main(int argc,char **args)
7: {
8: Mat C,A,Adup;
9: PetscInt i,j,m = 3,n = 2,rstart,rend;
10: PetscMPIInt size,rank;
12: PetscScalar v;
13: IS isrow;
14: PetscBool detect_bug = PETSC_FALSE;
16: PetscInitialize(&argc,&args,(char*)0,help);if (ierr) return ierr;
17: PetscOptionsHasName(NULL,NULL,"-detect_bug",&detect_bug);
18: MPI_Comm_rank(PETSC_COMM_WORLD,&rank);
19: MPI_Comm_size(PETSC_COMM_WORLD,&size);
20: n = 2*size;
22: MatCreate(PETSC_COMM_WORLD,&C);
23: MatSetSizes(C,PETSC_DECIDE,PETSC_DECIDE,m*n,m*n);
24: MatSetFromOptions(C);
25: MatSetUp(C);
27: /*
28: This is JUST to generate a nice test matrix, all processors fill up
29: the entire matrix. This is not something one would ever do in practice.
30: */
31: MatGetOwnershipRange(C,&rstart,&rend);
32: for (i=rstart; i<rend; i++) {
33: for (j=0; j<m*n; j++) {
34: v = i + j + 1;
35: MatSetValues(C,1,&i,1,&j,&v,INSERT_VALUES);
36: }
37: }
38: MatAssemblyBegin(C,MAT_FINAL_ASSEMBLY);
39: MatAssemblyEnd(C,MAT_FINAL_ASSEMBLY);
40: PetscViewerPushFormat(PETSC_VIEWER_STDOUT_WORLD,PETSC_VIEWER_ASCII_COMMON);
41: MatView(C,PETSC_VIEWER_STDOUT_WORLD);
42: PetscViewerPopFormat(PETSC_VIEWER_STDOUT_WORLD);
44: /*
45: Generate a new matrix consisting every row and column of the original matrix
46: */
47: MatGetOwnershipRange(C,&rstart,&rend);
49: /* Create parallel IS with the rows we want on THIS processor */
50: if (detect_bug && !rank) {
51: ISCreateStride(PETSC_COMM_WORLD,1,rstart,1,&isrow);
52: } else {
53: ISCreateStride(PETSC_COMM_WORLD,rend-rstart,rstart,1,&isrow);
54: }
55: MatCreateSubMatrix(C,isrow,NULL,MAT_INITIAL_MATRIX,&A);
57: /* Change C to test the case MAT_REUSE_MATRIX */
58: if (!rank ) {
59: i = 0; j = 0; v = 100;
60: MatSetValues(C,1,&i,1,&j,&v,INSERT_VALUES);
61: }
62: MatAssemblyBegin(C,MAT_FINAL_ASSEMBLY);
63: MatAssemblyEnd(C,MAT_FINAL_ASSEMBLY);
65: MatCreateSubMatrix(C,isrow,NULL,MAT_REUSE_MATRIX,&A);
66: PetscViewerPushFormat(PETSC_VIEWER_STDOUT_WORLD,PETSC_VIEWER_ASCII_COMMON);
67: MatView(A,PETSC_VIEWER_STDOUT_WORLD);
68: PetscViewerPopFormat(PETSC_VIEWER_STDOUT_WORLD);
70: /* Test MatDuplicate */
71: MatDuplicate(A,MAT_COPY_VALUES,&Adup);
72: MatDestroy(&Adup);
74: ISDestroy(&isrow);
75: MatDestroy(&A);
76: MatDestroy(&C);
77: PetscFinalize();
78: return ierr;
79: }
82: /*TEST
84: test:
85: nsize: 2
86: filter: grep -v "Mat Object"
87: requires: !complex
89: test:
90: suffix: 2
91: nsize: 3
92: args: -detect_bug
93: filter: grep -v "Mat Object"
94: requires: !complex
96: TEST*/