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
CharacteristicView_DA(Characteristic c,PetscViewer viewer)566976f2fSJacob Faibussowitsch static PetscErrorCode CharacteristicView_DA(Characteristic c, PetscViewer viewer)
6d71ae5a4SJacob Faibussowitsch {
7af33a6ddSJed Brown Characteristic_DA *da = (Characteristic_DA *)c->data;
89f196a02SMartin Diehl PetscBool isascii, isstring;
9af33a6ddSJed Brown
10af33a6ddSJed Brown PetscFunctionBegin;
11af33a6ddSJed Brown /* Pull out field names from DM */
129f196a02SMartin Diehl PetscCall(PetscObjectTypeCompare((PetscObject)viewer, PETSCVIEWERASCII, &isascii));
139566063dSJacob Faibussowitsch PetscCall(PetscObjectTypeCompare((PetscObject)viewer, PETSCVIEWERSTRING, &isstring));
149f196a02SMartin Diehl if (isascii) {
1563a3b9bcSJacob Faibussowitsch PetscCall(PetscViewerASCIIPrintf(viewer, " DMDA: dummy=%" PetscInt_FMT "\n", da->dummy));
16af33a6ddSJed Brown } else if (isstring) {
1763a3b9bcSJacob Faibussowitsch PetscCall(PetscViewerStringSPrintf(viewer, "dummy %" PetscInt_FMT, da->dummy));
18af33a6ddSJed Brown }
193ba16761SJacob Faibussowitsch PetscFunctionReturn(PETSC_SUCCESS);
20af33a6ddSJed Brown }
21af33a6ddSJed Brown
CharacteristicDestroy_DA(Characteristic c)2266976f2fSJacob Faibussowitsch static PetscErrorCode CharacteristicDestroy_DA(Characteristic c)
23d71ae5a4SJacob Faibussowitsch {
24af33a6ddSJed Brown Characteristic_DA *da = (Characteristic_DA *)c->data;
25af33a6ddSJed Brown
26af33a6ddSJed Brown PetscFunctionBegin;
279566063dSJacob Faibussowitsch PetscCall(PetscFree(da));
283ba16761SJacob Faibussowitsch PetscFunctionReturn(PETSC_SUCCESS);
29af33a6ddSJed Brown }
30af33a6ddSJed Brown
CharacteristicSetUp_DA(Characteristic c)3166976f2fSJacob Faibussowitsch static PetscErrorCode CharacteristicSetUp_DA(Characteristic c)
32d71ae5a4SJacob Faibussowitsch {
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));
39835f2295SStefano Zampini if (c->structured) PetscCall(PetscMPIIntCast(dim, &c->numIds));
40af33a6ddSJed Brown else c->numIds = 3;
4163a3b9bcSJacob 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 */
459371c9d4SSatish Balay blockLen[0] = 1 + c->numIds;
469371c9d4SSatish Balay indices[0] = 0;
479371c9d4SSatish Balay oldtypes[0] = MPIU_INT;
486497c311SBarry Smith PetscCall(PetscMPIIntCast(numValues, &blockLen[1]));
499371c9d4SSatish Balay indices[1] = (1 + c->numIds) * sizeof(PetscInt);
509371c9d4SSatish Balay oldtypes[1] = MPIU_SCALAR;
519566063dSJacob Faibussowitsch PetscCallMPI(MPI_Type_create_struct(2, blockLen, indices, oldtypes, &c->itemType));
529566063dSJacob Faibussowitsch PetscCallMPI(MPI_Type_commit(&c->itemType));
53af33a6ddSJed Brown
54af33a6ddSJed Brown /* Initialize the local queue for char foot values */
559566063dSJacob Faibussowitsch PetscCall(VecGetLocalSize(c->velocity, &c->queueMax));
569566063dSJacob Faibussowitsch PetscCall(PetscMalloc1(c->queueMax, &c->queue));
57af33a6ddSJed Brown c->queueSize = 0;
58af33a6ddSJed Brown
59af33a6ddSJed Brown /* Allocate communication structures */
606497c311SBarry Smith PetscCheck(c->numNeighbors > 0, PETSC_COMM_SELF, PETSC_ERR_ARG_WRONGSTATE, "Invalid number of neighbors %d. Call CharactersiticSetNeighbors() before setup.", c->numNeighbors);
619566063dSJacob Faibussowitsch PetscCall(PetscMalloc1(c->numNeighbors, &c->needCount));
629566063dSJacob Faibussowitsch PetscCall(PetscMalloc1(c->numNeighbors, &c->localOffsets));
639566063dSJacob Faibussowitsch PetscCall(PetscMalloc1(c->numNeighbors, &c->fillCount));
649566063dSJacob Faibussowitsch PetscCall(PetscMalloc1(c->numNeighbors, &c->remoteOffsets));
659566063dSJacob Faibussowitsch PetscCall(PetscMalloc1(c->numNeighbors - 1, &c->request));
669566063dSJacob Faibussowitsch PetscCall(PetscMalloc1(c->numNeighbors - 1, &c->status));
673ba16761SJacob Faibussowitsch PetscFunctionReturn(PETSC_SUCCESS);
68af33a6ddSJed Brown }
69af33a6ddSJed Brown
CharacteristicCreate_DA(Characteristic c)70d71ae5a4SJacob Faibussowitsch PETSC_EXTERN PetscErrorCode CharacteristicCreate_DA(Characteristic c)
71d71ae5a4SJacob Faibussowitsch {
72af33a6ddSJed Brown Characteristic_DA *da;
73af33a6ddSJed Brown
74af33a6ddSJed Brown PetscFunctionBegin;
759566063dSJacob Faibussowitsch PetscCall(PetscNew(&da));
769566063dSJacob Faibussowitsch PetscCall(PetscMemzero(da, sizeof(Characteristic_DA)));
77af33a6ddSJed Brown c->data = (void *)da;
78af33a6ddSJed Brown
79af33a6ddSJed Brown c->ops->setup = CharacteristicSetUp_DA;
80af33a6ddSJed Brown c->ops->destroy = CharacteristicDestroy_DA;
81af33a6ddSJed Brown c->ops->view = CharacteristicView_DA;
82af33a6ddSJed Brown
83af33a6ddSJed Brown da->dummy = 0;
843ba16761SJacob Faibussowitsch PetscFunctionReturn(PETSC_SUCCESS);
85af33a6ddSJed Brown }
86af33a6ddSJed Brown
87*21789920SBarry Smith /*
88af33a6ddSJed Brown Checks for periodicity of a DM and Maps points outside of a domain back onto the domain
89af33a6ddSJed Brown using appropriate periodicity. At the moment assumes only a 2-D DMDA.
90*21789920SBarry Smith */
DMDAMapCoordsToPeriodicDomain(DM da,PetscScalar * x,PetscScalar * y)91d71ae5a4SJacob Faibussowitsch PetscErrorCode DMDAMapCoordsToPeriodicDomain(DM da, PetscScalar *x, PetscScalar *y)
92d71ae5a4SJacob Faibussowitsch {
93bff4a2f0SMatthew G. Knepley DMBoundaryType bx, by;
94af33a6ddSJed Brown PetscInt dim, gx, gy;
95af33a6ddSJed Brown
96af33a6ddSJed Brown PetscFunctionBegin;
979566063dSJacob Faibussowitsch PetscCall(DMDAGetInfo(da, &dim, &gx, &gy, NULL, NULL, NULL, NULL, NULL, NULL, &bx, &by, NULL, NULL));
98af33a6ddSJed Brown
99bff4a2f0SMatthew G. Knepley if (bx == DM_BOUNDARY_PERIODIC) {
100bbd56ea5SKarl Rupp while (*x >= (PetscScalar)gx) *x -= (PetscScalar)gx;
101bbd56ea5SKarl Rupp while (*x < 0.0) *x += (PetscScalar)gx;
102af33a6ddSJed Brown }
103bff4a2f0SMatthew G. Knepley if (by == DM_BOUNDARY_PERIODIC) {
104bbd56ea5SKarl Rupp while (*y >= (PetscScalar)gy) *y -= (PetscScalar)gy;
105bbd56ea5SKarl Rupp while (*y < 0.0) *y += (PetscScalar)gy;
106af33a6ddSJed Brown }
1073ba16761SJacob Faibussowitsch PetscFunctionReturn(PETSC_SUCCESS);
108af33a6ddSJed Brown }
109