xref: /petsc/src/ts/characteristic/impls/da/slda.c (revision bbd56ea5790821d2a217d362e8e9710702952333)
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