54 auto dxinv = dxInv[0], dyinv = dxInv[1], dzinv = dxInv[2];
57 ParallelFor(bxx, bxy, bxz,
58 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k)
61 Real mfsq = mf_ux(i,j,0) * mf_uy(i,j,0);
63 Real diffContrib = ( (
tau11(i , j , k ) -
tau11(i-1, j ,k )) * dxinv * mfsq
64 + (
tau12(i , j+1, k ) -
tau12(i , j ,k )) * dyinv * mfsq
65 + (
tau13(i , j , k+1) -
tau13(i , j ,k )) * dzinv );
66 diffContrib /= 0.5*(detJ(i,j,k) + detJ(i-1,j,k));
67 rho_u_rhs(i,j,k) -= diffContrib;
69 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k)
72 Real mfsq = mf_vx(i,j,0) * mf_vy(i,j,0);
74 Real diffContrib = ( (
tau21(i+1, j , k ) -
tau21(i , j , k )) * dxinv * mfsq
75 + (
tau22(i , j , k ) -
tau22(i , j-1, k )) * dyinv * mfsq
76 + (
tau23(i , j , k+1) -
tau23(i , j , k )) * dzinv );
77 diffContrib /= 0.5*(detJ(i,j,k) + detJ(i,j-1,k));
78 rho_v_rhs(i,j,k) -= diffContrib;
80 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k)
83 Real mfsq = mf_mx(i,j,0) * mf_my(i,j,0);
85 Real diffContrib = ( (
tau31(i+1, j , k ) -
tau31(i , j , k )) * dxinv * mfsq
86 + (
tau32(i , j+1, k ) -
tau32(i , j , k )) * dyinv * mfsq
87 + (
tau33(i , j , k ) -
tau33(i , j , k-1)) * dzinv );
88 diffContrib /= 0.5*(detJ(i,j,k) + detJ(i,j,k-1));
89 rho_w_rhs(i,j,k) -= diffContrib;
92 }
else if (l_stretched_dz) {
94 auto dz_ptr = stretched_dz_d.data();
96 ParallelFor(bxx, bxy, bxz,
97 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k)
100 Real mfsq = mf_ux(i,j,0) * mf_uy(i,j,0);
101 Real dzloc = dz_ptr[k]*dzinv;
103 Real diffContrib = ( (
tau11(i , j , k ) -
tau11(i-1, j ,k )) * dxinv * mfsq
104 + (
tau12(i , j+1, k ) -
tau12(i , j ,k )) * dyinv * mfsq
105 + (
tau13(i , j , k+1) -
tau13(i , j ,k )) * dzinv );
107 rho_u_rhs(i,j,k) -= diffContrib/dzloc;
109 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k)
112 Real mfsq = mf_vx(i,j,0) * mf_vy(i,j,0);
113 Real dzloc = dz_ptr[k]*dzinv;
115 Real diffContrib = ( (
tau21(i+1, j , k ) -
tau21(i , j , k )) * dxinv * mfsq
116 + (
tau22(i , j , k ) -
tau22(i , j-1, k )) * dyinv * mfsq
117 + (
tau23(i , j , k+1) -
tau23(i , j , k )) * dzinv );
119 rho_v_rhs(i,j,k) -= diffContrib/dzloc;
121 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k)
124 Real mfsq = mf_mx(i,j,0) * mf_my(i,j,0);
125 Real dzloc = 0.5 * (dz_ptr[k] + dz_ptr[k-1])*dzinv;
127 Real diffContrib = ( (
tau31(i+1, j , k ) -
tau31(i , j , k )) * dxinv * mfsq
128 + (
tau32(i , j+1, k ) -
tau32(i , j , k )) * dyinv * mfsq
129 + (
tau33(i , j , k ) -
tau33(i , j , k-1)) * dzinv );
131 rho_w_rhs(i,j,k) -= diffContrib/dzloc;
136 ParallelFor(bxx, bxy, bxz,
137 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k)
140 Real mfsq = mf_ux(i,j,0) * mf_uy(i,j,0);
143 Real Imfy_hi = 1. / mf_my(i ,j,0);
144 Real Imfy_lo = 1. / mf_my(i-1,j,0);
145 Real Imfx_hi = 1. / (0.5 * (mf_vx(i,j+1,0) + mf_vx(i-1,j+1,0)));
146 Real Imfx_lo = 1. / (0.5 * (mf_vx(i,j ,0) + mf_vx(i-1,j ,0)));
147 rho_u_rhs(i,j,k) -= ( (
tau11(i , j , k )*Imfy_hi -
tau11(i-1, j ,k )*Imfy_lo) * dxinv * mfsq
148 + (
tau12(i , j+1, k )*Imfx_hi -
tau12(i , j ,k )*Imfx_lo) * dyinv * mfsq
149 + (
tau13(i , j , k+1) -
tau13(i , j ,k ) ) * dzinv );
151 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k)
154 Real mfsq = mf_vx(i,j,0) * mf_vy(i,j,0);
157 Real Imfy_hi = 1. / (0.5 * (mf_uy(i+1,j,0) + mf_uy(i+1,j-1,0)));
158 Real Imfy_lo = 1. / (0.5 * (mf_uy(i ,j,0) + mf_uy(i ,j-1,0)));
159 Real Imfx_hi = 1. / mf_mx(i ,j,0);
160 Real Imfx_lo = 1. / mf_mx(i-1,j,0);
161 rho_v_rhs(i,j,k) -= ( (
tau12(i+1, j , k )*Imfy_hi -
tau12(i , j , k )*Imfy_lo) * dxinv * mfsq
162 + (
tau22(i , j , k )*Imfx_hi -
tau22(i , j-1, k )*Imfx_lo) * dyinv * mfsq
163 + (
tau23(i , j , k+1) -
tau23(i , j , k ) ) * dzinv );
165 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k)
168 Real mfsq = mf_mx(i,j,0) * mf_my(i,j,0);
171 Real Imfy_hi = 1. / mf_uy(i+1,j ,0);
172 Real Imfy_lo = 1. / mf_uy(i ,j ,0);
173 Real Imfx_hi = 1. / mf_vx(i ,j+1,0);
174 Real Imfx_lo = 1. / mf_vx(i ,j ,0);
175 rho_w_rhs(i,j,k) -= ( (
tau13(i+1, j , k )*Imfy_hi -
tau13(i , j , k )*Imfy_lo) * dxinv * mfsq
176 + (
tau23(i , j+1, k )*Imfx_hi -
tau23(i , j , k )*Imfx_lo) * dyinv * mfsq
177 + (
tau33(i , j , k ) -
tau33(i , j , k-1) ) * dzinv );
@ tau12
Definition: ERF_DataStruct.H:30
@ tau23
Definition: ERF_DataStruct.H:30
@ tau33
Definition: ERF_DataStruct.H:30
@ tau22
Definition: ERF_DataStruct.H:30
@ tau11
Definition: ERF_DataStruct.H:30
@ tau32
Definition: ERF_DataStruct.H:30
@ tau31
Definition: ERF_DataStruct.H:30
@ tau21
Definition: ERF_DataStruct.H:30
@ tau13
Definition: ERF_DataStruct.H:30