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