1c4762a1bSJed Brown static char help[] = "Tests MatNorm(), MatLUFactor(), MatSolve() and MatSolveAdd().\n\n"; 2c4762a1bSJed Brown 3c4762a1bSJed Brown #include <petscmat.h> 4c4762a1bSJed Brown 5d71ae5a4SJacob Faibussowitsch int main(int argc, char **args) 6d71ae5a4SJacob Faibussowitsch { 7c4762a1bSJed Brown Mat C; 8c4762a1bSJed Brown PetscInt i, j, m = 3, n = 3, Ii, J; 9c4762a1bSJed Brown PetscBool flg; 10c4762a1bSJed Brown PetscScalar v; 11c4762a1bSJed Brown IS perm, iperm; 12c4762a1bSJed Brown Vec x, u, b, y; 13c4762a1bSJed Brown PetscReal norm, tol = PETSC_SMALL; 14c4762a1bSJed Brown MatFactorInfo info; 15c4762a1bSJed Brown PetscMPIInt size; 16c4762a1bSJed Brown 17327415f7SBarry Smith PetscFunctionBeginUser; 18*c8025a54SPierre Jolivet PetscCall(PetscInitialize(&argc, &args, NULL, help)); 199566063dSJacob Faibussowitsch PetscCallMPI(MPI_Comm_size(PETSC_COMM_WORLD, &size)); 20be096a46SBarry Smith PetscCheck(size == 1, PETSC_COMM_WORLD, PETSC_ERR_WRONG_MPI_SIZE, "This is a uniprocessor example only!"); 219566063dSJacob Faibussowitsch PetscCall(MatCreate(PETSC_COMM_WORLD, &C)); 229566063dSJacob Faibussowitsch PetscCall(MatSetSizes(C, PETSC_DECIDE, PETSC_DECIDE, m * n, m * n)); 239566063dSJacob Faibussowitsch PetscCall(MatSetFromOptions(C)); 249566063dSJacob Faibussowitsch PetscCall(MatSetUp(C)); 259566063dSJacob Faibussowitsch PetscCall(PetscOptionsHasName(NULL, NULL, "-symmetric", &flg)); 26c4762a1bSJed Brown if (flg) { /* Treat matrix as symmetric only if we set this flag */ 279566063dSJacob Faibussowitsch PetscCall(MatSetOption(C, MAT_SYMMETRIC, PETSC_TRUE)); 289566063dSJacob Faibussowitsch PetscCall(MatSetOption(C, MAT_SYMMETRY_ETERNAL, PETSC_TRUE)); 29c4762a1bSJed Brown } 30c4762a1bSJed Brown 31c4762a1bSJed Brown /* Create the matrix for the five point stencil, YET AGAIN */ 32c4762a1bSJed Brown for (i = 0; i < m; i++) { 33c4762a1bSJed Brown for (j = 0; j < n; j++) { 349371c9d4SSatish Balay v = -1.0; 359371c9d4SSatish Balay Ii = j + n * i; 369371c9d4SSatish Balay if (i > 0) { 379371c9d4SSatish Balay J = Ii - n; 389371c9d4SSatish Balay PetscCall(MatSetValues(C, 1, &Ii, 1, &J, &v, INSERT_VALUES)); 399371c9d4SSatish Balay } 409371c9d4SSatish Balay if (i < m - 1) { 419371c9d4SSatish Balay J = Ii + n; 429371c9d4SSatish Balay PetscCall(MatSetValues(C, 1, &Ii, 1, &J, &v, INSERT_VALUES)); 439371c9d4SSatish Balay } 449371c9d4SSatish Balay if (j > 0) { 459371c9d4SSatish Balay J = Ii - 1; 469371c9d4SSatish Balay PetscCall(MatSetValues(C, 1, &Ii, 1, &J, &v, INSERT_VALUES)); 479371c9d4SSatish Balay } 489371c9d4SSatish Balay if (j < n - 1) { 499371c9d4SSatish Balay J = Ii + 1; 509371c9d4SSatish Balay PetscCall(MatSetValues(C, 1, &Ii, 1, &J, &v, INSERT_VALUES)); 519371c9d4SSatish Balay } 529371c9d4SSatish Balay v = 4.0; 539371c9d4SSatish Balay PetscCall(MatSetValues(C, 1, &Ii, 1, &Ii, &v, INSERT_VALUES)); 54c4762a1bSJed Brown } 55c4762a1bSJed Brown } 569566063dSJacob Faibussowitsch PetscCall(MatAssemblyBegin(C, MAT_FINAL_ASSEMBLY)); 579566063dSJacob Faibussowitsch PetscCall(MatAssemblyEnd(C, MAT_FINAL_ASSEMBLY)); 589566063dSJacob Faibussowitsch PetscCall(MatGetOrdering(C, MATORDERINGRCM, &perm, &iperm)); 599566063dSJacob Faibussowitsch PetscCall(MatView(C, PETSC_VIEWER_STDOUT_WORLD)); 609566063dSJacob Faibussowitsch PetscCall(ISView(perm, PETSC_VIEWER_STDOUT_SELF)); 619566063dSJacob Faibussowitsch PetscCall(VecCreateSeq(PETSC_COMM_SELF, m * n, &u)); 629566063dSJacob Faibussowitsch PetscCall(VecSet(u, 1.0)); 639566063dSJacob Faibussowitsch PetscCall(VecDuplicate(u, &x)); 649566063dSJacob Faibussowitsch PetscCall(VecDuplicate(u, &b)); 659566063dSJacob Faibussowitsch PetscCall(VecDuplicate(u, &y)); 669566063dSJacob Faibussowitsch PetscCall(MatMult(C, u, b)); 679566063dSJacob Faibussowitsch PetscCall(VecCopy(b, y)); 689566063dSJacob Faibussowitsch PetscCall(VecScale(y, 2.0)); 69c4762a1bSJed Brown 709566063dSJacob Faibussowitsch PetscCall(MatNorm(C, NORM_FROBENIUS, &norm)); 719566063dSJacob Faibussowitsch PetscCall(PetscPrintf(PETSC_COMM_SELF, "Frobenius norm of matrix %g\n", (double)norm)); 729566063dSJacob Faibussowitsch PetscCall(MatNorm(C, NORM_1, &norm)); 739566063dSJacob Faibussowitsch PetscCall(PetscPrintf(PETSC_COMM_SELF, "One norm of matrix %g\n", (double)norm)); 749566063dSJacob Faibussowitsch PetscCall(MatNorm(C, NORM_INFINITY, &norm)); 759566063dSJacob Faibussowitsch PetscCall(PetscPrintf(PETSC_COMM_SELF, "Infinity norm of matrix %g\n", (double)norm)); 76c4762a1bSJed Brown 779566063dSJacob Faibussowitsch PetscCall(MatFactorInfoInitialize(&info)); 78c4762a1bSJed Brown info.fill = 2.0; 79c4762a1bSJed Brown info.dtcol = 0.0; 80c4762a1bSJed Brown info.zeropivot = 1.e-14; 81c4762a1bSJed Brown info.pivotinblocks = 1.0; 82c4762a1bSJed Brown 839566063dSJacob Faibussowitsch PetscCall(MatLUFactor(C, perm, iperm, &info)); 84c4762a1bSJed Brown 85c4762a1bSJed Brown /* Test MatSolve */ 869566063dSJacob Faibussowitsch PetscCall(MatSolve(C, b, x)); 879566063dSJacob Faibussowitsch PetscCall(VecView(b, PETSC_VIEWER_STDOUT_SELF)); 889566063dSJacob Faibussowitsch PetscCall(VecView(x, PETSC_VIEWER_STDOUT_SELF)); 899566063dSJacob Faibussowitsch PetscCall(VecAXPY(x, -1.0, u)); 909566063dSJacob Faibussowitsch PetscCall(VecNorm(x, NORM_2, &norm)); 9148a46eb9SPierre Jolivet if (norm > tol) PetscCall(PetscPrintf(PETSC_COMM_SELF, "MatSolve: Norm of error %g\n", (double)norm)); 92c4762a1bSJed Brown 93c4762a1bSJed Brown /* Test MatSolveAdd */ 949566063dSJacob Faibussowitsch PetscCall(MatSolveAdd(C, b, y, x)); 959566063dSJacob Faibussowitsch PetscCall(VecAXPY(x, -1.0, y)); 969566063dSJacob Faibussowitsch PetscCall(VecAXPY(x, -1.0, u)); 979566063dSJacob Faibussowitsch PetscCall(VecNorm(x, NORM_2, &norm)); 9848a46eb9SPierre Jolivet if (norm > tol) PetscCall(PetscPrintf(PETSC_COMM_SELF, "MatSolveAdd(): Norm of error %g\n", (double)norm)); 99c4762a1bSJed Brown 1009566063dSJacob Faibussowitsch PetscCall(ISDestroy(&perm)); 1019566063dSJacob Faibussowitsch PetscCall(ISDestroy(&iperm)); 1029566063dSJacob Faibussowitsch PetscCall(VecDestroy(&u)); 1039566063dSJacob Faibussowitsch PetscCall(VecDestroy(&y)); 1049566063dSJacob Faibussowitsch PetscCall(VecDestroy(&b)); 1059566063dSJacob Faibussowitsch PetscCall(VecDestroy(&x)); 1069566063dSJacob Faibussowitsch PetscCall(MatDestroy(&C)); 1079566063dSJacob Faibussowitsch PetscCall(PetscFinalize()); 108b122ec5aSJacob Faibussowitsch return 0; 109c4762a1bSJed Brown } 110c4762a1bSJed Brown 111c4762a1bSJed Brown /*TEST 112c4762a1bSJed Brown 113c4762a1bSJed Brown test: 114c4762a1bSJed Brown 115c4762a1bSJed Brown TEST*/ 116