[petsc-users] return -1 instead of raising an error in ao.app2petsc

Barry Smith bsmith at mcs.anl.gov
Wed Aug 8 15:26:26 CDT 2012


  Hmm,

PetscErrorCode AOApplicationToPetsc_Basic(AO ao,PetscInt n,PetscInt *ia)

   has

    if (ia[i] >= 0 && ia[i] < N) {
      ia[i] = aobasic->petsc[ia[i]];
    } else {
      ia[i] = -1;
    }

PetscErrorCode AOApplicationToPetsc_Mapping(AO ao, PetscInt n, PetscInt *ia)

has 

    if (low > high) SETERRQ1(PETSC_COMM_SELF,PETSC_ERR_ARG_OUTOFRANGE, "Invalid input index %D", idex);

PetscErrorCode AOApplicationToPetsc_MemoryScalable(AO ao,PetscInt n,PetscInt *ia)

has 

      if (ia[i] >= owners[rank] && ia[i] < owners[rank+1] ) {
        ia[i] = maploc[ia[i]-owners[rank]];
      } else {
        ia[i] = -1 ; /* ia[i] is not in the range of 0 and N-1, maps it to -1 */
      }

So it seems the intention is to return -1 for out of range not an error.

Can the PETSc developer who wrote all this stuff comment?   Likely our bug! Also we should fix the manual page for AOApplicationToPetsc() to clearly indicate what happens for out of range values

   Barry


On Aug 8, 2012, at 3:10 PM, Xin Zhao <sean.null at gmail.com> wrote:

> Dear all,
> 
> Assume that I want to convert an indices in application order into petsc order.
> But I don't know the indices in application is in range.
> 
> Say 
> I call
> ao = PETSc.AO().createMapping([4,2,3])
> 
> then
> ao.app2petsc([2,5,3])
> will raise an error.
> 
> is there any way to make return value to [1,-1,2] instead of raising an error?
> 
> 
> Or there is any way I can handle this error to make it work?
> 
> Best,
> Xin



More information about the petsc-users mailing list