[petsc-dev] DMDABoundaryType
Satish Balay
balay at mcs.anl.gov
Fri Mar 11 19:14:50 CST 2011
I just pushed this patch along with the fix you mentioned.. [and
couple of other fixes]
Satish
On Fri, 11 Mar 2011, Lisandro Dalcin wrote:
> On 11 March 2011 20:35, Ethan Coon <ecoon at lanl.gov> wrote:
> > Ok, here's a patch that makes the below change, and changes the APIs of
> > DMDACreate*D(), DMDAGetInfo(), and DMDASetBoundaryType().
> >
>
> You missed a couple of fixes (pasted at the end). After applying your
> patch, the updated (also working with petsc-3.1) petsc4py testsuite
> pass fine.
>
> > Nearly every tutorial/test example is touched, and everyone's DA code is
> > broken. Up to you if you want it :)
> >
> > This should deal with Lisandro's c++ issue with int/enum bitwise or (or
> > we could change the enum to a typedef if that works or int otherwise, or
> > some other hack for c++?).
> >
>
> I vote for pushing your patch plus my trivial fixes... I think Barry
> is still OK. Satish, do you what me to push? I'll use hg commit --user
> "Ethan Coon <ecoon at lanl.gov>"
>
> $ hg diff src/dm/impls/da/utils/binaryMatlab.c
> src/dm/impls/da/ftn-custom/zdaviewf.c
> diff -r e7b8783e37a0 src/dm/impls/da/ftn-custom/zdaviewf.c
> --- a/src/dm/impls/da/ftn-custom/zdaviewf.c Fri Mar 11 15:21:12 2011 -0600
> +++ b/src/dm/impls/da/ftn-custom/zdaviewf.c Fri Mar 11 21:57:20 2011 -0300
> @@ -10,7 +10,7 @@
>
> EXTERN_C_BEGIN
> void PETSC_STDCALL dmdagetinfo_(DM *da,PetscInt *dim,PetscInt
> *M,PetscInt *N,PetscInt *P,PetscInt *m,PetscInt *n,PetscInt
> *p,PetscInt *w,PetscInt *s,
> - DMDABoundaryType *wrap,DMDAStencilType
> *st,PetscErrorCode *ierr)
> + DMDABoundaryType *bx,DMDABoundaryType
> *by,DMDABoundaryType *bz,DMDAStencilType *st,PetscErrorCode *ierr)
> {
> CHKFORTRANNULLINTEGER(dim);
> CHKFORTRANNULLINTEGER(M);
> @@ -21,8 +21,10 @@
> CHKFORTRANNULLINTEGER(p);
> CHKFORTRANNULLINTEGER(w);
> CHKFORTRANNULLINTEGER(s);
> - CHKFORTRANNULLINTEGER(wrap);
> + CHKFORTRANNULLINTEGER(bx);
> + CHKFORTRANNULLINTEGER(by);
> + CHKFORTRANNULLINTEGER(bz);
> CHKFORTRANNULLINTEGER(st);
> - *ierr = DMDAGetInfo(*da,dim,M,N,P,m,n,p,w,s,wrap,st);
> + *ierr = DMDAGetInfo(*da,dim,M,N,P,m,n,p,w,s,bx,by,bz,st);
> }
> EXTERN_C_END
> diff -r e7b8783e37a0 src/dm/impls/da/utils/binaryMatlab.c
> --- a/src/dm/impls/da/utils/binaryMatlab.c Fri Mar 11 15:21:12 2011 -0600
> +++ b/src/dm/impls/da/utils/binaryMatlab.c Fri Mar 11 21:57:20 2011 -0300
> @@ -175,7 +175,7 @@
> PetscFunctionBegin;
> ierr = PetscObjectGetComm((PetscObject)viewer,&comm);CHKERRQ(ierr);
> ierr = PetscViewerBinaryGetInfoPointer(viewer,&info);CHKERRQ(ierr);
> - ierr = DMDAGetInfo(da,&dim,&ni,&nj,&nk,&pi,&pj,&pk,&dof,PETSC_NULL,PETSC_NULL,PETSC_NULL);CHKERRQ(ierr);
> + ierr = DMDAGetInfo(da,&dim,&ni,&nj,&nk,&pi,&pj,&pk,&dof,PETSC_NULL,PETSC_NULL,PETSC_NULL,PETSC_NULL,PETSC_NULL);CHKERRQ(ierr);
> ierr = VecView(vec,viewer);CHKERRQ(ierr);
> ierr = PetscFPrintf(comm,info,"%%--- begin code written by
> PetscViewerBinaryMatlabOutputVecDA ---%\n");CHKERRQ(ierr);
> ierr = PetscFPrintf(comm,info,"%%$$ tmp = PetscBinaryRead(fd);
> \n");CHKERRQ(ierr);
>
>
>
More information about the petsc-dev
mailing list