xref: /petsc/src/ts/characteristic/impls/da/slda.c (revision 63a3b9bc7a1f24f247904ccba9383635fe6abade)
130a76a96SBarry Smith #include <../src/ts/characteristic/impls/da/slda.h>       /*I  "petsccharacteristic.h"  I*/
21e25c274SJed Brown #include <petscdmda.h>
3665c2dedSJed Brown #include <petscviewer.h>
4af33a6ddSJed Brown 
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 
10af33a6ddSJed Brown   PetscFunctionBegin;
11af33a6ddSJed Brown   /* Pull out field names from DM */
129566063dSJacob Faibussowitsch   PetscCall(PetscObjectTypeCompare((PetscObject) viewer, PETSCVIEWERASCII, &iascii));
139566063dSJacob Faibussowitsch   PetscCall(PetscObjectTypeCompare((PetscObject) viewer, PETSCVIEWERSTRING, &isstring));
14af33a6ddSJed Brown   if (iascii) {
15*63a3b9bcSJacob Faibussowitsch     PetscCall(PetscViewerASCIIPrintf(viewer,"  DMDA: dummy=%" PetscInt_FMT "\n", da->dummy));
16af33a6ddSJed Brown   } else if (isstring) {
17*63a3b9bcSJacob Faibussowitsch     PetscCall(PetscViewerStringSPrintf(viewer,"dummy %" PetscInt_FMT, da->dummy));
18af33a6ddSJed Brown   }
19af33a6ddSJed Brown   PetscFunctionReturn(0);
20af33a6ddSJed Brown }
21af33a6ddSJed Brown 
22af33a6ddSJed Brown PetscErrorCode CharacteristicDestroy_DA(Characteristic c)
23af33a6ddSJed Brown {
24af33a6ddSJed Brown   Characteristic_DA *da = (Characteristic_DA*) c->data;
25af33a6ddSJed Brown 
26af33a6ddSJed Brown   PetscFunctionBegin;
279566063dSJacob Faibussowitsch   PetscCall(PetscFree(da));
28af33a6ddSJed Brown   PetscFunctionReturn(0);
29af33a6ddSJed Brown }
30af33a6ddSJed Brown 
31af33a6ddSJed Brown PetscErrorCode CharacteristicSetUp_DA(Characteristic c)
32af33a6ddSJed Brown {
33af33a6ddSJed Brown   PetscMPIInt    blockLen[2];
34af33a6ddSJed Brown   MPI_Aint       indices[2];
35af33a6ddSJed Brown   MPI_Datatype   oldtypes[2];
36af33a6ddSJed Brown   PetscInt       dim, numValues;
37af33a6ddSJed Brown 
389566063dSJacob Faibussowitsch   PetscCall(DMDAGetInfo(c->velocityDA, &dim, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL));
39af33a6ddSJed Brown   if (c->structured) c->numIds = dim;
40af33a6ddSJed Brown   else c->numIds = 3;
41*63a3b9bcSJacob Faibussowitsch   PetscCheck(c->numFieldComp <= MAX_COMPONENTS,PETSC_COMM_SELF,PETSC_ERR_ARG_OUTOFRANGE, "The maximum number of fields allowed is %d, you have %" PetscInt_FMT ". You can recompile after increasing MAX_COMPONENTS.", MAX_COMPONENTS, c->numFieldComp);
42af33a6ddSJed Brown   numValues = 4 + MAX_COMPONENTS;
43af33a6ddSJed Brown 
44af33a6ddSJed Brown   /* Create new MPI datatype for communication of characteristic point structs */
45af33a6ddSJed Brown   blockLen[0] = 1+c->numIds; indices[0] = 0;                              oldtypes[0] = MPIU_INT;
46af33a6ddSJed Brown   blockLen[1] = numValues;   indices[1] = (1+c->numIds)*sizeof(PetscInt); oldtypes[1] = MPIU_SCALAR;
479566063dSJacob Faibussowitsch   PetscCallMPI(MPI_Type_create_struct(2, blockLen, indices, oldtypes, &c->itemType));
489566063dSJacob Faibussowitsch   PetscCallMPI(MPI_Type_commit(&c->itemType));
49af33a6ddSJed Brown 
50af33a6ddSJed Brown   /* Initialize the local queue for char foot values */
519566063dSJacob Faibussowitsch   PetscCall(VecGetLocalSize(c->velocity, &c->queueMax));
529566063dSJacob Faibussowitsch   PetscCall(PetscMalloc1(c->queueMax, &c->queue));
53af33a6ddSJed Brown   c->queueSize = 0;
54af33a6ddSJed Brown 
55af33a6ddSJed Brown   /* Allocate communication structures */
56*63a3b9bcSJacob Faibussowitsch   PetscCheck(c->numNeighbors > 0,PETSC_COMM_SELF,PETSC_ERR_ARG_WRONGSTATE, "Invalid number of neighbors %" PetscInt_FMT ". Call CharactersiticSetNeighbors() before setup.", c->numNeighbors);
579566063dSJacob Faibussowitsch   PetscCall(PetscMalloc1(c->numNeighbors, &c->needCount));
589566063dSJacob Faibussowitsch   PetscCall(PetscMalloc1(c->numNeighbors, &c->localOffsets));
599566063dSJacob Faibussowitsch   PetscCall(PetscMalloc1(c->numNeighbors, &c->fillCount));
609566063dSJacob Faibussowitsch   PetscCall(PetscMalloc1(c->numNeighbors, &c->remoteOffsets));
619566063dSJacob Faibussowitsch   PetscCall(PetscMalloc1(c->numNeighbors-1, &c->request));
629566063dSJacob Faibussowitsch   PetscCall(PetscMalloc1(c->numNeighbors-1,  &c->status));
63af33a6ddSJed Brown   PetscFunctionReturn(0);
64af33a6ddSJed Brown }
65af33a6ddSJed Brown 
668cc058d9SJed Brown PETSC_EXTERN PetscErrorCode CharacteristicCreate_DA(Characteristic c)
67af33a6ddSJed Brown {
68af33a6ddSJed Brown   Characteristic_DA *da;
69af33a6ddSJed Brown 
70af33a6ddSJed Brown   PetscFunctionBegin;
719566063dSJacob Faibussowitsch   PetscCall(PetscNew(&da));
729566063dSJacob Faibussowitsch   PetscCall(PetscMemzero(da, sizeof(Characteristic_DA)));
739566063dSJacob Faibussowitsch   PetscCall(PetscLogObjectMemory((PetscObject)c, sizeof(Characteristic_DA)));
74af33a6ddSJed Brown   c->data = (void*) da;
75af33a6ddSJed Brown 
76af33a6ddSJed Brown   c->ops->setup   = CharacteristicSetUp_DA;
77af33a6ddSJed Brown   c->ops->destroy = CharacteristicDestroy_DA;
78af33a6ddSJed Brown   c->ops->view    = CharacteristicView_DA;
79af33a6ddSJed Brown 
80af33a6ddSJed Brown   da->dummy = 0;
81af33a6ddSJed Brown   PetscFunctionReturn(0);
82af33a6ddSJed Brown }
83af33a6ddSJed Brown 
84af33a6ddSJed Brown /* -----------------------------------------------------------------------------
85af33a6ddSJed Brown    Checks for periodicity of a DM and Maps points outside of a domain back onto the domain
86af33a6ddSJed Brown    using appropriate periodicity. At the moment assumes only a 2-D DMDA.
87af33a6ddSJed Brown    ----------------------------------------------------------------------------------------*/
88af33a6ddSJed Brown PetscErrorCode DMDAMapCoordsToPeriodicDomain(DM da, PetscScalar *x, PetscScalar *y)
89af33a6ddSJed Brown {
90bff4a2f0SMatthew G. Knepley   DMBoundaryType bx, by;
91af33a6ddSJed Brown   PetscInt       dim, gx, gy;
92af33a6ddSJed Brown 
93af33a6ddSJed Brown   PetscFunctionBegin;
949566063dSJacob Faibussowitsch   PetscCall(DMDAGetInfo(da, &dim, &gx, &gy, NULL, NULL, NULL, NULL, NULL, NULL, &bx, &by, NULL, NULL));
95af33a6ddSJed Brown 
96bff4a2f0SMatthew G. Knepley   if (bx == DM_BOUNDARY_PERIODIC) {
97bbd56ea5SKarl Rupp       while (*x >= (PetscScalar)gx) *x -= (PetscScalar)gx;
98bbd56ea5SKarl Rupp       while (*x < 0.0)              *x += (PetscScalar)gx;
99af33a6ddSJed Brown     }
100bff4a2f0SMatthew G. Knepley     if (by == DM_BOUNDARY_PERIODIC) {
101bbd56ea5SKarl Rupp       while (*y >= (PetscScalar)gy) *y -= (PetscScalar)gy;
102bbd56ea5SKarl Rupp       while (*y < 0.0)              *y += (PetscScalar)gy;
103af33a6ddSJed Brown     }
1043db9a53dSBarry Smith   PetscFunctionReturn(0);
105af33a6ddSJed Brown }
106