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