24 const Array4<Real >& phi,
25 const Array4<Real const>& Hz,
26 const Array4<Real >& Hzk,
27 const Array4<Real >& AK,
28 const Array4<Real const>& Akv,
29 const Array4<Real >& BC,
30 const Array4<Real >& DC,
31 const Array4<Real >& FC,
32 const Array4<Real >& CF,
33 const int nnew,
const int N,
const Real dt_lev)
39 amrex::Print() <<
"updating on box in vert_visc_3d: " << phi_bx << std::endl;
41 ParallelFor(phi_bx, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k)
43 Hzk(i,j,k)=0.5_rt*(Hz(i-ioff,j-joff,k)+Hz(i,j,k));
49 ParallelFor(surroundingNodes(phi_bx,2), [=] AMREX_GPU_DEVICE (
int i,
int j,
int k)
51 AK(i,j,k) = 0.5_rt * (Akv(i-ioff,j-joff,k)+Akv(i,j,k));
54 Gpu::streamSynchronize();
61 const Real sixth = 1.0_rt / 6.0_rt;
62 const Real third = 1.0_rt / 3.0_rt;
64 ParallelFor(makeSlab(phi_bx,2,0), [=] AMREX_GPU_DEVICE (
int i,
int j,
int )
69 for (
int k=1; k<=N; k++)
76 const Real oHzkm1 = 1.0_rt/ Hzk(i,j,k-1);
77 const Real oHz = 1.0_rt/ Hzk(i,j,k);
80 FC(i,j,k) = sixth * Hzk(i,j,k-1) - dt_lev * AK(i,j,k-1) / Hzk(i,j,k-1);
81 CF(i,j,k) = sixth * Hzk(i,j,k ) - dt_lev * AK(i,j,k+1) / Hzk(i,j,k );
83 BC(i,j,k) = third * (Hzk(i,j,k-1) + Hzk(i,j,k )) + dt_lev * AK(i,j,k) * (oHzkm1 + oHz);
84 Real cff = 1.0_rt / (BC(i,j,k) - FC(i,j,k) * CF(i,j,k-1));
86 DC(i,j,k) = cff * (phi(i,j,k ,nnew) - phi(i,j,k-1,nnew) - FC(i,j,k)*DC(i,j,k-1));
93 Gpu::streamSynchronize();
94 ParallelFor(makeSlab(phi_bx,2,0), [=] AMREX_GPU_DEVICE (
int i,
int j,
int )
97 for(
int k=N; k>=1; k--) {
101 DC(i,j,k) -= CF(i,j,k)*DC(i,j,k+1);
109 ParallelFor(surroundingNodes(phi_bx,2), [=] AMREX_GPU_DEVICE (
int i,
int j,
int k)
111 DC(i,j,k) *= AK(i,j,k);
114 ParallelFor(phi_bx, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k)
116 const Real oHz = 1.0_rt/ Hzk(i,j,k);
117 Real cff = dt_lev*oHz*(DC(i,j,k+1)-DC(i,j,k));
void vert_visc_3d(const amrex::Box &bx, const int ioff, const int joff, const amrex::Array4< amrex::Real > &phi, const amrex::Array4< amrex::Real const > &Hz, const amrex::Array4< amrex::Real > &Hzk, const amrex::Array4< amrex::Real > &AK, const amrex::Array4< amrex::Real const > &Akv, const amrex::Array4< amrex::Real > &BC, const amrex::Array4< amrex::Real > &DC, const amrex::Array4< amrex::Real > &FC, const amrex::Array4< amrex::Real > &CF, const int nnew, const int N, const amrex::Real dt_lev)
Calculate effects of vertical viscosity or diffusivity.