From 2a39ddb9f125bcddf71bc9c9d6f1dcba039fa298 Mon Sep 17 00:00:00 2001 From: Andy Nonaka Date: Mon, 6 Nov 2023 17:10:39 -0800 Subject: [PATCH] disjoining pressure --- exec/thinFilm/main_driver.cpp | 42 +++++++++++++++++++++++----- exec/thinFilm/thinfilm_functions.cpp | 4 ++- exec/thinFilm/thinfilm_namespace.H | 1 + 3 files changed, 39 insertions(+), 8 deletions(-) diff --git a/exec/thinFilm/main_driver.cpp b/exec/thinFilm/main_driver.cpp index df115084..614cc4ce 100644 --- a/exec/thinFilm/main_driver.cpp +++ b/exec/thinFilm/main_driver.cpp @@ -135,9 +135,11 @@ void main_driver(const char* argv) // define DistributionMapping dmap.define(ba); - MultiFab height(ba, dmap, 1, 1); - MultiFab Laph (ba, dmap, 1, 1); + MultiFab height (ba, dmap, 1, 1); + MultiFab Laph (ba, dmap, 1, 1); + MultiFab disjoining(ba, dmap, 1, 1); Laph.setVal(0.); // prevent intermediate NaN calculations behind physical boundaries + disjoining.setVal(0.); // for statsitics @@ -169,6 +171,11 @@ void main_driver(const char* argv) gradLaph[1].define(convert(ba,nodal_flag_y), dmap, 1, 0);, gradLaph[2].define(convert(ba,nodal_flag_z), dmap, 1, 0);); + std::array< MultiFab, AMREX_SPACEDIM > gradDisjoining; + AMREX_D_TERM(gradDisjoining[0].define(convert(ba,nodal_flag_x), dmap, 1, 0);, + gradDisjoining[1].define(convert(ba,nodal_flag_y), dmap, 1, 0);, + gradDisjoining[2].define(convert(ba,nodal_flag_z), dmap, 1, 0);); + std::array< MultiFab, AMREX_SPACEDIM > flux; AMREX_D_TERM(flux[0] .define(convert(ba,nodal_flag_x), dmap, 1, 0);, flux[1] .define(convert(ba,nodal_flag_y), dmap, 1, 0);, @@ -205,6 +212,7 @@ void main_driver(const char* argv) // constant factor in noise term Real ConstNoise = 2.*k_B*T_init[0] / (3.*visc_coef); Real Const3dx = thinfilm_gamma / (3.*visc_coef); + Real Const3dx_nogamma = 1. / (3.*visc_coef); Real time = 0.; @@ -301,7 +309,7 @@ void main_driver(const char* argv) AMREX_D_TERM(const Array4 & gradhx = gradh[0].array(mfi);, const Array4 & gradhy = gradh[1].array(mfi);, const Array4 & gradhz = gradh[2].array(mfi);); - + const Array4 & h = height.array(mfi); amrex::ParallelFor(bx_x, bx_y, @@ -365,12 +373,16 @@ void main_driver(const char* argv) } - // compute Laph + // compute Laph and disjoining for ( MFIter mfi(Laph,TilingIfNotGPU()); mfi.isValid(); ++mfi ) { const Box& bx = mfi.tilebox(); const Array4 & L = Laph.array(mfi); + + const Array4 & h = height.array(mfi); + + const Array4 & Disjoining = disjoining.array(mfi); AMREX_D_TERM(const Array4 & gradhx = gradh[0].array(mfi);, const Array4 & gradhy = gradh[1].array(mfi);, @@ -380,11 +392,13 @@ void main_driver(const char* argv) { L(i,j,k) = x_flux_fac * (gradhx(i+1,j,k) - gradhx(i,j,k)) / dx[0] + y_flux_fac * (gradhy(i,j+1,k) - gradhy(i,j,k)) / dx[1]; + + Disjoining(i,j,k) = thinfilm_hamaker / (6.*M_PI*std::pow(h(i,j,k),3.)); }); } Laph.FillBoundary(geom.periodicity()); - // compute gradLaph + // compute gradLaph and gradDisjoining for ( MFIter mfi(height,TilingIfNotGPU()); mfi.isValid(); ++mfi ) { AMREX_D_TERM(const Box & bx_x = mfi.nodaltilebox(0);, @@ -394,17 +408,25 @@ void main_driver(const char* argv) AMREX_D_TERM(const Array4 & gradLaphx = gradLaph[0].array(mfi);, const Array4 & gradLaphy = gradLaph[1].array(mfi);, const Array4 & gradLaphz = gradLaph[2].array(mfi);); + + AMREX_D_TERM(const Array4 & gradDisjoiningx = gradDisjoining[0].array(mfi);, + const Array4 & gradDisjoiningy = gradDisjoining[1].array(mfi);, + const Array4 & gradDisjoiningz = gradDisjoining[2].array(mfi);); const Array4 & L = Laph.array(mfi); + const Array4 & Disjoining = disjoining.array(mfi); + amrex::ParallelFor(bx_x, bx_y, [=] AMREX_GPU_DEVICE (int i, int j, int k) noexcept { gradLaphx(i,j,k) = ( L(i,j,k) - L(i-1,j,k) ) / dx[0]; + gradDisjoiningx(i,j,k) = ( Disjoining(i,j,k) -Disjoining(i-1,j,k) ) / dx[0]; }, [=] AMREX_GPU_DEVICE (int i, int j, int k) noexcept { gradLaphy(i,j,k) = ( L(i,j,k) - L(i,j-1,k) ) / dx[1]; + gradDisjoiningy(i,j,k) = ( Disjoining(i,j,k) -Disjoining(i,j-1,k) ) / dx[1]; }); } @@ -431,18 +453,24 @@ void main_driver(const char* argv) const Array4 & randfacey = randface[1].array(mfi);, const Array4 & randfacez = randface[2].array(mfi);); + AMREX_D_TERM(const Array4 & gradDisjoiningx = gradDisjoining[0].array(mfi);, + const Array4 & gradDisjoiningy = gradDisjoining[1].array(mfi);, + const Array4 & gradDisjoiningz = gradDisjoining[2].array(mfi);); + amrex::ParallelFor(bx_x, bx_y, [=] AMREX_GPU_DEVICE (int i, int j, int k) noexcept { fluxx(i,j,k) = x_flux_fac * ( std::sqrt(ConstNoise*std::pow(hfacex(i,j,k),3.) / (dt*dVol)) * randfacex(i,j,k) - + Const3dx * std::pow(hfacex(i,j,k),3.)*gradLaphx(i,j,k) ); + + Const3dx * std::pow(hfacex(i,j,k),3.)*gradLaphx(i,j,k) + + Const3dx_nogamma * std::pow(hfacex(i,j,k),3.)*gradDisjoiningx(i,j,k)); }, [=] AMREX_GPU_DEVICE (int i, int j, int k) noexcept { fluxy(i,j,k) = y_flux_fac * ( std::sqrt(ConstNoise*std::pow(hfacey(i,j,k),3.) / (dt*dVol)) * randfacey(i,j,k) - + Const3dx * std::pow(hfacey(i,j,k),3.)*gradLaphy(i,j,k) ); + + Const3dx * std::pow(hfacey(i,j,k),3.)*gradLaphy(i,j,k) + + Const3dx_nogamma * std::pow(hfacex(i,j,k),3.)*gradDisjoiningy(i,j,k) ); }); // lo x-faces diff --git a/exec/thinFilm/thinfilm_functions.cpp b/exec/thinFilm/thinfilm_functions.cpp index 3a4917d2..2c466f32 100644 --- a/exec/thinFilm/thinfilm_functions.cpp +++ b/exec/thinFilm/thinfilm_functions.cpp @@ -5,6 +5,7 @@ AMREX_GPU_MANAGED amrex::Real thinfilm::thinfilm_h0; AMREX_GPU_MANAGED amrex::Real thinfilm::thinfilm_gamma; AMREX_GPU_MANAGED amrex::Real thinfilm::thinfilm_pertamp; +AMREX_GPU_MANAGED amrex::Real thinfilm::thinfilm_hamaker; AMREX_GPU_MANAGED int thinfilm::thinfilm_icorr; AMREX_GPU_MANAGED int thinfilm::thinfilm_jcorr; @@ -19,6 +20,7 @@ void InitializeThinfilmNamespace() { thinfilm_icorr = 0; thinfilm_jcorr = 0; thinfilm_pertamp = 0.; + thinfilm_hamaker = 0.; do_fft_diag = 1; @@ -26,8 +28,8 @@ void InitializeThinfilmNamespace() { pp.get("thinfilm_h0",thinfilm_h0); pp.get("thinfilm_gamma",thinfilm_gamma); - pp.query("thinfilm_pertamp",thinfilm_pertamp); + pp.query("thinfilm_hamaker",thinfilm_hamaker); pp.query("thinfilm_icorr",thinfilm_icorr); pp.query("thinfilm_jcorr",thinfilm_jcorr); diff --git a/exec/thinFilm/thinfilm_namespace.H b/exec/thinFilm/thinfilm_namespace.H index 59091542..16f3afef 100644 --- a/exec/thinFilm/thinfilm_namespace.H +++ b/exec/thinFilm/thinfilm_namespace.H @@ -3,6 +3,7 @@ namespace thinfilm { extern AMREX_GPU_MANAGED amrex::Real thinfilm_h0; extern AMREX_GPU_MANAGED amrex::Real thinfilm_gamma; extern AMREX_GPU_MANAGED amrex::Real thinfilm_pertamp; + extern AMREX_GPU_MANAGED amrex::Real thinfilm_hamaker; extern AMREX_GPU_MANAGED int thinfilm_icorr; extern AMREX_GPU_MANAGED int thinfilm_jcorr;