我正在学习在 c/c++ 中使用 petsc,以便在其中使用稀疏矩阵分解函数 (MatICCFactor)。我做的第一步是将一个玩具矩阵读入 petsc 以创建一个稀疏矩阵并在我对它做任何事情之前查看该矩阵。我是 c/c++ 编码 BTW 的初学者。这是我使用的代码:
static char help[] = "Tests Petscmat functions.\n\n";
#include<petscmat.h>
#include <petscsys.h>
int main(int argc,char **args)
{
PetscInitialize(&argc,&args,(char*)0, help);
Mat *A;
PetscInt m = 3;
PetscInt n = 3;
//to build sparse matrix(CSR)
/*
* 1 0 0
* 2 0 3
* 4 5 6
*/
PetscInt Iv[4]={0,1,3,6}; //i vec size nrow+1
PetscInt Jv[6]={0,0,2,0,1,2}; //j vec size nnz
PetscScalar vv[6]={1,2,3,4,5,6}; //v vec size nnz
PetscInt nzrv[3]={1,2,3}; // nnz per row
PetscViewer viewer;
//MatSeqAIJSetPreallocation(A,n,nzrv);//If nnz is given then nz is ignored
MatCreateSeqAIJWithArrays(PETSC_COMM_WORLD, m, n, Iv,Jv,vv, A);
MatView(A,viewer);
PetscViewerDestroy(&viewer);
MatDestroy(&A);
PetscFinalize();
return 0;
}
它编译但在运行时会导致分段冲突。我发现MatView()是分段错误的根源。谁能帮我正确使用 MatView 吗?