20 Vec in_vec_local = NULL, out_vec_global = NULL;
21 DM dm_in = NULL, dm_out = NULL;
24 PetscFunctionBeginUser;
25 LOG_ALLOW(
GLOBAL,
LOG_INFO,
"-> KERNEL: Running ComputeNodalAverage on '%s' -> '%s'.\n", in_field_name, out_field_name);
28 if (strcasecmp(in_field_name,
"P") == 0) { in_vec_local = user->
lP; dm_in = user->
da; dof = 1; }
29 else if (strcasecmp(in_field_name,
"Ucat") == 0) { in_vec_local = user->
lUcat; dm_in = user->
fda; dof = 3; }
31 else SETERRQ(PETSC_COMM_WORLD, PETSC_ERR_ARG_WRONG,
"Unknown input field name for nodal averaging: %s", in_field_name);
33 if (strcasecmp(out_field_name,
"P_nodal") == 0) { out_vec_global = user->
P_nodal; dm_out = user->
da; }
34 else if (strcasecmp(out_field_name,
"Ucat_nodal") == 0) { out_vec_global = user->
Ucat_nodal; dm_out = user->
fda; }
36 else SETERRQ(PETSC_COMM_WORLD, PETSC_ERR_ARG_WRONG,
"Unknown output field name for nodal averaging: %s", out_field_name);
43 ierr = DMDAGetLocalInfo(dm_out, &info); CHKERRQ(ierr);
46 const PetscReal ***l_in_arr;
47 PetscReal ***g_out_arr;
48 ierr = DMDAVecGetArrayRead(dm_in,in_vec_local, (
void*)&l_in_arr); CHKERRQ(ierr);
49 ierr = DMDAVecGetArray(dm_out,out_vec_global, (
void*)&g_out_arr); CHKERRQ(ierr);
53 for (PetscInt k = info.zs; k < info.zs + info.zm - 1; k++) {
54 for (PetscInt j = info.ys; j < info.ys + info.ym - 1; j++) {
55 for (PetscInt i = info.xs; i < info.xs + info.xm - 1; i++) {
56 g_out_arr[k][j][i] = 0.125 * (l_in_arr[k][j][i] + l_in_arr[k][j][i+1] +
57 l_in_arr[k][j+1][i] + l_in_arr[k][j+1][i+1] +
58 l_in_arr[k+1][j][i] + l_in_arr[k+1][j][i+1] +
59 l_in_arr[k+1][j+1][i] + l_in_arr[k+1][j+1][i+1]);
63 ierr = DMDAVecRestoreArrayRead(dm_in,in_vec_local, (
void*)&l_in_arr); CHKERRQ(ierr);
64 ierr = DMDAVecRestoreArray(dm_out,out_vec_global, (
void*)&g_out_arr); CHKERRQ(ierr);
66 }
else if (dof == 3) {
69 ierr = DMDAVecGetArrayRead(dm_in,in_vec_local, (
void*)&l_in_arr); CHKERRQ(ierr);
70 ierr = DMDAVecGetArray(dm_out,out_vec_global, (
void*)&g_out_arr); CHKERRQ(ierr);
72 for (PetscInt k = info.zs; k < info.zs + info.zm - 1; k++) {
73 for (PetscInt j = info.ys; j < info.ys + info.ym - 1; j++) {
74 for (PetscInt i = info.xs; i < info.xs + info.xm - 1; i++) {
75 g_out_arr[k][j][i].
x = 0.125 * (l_in_arr[k][j][i].
x + l_in_arr[k][j][i+1].
x +
76 l_in_arr[k][j+1][i].
x + l_in_arr[k][j+1][i+1].
x +
77 l_in_arr[k+1][j][i].
x + l_in_arr[k+1][j][i+1].
x +
78 l_in_arr[k+1][j+1][i].
x + l_in_arr[k+1][j+1][i+1].
x);
80 g_out_arr[k][j][i].
y = 0.125 * (l_in_arr[k][j][i].
y + l_in_arr[k][j][i+1].
y +
81 l_in_arr[k][j+1][i].
y + l_in_arr[k][j+1][i+1].
y +
82 l_in_arr[k+1][j][i].
y + l_in_arr[k+1][j][i+1].
y +
83 l_in_arr[k+1][j+1][i].
y + l_in_arr[k+1][j+1][i+1].
y);
85 g_out_arr[k][j][i].
z = 0.125 * (l_in_arr[k][j][i].
z + l_in_arr[k][j][i+1].
z +
86 l_in_arr[k][j+1][i].
z + l_in_arr[k][j+1][i+1].
z +
87 l_in_arr[k+1][j][i].
z + l_in_arr[k+1][j][i+1].
z +
88 l_in_arr[k+1][j+1][i].
z + l_in_arr[k+1][j+1][i+1].
z);
92 ierr = DMDAVecRestoreArrayRead(dm_in,in_vec_local, (
void*)&l_in_arr); CHKERRQ(ierr);
93 ierr = DMDAVecRestoreArray(dm_out,out_vec_global, (
void*)&g_out_arr); CHKERRQ(ierr);
95 PetscFunctionReturn(0);
112 const Cmpnts ***lucat, ***lcsi, ***leta, ***lzet;
113 const PetscReal***laj, ***lnvert;
116 PetscFunctionBeginUser;
128 ierr = DMDAGetLocalInfo(user->
da, &info); CHKERRQ(ierr);
130 ierr = DMDAVecGetArrayRead(user->
fda, user->
lUcat, (
void*)&lucat); CHKERRQ(ierr);
131 ierr = DMDAVecGetArrayRead(user->
fda, user->
lCsi, (
void*)&lcsi); CHKERRQ(ierr);
132 ierr = DMDAVecGetArrayRead(user->
fda, user->
lEta, (
void*)&leta); CHKERRQ(ierr);
133 ierr = DMDAVecGetArrayRead(user->
fda, user->
lZet, (
void*)&lzet); CHKERRQ(ierr);
134 ierr = DMDAVecGetArrayRead(user->
da, user->
lAj, (
void*)&laj); CHKERRQ(ierr);
135 ierr = DMDAVecGetArrayRead(user->
da, user->
lNvert, (
void*)&lnvert); CHKERRQ(ierr);
136 ierr = DMDAVecGetArray(user->
da, user->
Qcrit, (
void*)&gq); CHKERRQ(ierr);
139 PetscInt i_start = (info.xs == 0) ? 1 : info.xs;
140 PetscInt i_end = (info.xs + info.xm == info.mx) ? info.mx - 1 : info.xs + info.xm;
141 PetscInt j_start = (info.ys == 0) ? 1 : info.ys;
142 PetscInt j_end = (info.ys + info.ym == info.my) ? info.my - 1 : info.ys + info.ym;
143 PetscInt k_start = (info.zs == 0) ? 1 : info.zs;
144 PetscInt k_end = (info.zs + info.zm == info.mz) ? info.mz - 1 : info.zs + info.zm;
147 for (PetscInt k = k_start; k < k_end; k++) {
148 for (PetscInt j = j_start; j < j_end; j++) {
149 for (PetscInt i = i_start; i < i_end; i++) {
152 PetscReal uc = 0.5 * (lucat[k][j][i+1].
x - lucat[k][j][i-1].
x);
153 PetscReal vc = 0.5 * (lucat[k][j][i+1].
y - lucat[k][j][i-1].
y);
154 PetscReal wc = 0.5 * (lucat[k][j][i+1].
z - lucat[k][j][i-1].
z);
156 PetscReal ue = 0.5 * (lucat[k][j+1][i].
x - lucat[k][j-1][i].
x);
157 PetscReal ve = 0.5 * (lucat[k][j+1][i].
y - lucat[k][j-1][i].
y);
158 PetscReal we = 0.5 * (lucat[k][j+1][i].
z - lucat[k][j-1][i].
z);
160 PetscReal uz = 0.5 * (lucat[k+1][j][i].
x - lucat[k-1][j][i].
x);
161 PetscReal vz = 0.5 * (lucat[k+1][j][i].
y - lucat[k-1][j][i].
y);
162 PetscReal wz = 0.5 * (lucat[k+1][j][i].
z - lucat[k-1][j][i].
z);
165 PetscReal csi1 = 0.5 * (lcsi[k][j][i].
x + lcsi[k][j][i-1].
x) * laj[k][j][i];
166 PetscReal csi2 = 0.5 * (lcsi[k][j][i].
y + lcsi[k][j][i-1].
y) * laj[k][j][i];
167 PetscReal csi3 = 0.5 * (lcsi[k][j][i].
z + lcsi[k][j][i-1].
z) * laj[k][j][i];
169 PetscReal eta1 = 0.5 * (leta[k][j][i].
x + leta[k][j-1][i].
x) * laj[k][j][i];
170 PetscReal eta2 = 0.5 * (leta[k][j][i].
y + leta[k][j-1][i].
y) * laj[k][j][i];
171 PetscReal eta3 = 0.5 * (leta[k][j][i].
z + leta[k][j-1][i].
z) * laj[k][j][i];
173 PetscReal zet1 = 0.5 * (lzet[k][j][i].
x + lzet[k-1][j][i].
x) * laj[k][j][i];
174 PetscReal zet2 = 0.5 * (lzet[k][j][i].
y + lzet[k-1][j][i].
y) * laj[k][j][i];
175 PetscReal zet3 = 0.5 * (lzet[k][j][i].
z + lzet[k-1][j][i].
z) * laj[k][j][i];
178 PetscReal d11 = uc * csi1 + ue * eta1 + uz * zet1;
179 PetscReal d12 = uc * csi2 + ue * eta2 + uz * zet2;
180 PetscReal d13 = uc * csi3 + ue * eta3 + uz * zet3;
182 PetscReal d21 = vc * csi1 + ve * eta1 + vz * zet1;
183 PetscReal d22 = vc * csi2 + ve * eta2 + vz * zet2;
184 PetscReal d23 = vc * csi3 + ve * eta3 + vz * zet3;
186 PetscReal d31 = wc * csi1 + we * eta1 + wz * zet1;
187 PetscReal d32 = wc * csi2 + we * eta2 + wz * zet2;
188 PetscReal d33 = wc * csi3 + we * eta3 + wz * zet3;
192 PetscReal s12 = 0.5 * (d12 + d21);
193 PetscReal s13 = 0.5 * (d13 + d31);
195 PetscReal s23 = 0.5 * (d23 + d32);
199 PetscReal w12 = 0.5 * (d12 - d21);
200 PetscReal w13 = 0.5 * (d13 - d31);
201 PetscReal w23 = 0.5 * (d23 - d32);
204 PetscReal s_norm_sq = s11*s11 + s22*s22 + s33*s33 + 2.0*(s12*s12 + s13*s13 + s23*s23);
205 PetscReal w_norm_sq = 2.0 * (w12*w12 + w13*w13 + w23*w23);
207 gq[k][j][i] = 0.5 * (w_norm_sq - s_norm_sq);
209 if (lnvert[k][j][i] > 0.1) {
217 ierr = DMDAVecRestoreArrayRead(user->
fda, user->
lUcat, (
void*)&lucat); CHKERRQ(ierr);
218 ierr = DMDAVecRestoreArrayRead(user->
fda, user->
lCsi, (
void*)&lcsi); CHKERRQ(ierr);
219 ierr = DMDAVecRestoreArrayRead(user->
fda, user->
lEta, (
void*)&leta); CHKERRQ(ierr);
220 ierr = DMDAVecRestoreArrayRead(user->
fda, user->
lZet, (
void*)&lzet); CHKERRQ(ierr);
221 ierr = DMDAVecRestoreArrayRead(user->
da, user->
lAj, (
void*)&laj); CHKERRQ(ierr);
222 ierr = DMDAVecRestoreArrayRead(user->
da, user->
lNvert, (
void*)&lnvert); CHKERRQ(ierr);
223 ierr = DMDAVecRestoreArray(user->
da, user->
Qcrit, (
void*)&gq); CHKERRQ(ierr);
225 PetscFunctionReturn(0);
245 PetscInt ip=1, jp=1, kp=1;
246 PetscReal p_ref = 0.0;
247 PetscInt ref_point_global_idx[1];
248 PetscScalar ref_value_local[1];
250 VecScatter scatter_ctx;
253 PetscFunctionBeginUser;
257 if (strcasecmp(relative_field_name,
"P") == 0) {
260 SETERRQ(PETSC_COMM_SELF, 1,
"NormalizeRelativeField only supports the primary 'P' field , not '%s' currently.", relative_field_name);
264 ierr = MPI_Comm_rank(PETSC_COMM_WORLD, &rank); CHKERRQ(ierr);
265 ierr = PetscOptionsGetInt(NULL, NULL,
"-ip", &ip, NULL); CHKERRQ(ierr);
266 ierr = PetscOptionsGetInt(NULL, NULL,
"-jp", &jp, NULL); CHKERRQ(ierr);
267 ierr = PetscOptionsGetInt(NULL, NULL,
"-kp", &kp, NULL); CHKERRQ(ierr);
270 ref_point_global_idx[0] = kp * (user->
IM * user->
JM) + jp * user->
IM + ip;
274 ierr = ISCreateGeneral(PETSC_COMM_WORLD, 1, ref_point_global_idx, PETSC_COPY_VALUES, &is_from); CHKERRQ(ierr);
277 ierr = VecCreateSeq(PETSC_COMM_SELF, 1, &ref_vec_seq); CHKERRQ(ierr);
280 PetscInt dest_idx[1] = {0};
281 ierr = ISCreateGeneral(PETSC_COMM_SELF, 1, dest_idx, PETSC_COPY_VALUES, &is_to); CHKERRQ(ierr);
284 ierr = VecScatterCreate(P_vec, is_from, ref_vec_seq, is_to, &scatter_ctx); CHKERRQ(ierr);
285 ierr = VecScatterBegin(scatter_ctx, P_vec, ref_vec_seq, INSERT_VALUES, SCATTER_FORWARD); CHKERRQ(ierr);
286 ierr = VecScatterEnd(scatter_ctx, P_vec, ref_vec_seq, INSERT_VALUES, SCATTER_FORWARD); CHKERRQ(ierr);
290 ierr = VecGetValues(ref_vec_seq, 1, dest_idx, ref_value_local); CHKERRQ(ierr);
291 p_ref = ref_value_local[0];
292 LOG_ALLOW(
LOCAL,
LOG_DEBUG,
"%s reference point (%" PetscInt_FMT
", %" PetscInt_FMT
", %" PetscInt_FMT
") has value %g.\n", relative_field_name, jp, kp, ip, p_ref);
296 ierr = MPI_Bcast(&p_ref, 1, MPIU_REAL, 0, PETSC_COMM_WORLD); CHKERRQ(ierr);
299 ierr = VecShift(P_vec, -p_ref); CHKERRQ(ierr);
303 ierr = ISDestroy(&is_from); CHKERRQ(ierr);
304 ierr = ISDestroy(&is_to); CHKERRQ(ierr);
305 ierr = VecScatterDestroy(&scatter_ctx); CHKERRQ(ierr);
306 ierr = VecDestroy(&ref_vec_seq); CHKERRQ(ierr);
308 PetscFunctionReturn(0);
331 const PetscScalar (*vel_arr)[3];
332 PetscScalar *ske_arr;
334 PetscFunctionBeginUser;
335 LOG_ALLOW(
GLOBAL,
LOG_INFO,
"-> KERNEL: Running ComputeSpecificKE ('%s' -> '%s').\n", velocity_field, ske_field);
338 ierr = DMSwarmGetLocalSize(user->
swarm, &n_local); CHKERRQ(ierr);
339 if (n_local == 0) PetscFunctionReturn(0);
342 ierr = DMSwarmGetField(user->
swarm, velocity_field, NULL, NULL, (
const void**)&vel_arr); CHKERRQ(ierr);
343 ierr = DMSwarmGetField(user->
post_swarm, ske_field, NULL, NULL, (
void**)&ske_arr); CHKERRQ(ierr);
346 for (PetscInt p = 0; p < n_local; p++) {
347 const PetscScalar u = vel_arr[p][0];
348 const PetscScalar v = vel_arr[p][1];
349 const PetscScalar w = vel_arr[p][2];
350 const PetscScalar vel_sq = u*u + v*v + w*w;
351 ske_arr[p] = 0.5 * vel_sq;
355 ierr = DMSwarmRestoreField(user->
swarm, velocity_field, NULL, NULL, (
const void**)&vel_arr); CHKERRQ(ierr);
356 ierr = DMSwarmRestoreField(user->
post_swarm, ske_field, NULL, NULL, (
void**)&ske_arr); CHKERRQ(ierr);
358 PetscFunctionReturn(0);
PetscErrorCode ComputeQCriterion(UserCtx *user)
Computes the Q-Criterion, a scalar value identifying vortex cores.
PetscErrorCode ComputeSpecificKE(UserCtx *user, const char *velocity_field, const char *ske_field)
Computes the specific kinetic energy (KE per unit mass) for each particle.
PetscErrorCode NormalizeRelativeField(UserCtx *user, const char *relative_field_name)
Normalizes a relative field by subtracting a reference value.
PetscErrorCode ComputeNodalAverage(UserCtx *user, const char *in_field_name, const char *out_field_name)
Computes node-centered data by averaging 8 surrounding cell-centered values, exactly replicating the ...