"(Sadly) MATSBAIJ is extremely broken, in particular, it cannot be used to 
retrieve rectangular blocks in MatCreateSubMatrices, thus you cannot get the 
A01 and A10 blocks in PCFIELDSPLIT.
I have a branch that fixes this, but I haven’t rebased in a while (and I’m AFK 
right now), would you want me to rebase and give it a go, or must you stick to 
a release tarball?"

Ok, would be great if you could look at this! I don't need to stick to any 
particular branch.

Do you think MATNEST could be an alternative here? My matrix is
[A00 A01;
 A01^t A11]
so perhaps with MATNEST I can make use of the block-symmetry at least, and then 
use MATSBAIJ for 
A00 and A11 if it's possible to combine matrix types which the manual seems to 
imply. 

Kind regards
Carl-Johan


> On 26 Aug 2023, at 10:09 PM, Carl-Johan Thore <carljohanth...@gmail.com> 
> wrote:
> 
> Hi,
> 
> I'm trying to use PCFIELDSPLIT with MATSBAIJ in PETSc 3.19.4. 
> According to the manual "[t]he fieldsplit preconditioner cannot 
> currently be used with the MATBAIJ or MATSBAIJ data formats if the 
> blocksize is larger than 1". Since my blocksize is exactly 1 it would seem 
> that I can use PCFIELDSPLIT. But this fails with "PETSC ERROR: For symmetric 
> format, iscol must equal isrow"
> from MatCreateSubMatrix_MPISBAIJ. Tracing backwards one ends up in 
> fieldsplit.c at
> 
> /* extract the A01 and A10 matrices */ ilink = jac->head; 
> PetscCall(ISComplement(ilink->is_col, rstart, rend, &ccis)); if 
> (jac->offdiag_use_amat) { PetscCall(MatCreateSubMatrix(pc->mat, 
> ilink->is, ccis, MAT_INITIAL_MATRIX, &jac->B)); } else {
>         PetscCall(MatCreateSubMatrix(pc->pmat, ilink->is, ccis, 
> MAT_INITIAL_MATRIX, &jac->B)); }
> 
> This, since my A01 and A10 are not square, seems to explain why iscol is not 
> equal to isrow.
> From this I gather that it is in general NOT possible to use 
> PCFIELDSPLIT with MATSBAIJ even with block size 1?
> 
> Kind regards,
> Carl-Johan

Reply via email to