[petsc-users] Compute the sum of the absolute values of the off-block diagonal entries of each row
Smith, Barry F.
bsmith at mcs.anl.gov
Mon Mar 4 17:10:46 CST 2019
How about something like,
MatMPIAIJGetSeqAIJ(A,NULL,&Ao,NULL);
> MatGetOwnershipRange(A, &rS, &rE);
> for (r = 0; r < rE-rS; ++r) {
> sum = 0.0;
> MatGetRow(Ao, r, &ncols, NULL, &vals);
> for (c = 0; c < ncols; ++c) sum += PetscAbsScalar(vals[c]);
// do what you need with sum
> }
Barry
> On Mar 4, 2019, at 10:38 AM, Matthew Knepley via petsc-users <petsc-users at mcs.anl.gov> wrote:
>
> On Mon, Mar 4, 2019 at 11:28 AM Cyrill Vonplanta via petsc-users <petsc-users at mcs.anl.gov> wrote:
> Dear Petsc Users,
>
> I am trying to implement a variant of the $l^1$-Gauss-Seidel smoother from https://doi.org/10.1137/100798806 (eq. 6.1 and below). One of the main issues is that I need to compute the sum $\sum_j |a_{i_j}|$ of the matrix entries that are not part of the local diagonal block. I was looking for something like MatGetRowSumAbs but it looks like it hasn't been made yet.
>
> I guess i have to come up with something myself, but would you know of some workaround for this without going too deep into PETCs?
>
> MatGetOwnershipRange(A, &rS, &rE);
> for (r = rS; r < rE; ++r) {
> sum = 0.0;
> MatGetRow(A, r, &ncols, &cols, &vals);
> for (c = 0; c < ncols; ++c) if ((cols[c] < rS) || (cols[c] >= rE)) sum += PetscAbsScalar(vals[c]);
> }
>
> Thanks,
>
> Matt
>
> Best Cyrill
> --
> What most experimenters take for granted before they begin their experiments is infinitely more interesting than any results to which their experiments lead.
> -- Norbert Wiener
>
> https://www.cse.buffalo.edu/~knepley/
More information about the petsc-users
mailing list