1*af33a6ddSJed Brown #include <../src/ts/characteristic/impls/da/slda.h> /*I "characteristic.h" I*/ 2*af33a6ddSJed Brown 3*af33a6ddSJed Brown #undef __FUNCT__ 4*af33a6ddSJed Brown #define __FUNCT__ "CharacteristicView_DA" 5*af33a6ddSJed Brown PetscErrorCode CharacteristicView_DA(Characteristic c, PetscViewer viewer) 6*af33a6ddSJed Brown { 7*af33a6ddSJed Brown Characteristic_DA *da = (Characteristic_DA *) c->data; 8*af33a6ddSJed Brown PetscBool iascii, isstring; 9*af33a6ddSJed Brown PetscErrorCode ierr; 10*af33a6ddSJed Brown 11*af33a6ddSJed Brown PetscFunctionBegin; 12*af33a6ddSJed Brown /* Pull out field names from DM */ 13*af33a6ddSJed Brown ierr = PetscTypeCompare((PetscObject) viewer, PETSCVIEWERASCII, &iascii);CHKERRQ(ierr); 14*af33a6ddSJed Brown ierr = PetscTypeCompare((PetscObject) viewer, PETSCVIEWERSTRING, &isstring);CHKERRQ(ierr); 15*af33a6ddSJed Brown if (iascii) { 16*af33a6ddSJed Brown ierr = PetscViewerASCIIPrintf(viewer," DMDA: dummy=%D\n", da->dummy);CHKERRQ(ierr); 17*af33a6ddSJed Brown } else if (isstring) { 18*af33a6ddSJed Brown ierr = PetscViewerStringSPrintf(viewer,"dummy %D", da->dummy);CHKERRQ(ierr); 19*af33a6ddSJed Brown } else { 20*af33a6ddSJed Brown SETERRQ1(PETSC_COMM_SELF,PETSC_ERR_SUP, "Viewer type %s not supported for Characteristic DMDA", ((PetscObject) viewer)->type_name); 21*af33a6ddSJed Brown } 22*af33a6ddSJed Brown PetscFunctionReturn(0); 23*af33a6ddSJed Brown } 24*af33a6ddSJed Brown 25*af33a6ddSJed Brown #undef __FUNCT__ 26*af33a6ddSJed Brown #define __FUNCT__ "CharacteristicDestroy_DA" 27*af33a6ddSJed Brown PetscErrorCode CharacteristicDestroy_DA(Characteristic c) 28*af33a6ddSJed Brown { 29*af33a6ddSJed Brown Characteristic_DA *da = (Characteristic_DA*) c->data; 30*af33a6ddSJed Brown PetscErrorCode ierr; 31*af33a6ddSJed Brown 32*af33a6ddSJed Brown PetscFunctionBegin; 33*af33a6ddSJed Brown ierr = PetscFree(da);CHKERRQ(ierr); 34*af33a6ddSJed Brown PetscFunctionReturn(0); 35*af33a6ddSJed Brown } 36*af33a6ddSJed Brown 37*af33a6ddSJed Brown #undef __FUNCT__ 38*af33a6ddSJed Brown #define __FUNCT__ "CharacteristicSetUp_DA" 39*af33a6ddSJed Brown PetscErrorCode CharacteristicSetUp_DA(Characteristic c) 40*af33a6ddSJed Brown { 41*af33a6ddSJed Brown PetscMPIInt blockLen[2]; 42*af33a6ddSJed Brown MPI_Aint indices[2]; 43*af33a6ddSJed Brown MPI_Datatype oldtypes[2]; 44*af33a6ddSJed Brown PetscInt dim, numValues; 45*af33a6ddSJed Brown PetscErrorCode ierr; 46*af33a6ddSJed Brown 47*af33a6ddSJed Brown ierr = DMDAGetInfo(c->velocityDA, &dim, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,0,0);CHKERRQ(ierr); 48*af33a6ddSJed Brown if (c->structured) c->numIds = dim; 49*af33a6ddSJed Brown else c->numIds = 3; 50*af33a6ddSJed Brown if (c->numFieldComp > MAX_COMPONENTS) SETERRQ2(PETSC_COMM_SELF,PETSC_ERR_ARG_OUTOFRANGE, "The maximum number of fields allowed is %d, you have %d. You can recompile after increasing MAX_COMPONENTS.", MAX_COMPONENTS, c->numFieldComp); 51*af33a6ddSJed Brown numValues = 4 + MAX_COMPONENTS; 52*af33a6ddSJed Brown 53*af33a6ddSJed Brown /* Create new MPI datatype for communication of characteristic point structs */ 54*af33a6ddSJed Brown blockLen[0] = 1+c->numIds; indices[0] = 0; oldtypes[0] = MPIU_INT; 55*af33a6ddSJed Brown blockLen[1] = numValues; indices[1] = (1+c->numIds)*sizeof(PetscInt); oldtypes[1] = MPIU_SCALAR; 56*af33a6ddSJed Brown ierr = MPI_Type_struct(2, blockLen, indices, oldtypes, &c->itemType);CHKERRQ(ierr); 57*af33a6ddSJed Brown ierr = MPI_Type_commit(&c->itemType);CHKERRQ(ierr); 58*af33a6ddSJed Brown 59*af33a6ddSJed Brown /* Initialize the local queue for char foot values */ 60*af33a6ddSJed Brown ierr = VecGetLocalSize(c->velocity, &c->queueMax);CHKERRQ(ierr); 61*af33a6ddSJed Brown ierr = PetscMalloc(c->queueMax * sizeof(CharacteristicPointDA2D), &c->queue);CHKERRQ(ierr); 62*af33a6ddSJed Brown c->queueSize = 0; 63*af33a6ddSJed Brown 64*af33a6ddSJed Brown /* Allocate communication structures */ 65*af33a6ddSJed Brown if (c->numNeighbors <= 0) { 66*af33a6ddSJed Brown SETERRQ1(PETSC_COMM_SELF,PETSC_ERR_ARG_WRONGSTATE, "Invalid number of neighbors %d. Call CharactersiticSetNeighbors() before setup.", c->numNeighbors); 67*af33a6ddSJed Brown } 68*af33a6ddSJed Brown ierr = PetscMalloc(c->numNeighbors * sizeof(PetscInt), &c->needCount);CHKERRQ(ierr); 69*af33a6ddSJed Brown ierr = PetscMalloc(c->numNeighbors * sizeof(PetscInt), &c->localOffsets);CHKERRQ(ierr); 70*af33a6ddSJed Brown ierr = PetscMalloc(c->numNeighbors * sizeof(PetscInt), &c->fillCount);CHKERRQ(ierr); 71*af33a6ddSJed Brown ierr = PetscMalloc(c->numNeighbors * sizeof(PetscInt), &c->remoteOffsets);CHKERRQ(ierr); 72*af33a6ddSJed Brown ierr = PetscMalloc((c->numNeighbors-1) * sizeof(MPI_Request), &c->request);CHKERRQ(ierr); 73*af33a6ddSJed Brown ierr = PetscMalloc((c->numNeighbors-1) * sizeof(MPI_Status), &c->status);CHKERRQ(ierr); 74*af33a6ddSJed Brown PetscFunctionReturn(0); 75*af33a6ddSJed Brown } 76*af33a6ddSJed Brown 77*af33a6ddSJed Brown EXTERN_C_BEGIN 78*af33a6ddSJed Brown #undef __FUNCT__ 79*af33a6ddSJed Brown #define __FUNCT__ "CharacteristicCreate_DA" 80*af33a6ddSJed Brown PetscErrorCode CharacteristicCreate_DA(Characteristic c) 81*af33a6ddSJed Brown { 82*af33a6ddSJed Brown Characteristic_DA *da; 83*af33a6ddSJed Brown PetscErrorCode ierr; 84*af33a6ddSJed Brown 85*af33a6ddSJed Brown PetscFunctionBegin; 86*af33a6ddSJed Brown ierr = PetscNew(Characteristic_DA, &da);CHKERRQ(ierr); 87*af33a6ddSJed Brown ierr = PetscMemzero(da, sizeof(Characteristic_DA));CHKERRQ(ierr); 88*af33a6ddSJed Brown ierr = PetscLogObjectMemory(c, sizeof(Characteristic_DA));CHKERRQ(ierr); 89*af33a6ddSJed Brown c->data = (void *) da; 90*af33a6ddSJed Brown 91*af33a6ddSJed Brown c->ops->setup = CharacteristicSetUp_DA; 92*af33a6ddSJed Brown c->ops->destroy = CharacteristicDestroy_DA; 93*af33a6ddSJed Brown c->ops->view = CharacteristicView_DA; 94*af33a6ddSJed Brown 95*af33a6ddSJed Brown da->dummy = 0; 96*af33a6ddSJed Brown PetscFunctionReturn(0); 97*af33a6ddSJed Brown } 98*af33a6ddSJed Brown EXTERN_C_END 99*af33a6ddSJed Brown 100*af33a6ddSJed Brown #undef __FUNCT__ 101*af33a6ddSJed Brown #define __FUNCT__ "DMDAMapCoordsToPeriodicDomain" 102*af33a6ddSJed Brown /* ----------------------------------------------------------------------------- 103*af33a6ddSJed Brown Checks for periodicity of a DM and Maps points outside of a domain back onto the domain 104*af33a6ddSJed Brown using appropriate periodicity. At the moment assumes only a 2-D DMDA. 105*af33a6ddSJed Brown ----------------------------------------------------------------------------------------*/ 106*af33a6ddSJed Brown PetscErrorCode DMDAMapCoordsToPeriodicDomain(DM da, PetscScalar *x, PetscScalar *y) 107*af33a6ddSJed Brown { 108*af33a6ddSJed Brown DMDABoundaryType bx, by; 109*af33a6ddSJed Brown PetscInt dim, gx, gy; 110*af33a6ddSJed Brown PetscErrorCode ierr; 111*af33a6ddSJed Brown 112*af33a6ddSJed Brown PetscFunctionBegin; 113*af33a6ddSJed Brown ierr = DMDAGetInfo(da, &dim, &gx, &gy, 0, 0, 0, 0, 0, 0, &bx, &by, 0, 0); 114*af33a6ddSJed Brown 115*af33a6ddSJed Brown if (bx == DMDA_BOUNDARY_PERIODIC) { 116*af33a6ddSJed Brown while (*x >= ( PetscScalar ) gx ) { *x -= ( PetscScalar ) gx; } 117*af33a6ddSJed Brown while (*x < 0.0 ) { *x += ( PetscScalar ) gx; } 118*af33a6ddSJed Brown } 119*af33a6ddSJed Brown if (by == DMDA_BOUNDARY_PERIODIC) { 120*af33a6ddSJed Brown while (*y >= ( PetscScalar ) gy ) { *y -= ( PetscScalar ) gy; } 121*af33a6ddSJed Brown while (*y < 0.0 ) { *y += ( PetscScalar ) gy; } 122*af33a6ddSJed Brown } 123*af33a6ddSJed Brown PetscFunctionReturn(ierr); 124*af33a6ddSJed Brown } 125