Actual source code: getcolv.c
petsc-3.3-p7 2013-05-11
2: #include <petsc-private/matimpl.h> /*I "petscmat.h" I*/
6: /*@
7: MatGetColumnVector - Gets the values from a given column of a matrix.
9: Not Collective
11: Input Parameters:
12: + A - the matrix
13: . yy - the vector
14: - c - the column requested (in global numbering)
16: Level: advanced
18: Notes:
19: Each processor for which this is called gets the values for its rows.
21: Since PETSc matrices are usually stored in compressed row format, this routine
22: will generally be slow.
24: The vector must have the same parallel row layout as the matrix.
26: Contributed by: Denis Vanderstraeten
28: .keywords: matrix, column, get
30: .seealso: MatGetRow(), MatGetDiagonal()
32: @*/
33: PetscErrorCode MatGetColumnVector(Mat A,Vec yy,PetscInt col)
34: {
35: PetscScalar *y;
36: const PetscScalar *v;
37: PetscErrorCode ierr;
38: PetscInt i,j,nz,N,Rs,Re,rs,re;
39: const PetscInt *idx;
40:
44: if (col < 0) SETERRQ1(PETSC_COMM_SELF,PETSC_ERR_ARG_OUTOFRANGE,"Requested negative column: %D",col);
45: MatGetSize(A,PETSC_NULL,&N);
46: if (col >= N) SETERRQ2(PETSC_COMM_SELF,PETSC_ERR_ARG_OUTOFRANGE,"Requested column %D larger than number columns in matrix %D",col,N);
47: MatGetOwnershipRange(A,&Rs,&Re);
48: VecGetOwnershipRange(yy,&rs,&re);
49: if (Rs != rs || Re != re) SETERRQ4(PETSC_COMM_SELF,PETSC_ERR_ARG_INCOMP,"Matrix %D %D does not have same ownership range (size) as vector %D %D",Rs,Re,rs,re);
51: if (A->ops->getcolumnvector) {
52: (*A->ops->getcolumnvector)(A,yy,col);
53: } else {
54: VecSet(yy,0.0);
55: VecGetArray(yy,&y);
56:
57: for (i=Rs; i<Re; i++) {
58: MatGetRow(A,i,&nz,&idx,&v);
59: if (nz && idx[0] <= col) {
60: /*
61: Should use faster search here
62: */
63: for (j=0; j<nz; j++) {
64: if (idx[j] >= col) {
65: if (idx[j] == col) y[i-rs] = v[j];
66: break;
67: }
68: }
69: }
70: MatRestoreRow(A,i,&nz,&idx,&v);
71: }
72: VecRestoreArray(yy,&y);
73: }
74: return(0);
75: }
82: /*@
83: MatGetColumnNorms - Gets the norms of each column of a sparse or dense matrix.
85: Input Parameter:
86: + A - the matrix
87: - type - NORM_2, NORM_1 or NORM_INFINITY
89: Output Parameter:
90: . norms - an array as large as the TOTAL number of columns in the matrix
92: Level: intermediate
94: Notes: Each process has ALL the column norms after the call. Because of the way this is computed each process gets all the values,
95: if each process wants only some of the values it should extract the ones it wants from the array.
97: .seealso: MatGetColumns()
99: @*/
100: PetscErrorCode MatGetColumnNorms(Mat A,NormType type,PetscReal *norms)
101: {
106: if (A->ops->getcolumnnorms) {
107: (*A->ops->getcolumnnorms)(A,type,norms);
108: } else SETERRQ(((PetscObject)A)->comm,PETSC_ERR_SUP,"Not coded for this matrix type");
109: return(0);
110: }
111: