From ef06864524affcc13b957d9ac5ec023124ec005a Mon Sep 17 00:00:00 2001 From: Sreehari Perumanath Date: Tue, 19 Mar 2024 14:30:23 +0000 Subject: [PATCH 1/6] Updated from main --- exec/multispec/AdvanceTimestepBousq.cpp | 166 ++++++++++++++++-- exec/multispec/Checkpoint.cpp | 14 ++ exec/multispec/GNUmakefile | 2 +- exec/multispec/Init.cpp | 81 ++++++++- exec/multispec/WritePlotFile.cpp | 26 ++- exec/multispec/_Examples/README | 13 ++ .../_Examples/_Validation/inputs_laplace | 152 ++++++++++++++++ .../_Examples/_Validation/inputs_spectrum | 152 ++++++++++++++++ exec/multispec/_Examples/inputs_nucleus_3d | 129 ++++++++++++++ exec/multispec/_Examples/inputs_slab_3d | 129 ++++++++++++++ exec/multispec/_PNAS_inputs/README | 15 -- .../_laplace_pressure/inputs_bubble_chi_3.0 | 141 --------------- .../_laplace_pressure/inputs_bubble_chi_3.25 | 143 --------------- .../_laplace_pressure/inputs_bubble_chi_3.5 | 143 --------------- .../_laplace_pressure/inputs_bubble_chi_3.75 | 141 --------------- .../_laplace_pressure/inputs_bubble_chi_4.0 | 141 --------------- .../_laplace_pressure/inputs_bubble_chi_4.25 | 141 --------------- .../_laplace_pressure/inputs_bubble_chi_4.5 | 141 --------------- .../_laplace_pressure/inputs_bubble_chi_4.75 | 141 --------------- .../_laplace_pressure/inputs_bubble_chi_5.0 | 141 --------------- .../_thickness/inputs_slab_chi_3.0 | 143 --------------- .../_thickness/inputs_slab_chi_3.25 | 150 ---------------- .../_thickness/inputs_slab_chi_3.5 | 150 ---------------- .../_thickness/inputs_slab_chi_3.75 | 151 ---------------- .../_thickness/inputs_slab_chi_4.0 | 152 ---------------- .../_thickness/inputs_slab_chi_4.25 | 153 ---------------- .../_thickness/inputs_slab_chi_4.5 | 153 ---------------- .../_thickness/inputs_slab_chi_4.75 | 153 ---------------- .../_thickness/inputs_slab_chi_5.0 | 149 ---------------- .../_PNAS_inputs/inputs_RayleighPlateau | 141 --------------- .../_PNAS_inputs/inputs_high_schmidt | 141 --------------- exec/multispec/_PNAS_inputs/inputs_spectrum | 142 --------------- exec/multispec/_PNAS_inputs/inputs_torus | 141 --------------- exec/multispec/main_driver.cpp | 28 ++- exec/multispec/multispec_test_functions.H | 15 +- 35 files changed, 879 insertions(+), 3235 deletions(-) create mode 100644 exec/multispec/_Examples/README create mode 100644 exec/multispec/_Examples/_Validation/inputs_laplace create mode 100644 exec/multispec/_Examples/_Validation/inputs_spectrum create mode 100644 exec/multispec/_Examples/inputs_nucleus_3d create mode 100644 exec/multispec/_Examples/inputs_slab_3d delete mode 100644 exec/multispec/_PNAS_inputs/README delete mode 100644 exec/multispec/_PNAS_inputs/_laplace_pressure/inputs_bubble_chi_3.0 delete mode 100644 exec/multispec/_PNAS_inputs/_laplace_pressure/inputs_bubble_chi_3.25 delete mode 100644 exec/multispec/_PNAS_inputs/_laplace_pressure/inputs_bubble_chi_3.5 delete mode 100644 exec/multispec/_PNAS_inputs/_laplace_pressure/inputs_bubble_chi_3.75 delete mode 100644 exec/multispec/_PNAS_inputs/_laplace_pressure/inputs_bubble_chi_4.0 delete mode 100644 exec/multispec/_PNAS_inputs/_laplace_pressure/inputs_bubble_chi_4.25 delete mode 100644 exec/multispec/_PNAS_inputs/_laplace_pressure/inputs_bubble_chi_4.5 delete mode 100644 exec/multispec/_PNAS_inputs/_laplace_pressure/inputs_bubble_chi_4.75 delete mode 100644 exec/multispec/_PNAS_inputs/_laplace_pressure/inputs_bubble_chi_5.0 delete mode 100644 exec/multispec/_PNAS_inputs/_thickness/inputs_slab_chi_3.0 delete mode 100644 exec/multispec/_PNAS_inputs/_thickness/inputs_slab_chi_3.25 delete mode 100644 exec/multispec/_PNAS_inputs/_thickness/inputs_slab_chi_3.5 delete mode 100644 exec/multispec/_PNAS_inputs/_thickness/inputs_slab_chi_3.75 delete mode 100644 exec/multispec/_PNAS_inputs/_thickness/inputs_slab_chi_4.0 delete mode 100644 exec/multispec/_PNAS_inputs/_thickness/inputs_slab_chi_4.25 delete mode 100644 exec/multispec/_PNAS_inputs/_thickness/inputs_slab_chi_4.5 delete mode 100644 exec/multispec/_PNAS_inputs/_thickness/inputs_slab_chi_4.75 delete mode 100644 exec/multispec/_PNAS_inputs/_thickness/inputs_slab_chi_5.0 delete mode 100644 exec/multispec/_PNAS_inputs/inputs_RayleighPlateau delete mode 100644 exec/multispec/_PNAS_inputs/inputs_high_schmidt delete mode 100644 exec/multispec/_PNAS_inputs/inputs_spectrum delete mode 100644 exec/multispec/_PNAS_inputs/inputs_torus diff --git a/exec/multispec/AdvanceTimestepBousq.cpp b/exec/multispec/AdvanceTimestepBousq.cpp index 8d9f3931c..69e91ee19 100644 --- a/exec/multispec/AdvanceTimestepBousq.cpp +++ b/exec/multispec/AdvanceTimestepBousq.cpp @@ -9,6 +9,7 @@ #include #include +#include // argv contains the name of the inputs file entered at the command line @@ -33,6 +34,10 @@ void AdvanceTimestepBousq(std::array< MultiFab, AMREX_SPACEDIM >& umac, MultiFab& permittivity, StochMassFlux& sMassFlux, StochMomFlux& sMomFlux, + MultiFab& phi_old, + MultiFab& phi_new, + MultiFab& phitot_old, + MultiFab& phitot_new, const Real& dt, const Real& time, const int& istep, @@ -122,7 +127,7 @@ void AdvanceTimestepBousq(std::array< MultiFab, AMREX_SPACEDIM >& umac, } } - if (use_multiphase || use_flory_huggins) { + if (use_multiphase || use_flory_huggins || use_ice_nucleation) { for (int d=0; d& umac, if (any_grav) { Abort("AdvanceTimestepBousq.cpp gravity not implemented"); } - + +if (use_ice_nucleation ==0) { if (variance_coef_mass != 0.) { sMassFlux.fillMassStochastic(); } @@ -217,7 +223,7 @@ void AdvanceTimestepBousq(std::array< MultiFab, AMREX_SPACEDIM >& umac, ComputeMassFluxdiv(rho_old,rhotot_old,Temp,diff_mass_fluxdiv,stoch_mass_fluxdiv, diff_mass_flux,stoch_mass_flux,sMassFlux,0.5*dt,time,geom,weights_mass, charge_old,grad_Epot_old,Epot,permittivity); - + // here is a reasonable place to call something to compute in reversible stress term // in this case want to get divergence so it looks like a add to rhs for stokes solver if (use_multiphase) { @@ -240,6 +246,18 @@ void AdvanceTimestepBousq(std::array< MultiFab, AMREX_SPACEDIM >& umac, } } + } else { + + ComputeRhotot(phi_old,phitot_old); + // compute reversible stress tensor ---added term + ComputeDivFHReversibleStress(div_reversible_stress,phitot_old,phi_old,geom); + + // add divergence of reversible stress to gmres_rhs_v + for (int d=0; d& umac, eta_ed[d].mult(2.,0,1,0); } +if (use_ice_nucleation ==0){ ////////////////////////////////////////////// // Step 2: compute reactions and mass fluxes at t^n ////////////////////////////////////////////// @@ -368,7 +387,7 @@ void AdvanceTimestepBousq(std::array< MultiFab, AMREX_SPACEDIM >& umac, end if */ - + if (advection_type == 1 || advection_type == 2) { // bds advection @@ -415,7 +434,7 @@ void AdvanceTimestepBousq(std::array< MultiFab, AMREX_SPACEDIM >& umac, Abort("Invalid advection_type"); } - + ////////////////////////////////////////////// /// Step 3: density prediction to t^{n+1/2} ////////////////////////////////////////////// @@ -440,7 +459,7 @@ void AdvanceTimestepBousq(std::array< MultiFab, AMREX_SPACEDIM >& umac, end if */ } - + // compute rhotot^{n+1/2} from rho^{n+1/2} in VALID REGION ComputeRhotot(rho_new,rhotot_new); @@ -450,6 +469,17 @@ void AdvanceTimestepBousq(std::array< MultiFab, AMREX_SPACEDIM >& umac, // average rho_i^{n+1/2} to faces AverageCCToFace(rho_new,rho_fc,0,nspecies,SPEC_BC_COMP,geom); +} else { + // compute rhotot^{n+1/2} from rho^{n+1/2} in VALID REGION + ComputeRhotot(rho_old,rhotot_new); + + // fill rho and rhotot ghost cells at t^{n+1/2} + FillRhoRhototGhost(rho_old,rhotot_new,geom); + + // average rho_i^{n+1/2} to faces + //AverageCCToFace(rho_old,rho_fc,0,nspecies,SPEC_BC_COMP,geom); +} + if (use_charged_fluid) { // compute total charge at t^{n+1/2} DotWithZ(rho_new,charge_new); @@ -461,7 +491,11 @@ void AdvanceTimestepBousq(std::array< MultiFab, AMREX_SPACEDIM >& umac, } // compute (eta,kappa)^{n+1/2} +if (use_ice_nucleation ==0){ ComputeEta(rho_new, rhotot_new, eta); +} else { + ComputeEta(phi_old, phitot_old, eta); +} if (AMREX_SPACEDIM == 2) { AverageCCToNode(eta,eta_ed[0],0,1,SPEC_BC_COMP,geom); } @@ -469,6 +503,7 @@ void AdvanceTimestepBousq(std::array< MultiFab, AMREX_SPACEDIM >& umac, AverageCCToEdge(eta,eta_ed,0,1,SPEC_BC_COMP,geom); } +if (use_ice_nucleation ==0){ ////////////////////////////////////////////// // Step 4: compute mass fluxes and reactions at t^{n+1/2} ////////////////////////////////////////////// @@ -525,7 +560,7 @@ void AdvanceTimestepBousq(std::array< MultiFab, AMREX_SPACEDIM >& umac, } else if (use_flory_huggins ==1){ // compute reversible stress tensor ---added term - ComputeDivFHReversibleStress(div_reversible_stress,rhotot_new,rho_new,geom); + ComputeDivFHReversibleStress(div_reversible_stress,rhotot_new,rho_new,geom); } @@ -568,7 +603,7 @@ void AdvanceTimestepBousq(std::array< MultiFab, AMREX_SPACEDIM >& umac, MkAdvSFluxdiv(umac_old,rho_fc,adv_mass_fluxdiv,geom,0,nspecies,false); MkAdvSFluxdiv(umac ,rho_fc,adv_mass_fluxdiv,geom,0,nspecies,true); } - + ////////////////////////////////////////////// // Step 5: density integration to t^{n+1} ////////////////////////////////////////////// @@ -606,6 +641,111 @@ void AdvanceTimestepBousq(std::array< MultiFab, AMREX_SPACEDIM >& umac, // average rho^{n+1} to faces AverageCCToFace(rhotot_new,rhotot_fc_new,0,1,RHO_BC_COMP,geom); + +} else { + AverageCCToFace(rhotot_old,rhotot_fc_new,0,1,RHO_BC_COMP,geom); + + amrex::Real EnScale = rhobar[0]*k_B*T_init[0]*fh_chi(1,0)/monomer_mass; // 2.79e09 + amrex::Real GradEnCoef = rhobar[0]*k_B*T_init[0]*fh_kappa(1,0)/monomer_mass; // 2.73e-6 + amrex::Real PotWellDepr = -2.687e-05*T_init[0]*T_init[0]+0.009943*T_init[0]-0.7128; // For polynomial potential + amrex::Real Mobility = 4.997e6*exp(-4438.0/T_init[0]); // AC Mobility from MATLAB simulations + + MultiFab phi_prd(ba,dmap,1,2); + + FillRhoRhototGhost(phi_old,phitot_old,geom); + + // predict phi at t+1/2 + for (MFIter mfi(phi_prd); mfi.isValid(); ++mfi ) + { + Box bx = mfi.tilebox(); + const Array4& phiOld = phi_old.array(mfi); + const Array4& phiPrd = phi_prd.array(mfi); + + const amrex::Array4& u = umac[0].array(mfi); + const amrex::Array4& v = umac[1].array(mfi); + const amrex::Array4& u_old = umac_old[0].array(mfi); + const amrex::Array4& v_old = umac_old[1].array(mfi); +#if (AMREX_SPACEDIM == 3) + const amrex::Array4& w = umac[2].array(mfi); + const amrex::Array4& w_old = umac_old[2].array(mfi); +#endif + int n=0; + amrex::ParallelFor(bx, [=] AMREX_GPU_DEVICE (int i, int j, int k) noexcept + { + + phiPrd(i,j,k) = phiOld(i,j,k,n) + + dt/2 * Mobility * 2 * GradEnCoef * + ( (phiOld(i+1,j,k,n) - 2.*phiOld(i,j,k,n) + phiOld(i-1,j,k,n)) / (dx[0]*dx[0]) + +(phiOld(i,j+1,k,n) - 2.*phiOld(i,j,k,n) + phiOld(i,j-1,k,n)) / (dx[1]*dx[1]) + ) + - dt/2 * ((u(i+1,j,k)+u_old(i+1,j,k))/2*(phiOld(i+1,j,k,n)+phiOld(i,j,k,n))/2-(u(i,j,k)+u_old(i,j,k))/2*(phiOld(i,j,k,n)+phiOld(i-1,j,k,n))/2)/dx[0] + - dt/2 * ((v(i,j+1,k)+v_old(i,j+1,k))/2*(phiOld(i,j+1,k,n)+phiOld(i,j,k,n))/2-(v(i,j,k)+v_old(i,j,k))/2*(phiOld(i,j,k,n)+phiOld(i,j-1,k,n))/2)/dx[1] +#if (AMREX_SPACEDIM == 3) + + dt/2 * Mobility * 2 * GradEnCoef * (phiOld(i,j,k+1,n) - 2.*phiOld(i,j,k,n) + phiOld(i,j,k-1,n)) / (dx[2]*dx[2]) + - dt/2 * ((w(i,j,k+1)+w_old(i,j,k+1))/2*(phiOld(i,j,k+1,n)+phiOld(i,j,k,n))/2-(w(i,j,k)+w_old(i,j,k))/2*(phiOld(i,j,k,n)+phiOld(i,j,k-1,n))/2)/dx[2] + + variance_coef_mass*sqrt(2.0*k_B*T_init[0]*Mobility*dt/(dx[0]*dx[1]*dx[2]))*amrex::RandomNormal(0,1)/sqrt(2) +#elif (AMREX_SPACEDIM == 2) + + variance_coef_mass*sqrt(2.0*k_B*T_init[0]*Mobility*dt/(dx[0]*dx[1]*cell_depth))*amrex::RandomNormal(0,1)/sqrt(2) +#endif + - dt/2 * Mobility * EnScale*(2*phiOld(i,j,k,n)*(phiOld(i,j,k,n)-1)*(phiOld(i,j,k,n)-1)+2*phiOld(i,j,k,n)*phiOld(i,j,k,n)*(phiOld(i,j,k,n)-1) - PotWellDepr) + ; + }); + } + + phi_prd.FillBoundary(geom.periodicity()); + // advance phi to t+1 + for (MFIter mfi(phi_new); mfi.isValid(); ++mfi ) + { + Box bx = mfi.tilebox(); + const Array4& phiNew = phi_new.array(mfi); + const Array4& phiOld = phi_old.array(mfi); + const Array4& phiPrd = phi_prd.array(mfi); + + const amrex::Array4& u = umac[0].array(mfi); + const amrex::Array4& v = umac[1].array(mfi); + const amrex::Array4& u_old = umac_old[0].array(mfi); + const amrex::Array4& v_old = umac_old[1].array(mfi); +#if (AMREX_SPACEDIM == 3) + const amrex::Array4& w = umac[2].array(mfi); + const amrex::Array4& w_old = umac_old[2].array(mfi); +#endif + int n=0; + amrex::ParallelFor(bx, [=] AMREX_GPU_DEVICE (int i, int j, int k) noexcept + { + + phiNew(i,j,k,n) = phiOld(i,j,k,n) + + dt * Mobility * 2 * GradEnCoef * + ( (phiPrd(i+1,j,k) - 2.*phiPrd(i,j,k) + phiPrd(i-1,j,k)) / (dx[0]*dx[0]) + +(phiPrd(i,j+1,k) - 2.*phiPrd(i,j,k) + phiPrd(i,j-1,k)) / (dx[1]*dx[1]) + ) + - dt * ((u(i+1,j,k)+u_old(i+1,j,k))/2*(phiPrd(i+1,j,k)+phiPrd(i,j,k))/2-(u(i,j,k)+u_old(i,j,k))/2*(phiPrd(i,j,k)+phiPrd(i-1,j,k))/2)/dx[0] + - dt * ((v(i,j+1,k)+v_old(i,j+1,k))/2*(phiPrd(i,j+1,k)+phiPrd(i,j,k))/2-(v(i,j,k)+v_old(i,j,k))/2*(phiPrd(i,j,k)+phiPrd(i,j-1,k))/2)/dx[1] +#if (AMREX_SPACEDIM == 3) + + dt * Mobility * 2 * GradEnCoef * (phiPrd(i,j,k+1) - 2.*phiPrd(i,j,k) + phiPrd(i,j,k-1)) / (dx[2]*dx[2]) + - dt * ((w(i,j,k+1)+w_old(i,j,k+1))/2*(phiPrd(i,j,k+1)+phiPrd(i,j,k))/2-(w(i,j,k)+w_old(i,j,k))/2*(phiPrd(i,j,k)+phiPrd(i,j,k-1))/2)/dx[2] + + variance_coef_mass*sqrt(2.0*k_B*T_init[0]*Mobility*dt/(dx[0]*dx[1]*dx[2]))*amrex::RandomNormal(0,1) +#elif (AMREX_SPACEDIM == 2) + + variance_coef_mass*sqrt(2.0*k_B*T_init[0]*Mobility*dt/(dx[0]*dx[1]*cell_depth))*amrex::RandomNormal(0,1) +#endif + - dt * Mobility * EnScale*(2*phiPrd(i,j,k)*(phiPrd(i,j,k)-1)*(phiPrd(i,j,k)-1)+2*phiPrd(i,j,k)*phiPrd(i,j,k)*(phiPrd(i,j,k)-1) - PotWellDepr) + ; + + phiNew(i,j,k,n+1) = 1-phiNew(i,j,k,n); + }); + } + + ComputeRhotot(phi_new,phitot_new); + // compute reversible stress tensor ---added term + ComputeDivFHReversibleStress(div_reversible_stress,phitot_new,phi_new,geom); + + MultiFab::Copy(phi_old,phi_new,0,0,nspecies,0); + + amrex::Print() << "Advanced phi (phi1_avg = " << phi_new.sum(0)/(n_cells[0]*n_cells[1] +#if (AMREX_SPACEDIM == 3) + *n_cells[2] +#endif + ) <<")\n"; +} if (use_charged_fluid) { // compute total charge at t^{n+1} @@ -617,14 +757,18 @@ void AdvanceTimestepBousq(std::array< MultiFab, AMREX_SPACEDIM >& umac, } } +if (use_ice_nucleation ==0){ ComputeEta(rho_new, rhotot_new, eta); +} else { + ComputeEta(phi_new, phitot_new, eta); +} if (AMREX_SPACEDIM == 2) { AverageCCToNode(eta,eta_ed[0],0,1,SPEC_BC_COMP,geom); } else { AverageCCToEdge(eta,eta_ed,0,1,SPEC_BC_COMP,geom); } - + ////////////////////////////////////////////// // Step 6: solve for v^{n+1} and pi^{n+1/2} using GMRES ////////////////////////////////////////////// @@ -676,7 +820,7 @@ void AdvanceTimestepBousq(std::array< MultiFab, AMREX_SPACEDIM >& umac, // call mk_grav_force_bousq(mla,gmres_rhs_v,.true.,rho_fc,the_bc_tower) } - if (use_multiphase || use_flory_huggins) { + if (use_multiphase || use_flory_huggins || use_ice_nucleation) { // add divergence of reversible stress to gmres_rhs_v for (int d=0; d& umac, eta_ed[d].mult(2.,0,1,0); } +if (use_ice_nucleation ==0) { // if writing a plotfile for electro-explicit option, compute Epot using new densities // use existing machinery to compute all mass fluxes - yes this is overkill // but better than writing a separate routine for now @@ -800,5 +945,6 @@ void AdvanceTimestepBousq(std::array< MultiFab, AMREX_SPACEDIM >& umac, charge_old,grad_Epot_old,Epot,permittivity,0); } } + } } diff --git a/exec/multispec/Checkpoint.cpp b/exec/multispec/Checkpoint.cpp index 06d20503c..4d46609c1 100644 --- a/exec/multispec/Checkpoint.cpp +++ b/exec/multispec/Checkpoint.cpp @@ -23,6 +23,8 @@ void WriteCheckPoint(int step, const amrex::Real dt, const MultiFab& rho, const MultiFab& rhotot, + const MultiFab& phi, + const MultiFab& phitot, const MultiFab& pi, std::array< MultiFab, AMREX_SPACEDIM >& umac, const MultiFab& Epot, @@ -145,6 +147,10 @@ void WriteCheckPoint(int step, amrex::MultiFabFileFullPrefix(0, checkpointname, "Level_", "rho")); VisMF::Write(rhotot, amrex::MultiFabFileFullPrefix(0, checkpointname, "Level_", "rhotot")); + VisMF::Write(phi, + amrex::MultiFabFileFullPrefix(0, checkpointname, "Level_", "phi")); + VisMF::Write(phitot, + amrex::MultiFabFileFullPrefix(0, checkpointname, "Level_", "phitot")); VisMF::Write(pi, amrex::MultiFabFileFullPrefix(0, checkpointname, "Level_", "pi")); @@ -159,6 +165,8 @@ void ReadCheckPoint(int& step, amrex::Real& dt, MultiFab& rho, MultiFab& rhotot, + MultiFab& phi, + MultiFab& phitot, MultiFab& pi, std::array< MultiFab, AMREX_SPACEDIM >& umac, MultiFab& Epot, @@ -237,6 +245,8 @@ void ReadCheckPoint(int& step, rho .define(ba, dmap, nspecies, ng_s); rhotot.define(ba, dmap, 1, ng_s); + phi .define(ba, dmap, nspecies, ng_s); + phitot.define(ba, dmap, 1, ng_s); pi .define(ba, dmap, 1, 1); if (use_charged_fluid) { @@ -327,6 +337,10 @@ void ReadCheckPoint(int& step, amrex::MultiFabFileFullPrefix(0, checkpointname, "Level_", "rho")); VisMF::Read(rhotot, amrex::MultiFabFileFullPrefix(0, checkpointname, "Level_", "rhotot")); + VisMF::Read(phi, + amrex::MultiFabFileFullPrefix(0, checkpointname, "Level_", "phi")); + VisMF::Read(phitot, + amrex::MultiFabFileFullPrefix(0, checkpointname, "Level_", "phitot")); VisMF::Read(pi, amrex::MultiFabFileFullPrefix(0, checkpointname, "Level_", "pi")); diff --git a/exec/multispec/GNUmakefile b/exec/multispec/GNUmakefile index befc75675..f94107b34 100644 --- a/exec/multispec/GNUmakefile +++ b/exec/multispec/GNUmakefile @@ -13,7 +13,7 @@ MAX_SPEC = 8 # MAX_ELEM needs to be MAX_SPEC*(MAX_SPEC-1)/2 MAX_ELEM = 28 -TINY_PROFILE = TRUE +TINY_PROFILE = FALSE USE_PARTICLES = FALSE include $(AMREX_HOME)/Tools/GNUMake/Make.defs diff --git a/exec/multispec/Init.cpp b/exec/multispec/Init.cpp index b91870e6e..da4671d4c 100644 --- a/exec/multispec/Init.cpp +++ b/exec/multispec/Init.cpp @@ -7,6 +7,7 @@ using namespace multispec; void InitRhoUmac(std::array< MultiFab, AMREX_SPACEDIM >& umac, MultiFab& rho_in, + MultiFab& phi_in, const Geometry& geom) { @@ -35,7 +36,7 @@ void InitRhoUmac(std::array< MultiFab, AMREX_SPACEDIM >& umac, Box bx = mfi.tilebox(); const Array4& c = conc.array(mfi); - + if (prob_type == 1) { /* @@ -78,7 +79,7 @@ void InitRhoUmac(std::array< MultiFab, AMREX_SPACEDIM >& umac, }); - } else if (prob_type == 5) { + } else if (prob_type == 5) { /* bubble with radius = 1/4 of domain in x @@ -493,6 +494,68 @@ void InitRhoUmac(std::array< MultiFab, AMREX_SPACEDIM >& umac, } }); + } else if (prob_type == 21) { + + /* + cylinder with radius = 1/4 of domain in x + c=c_init_1(:) inside, c=c_init_2(:) outside + can be discontinous or smooth depending on smoothing_width + */ + //Real rad = L[0] / 8.; + int nsub = 100; + Real factor = nsub; + Real dxsub = dx[0]/factor; + Real dysub = dx[1]/factor; + Real x,y,z; + amrex::Print() << "smoothing width " << smoothing_width << " film_thickness " << film_thickness << std::endl; + + amrex::ParallelFor(bx, [=] AMREX_GPU_DEVICE (int i, int j, int k) noexcept + { + for (int n=0; n& umac, } else if (prob_type == 4) { /* - bubble with radius = 1/4 of domain in x + slab with thickness = 2*radius_cyl c=c_init_1(:) inside, c=c_init_2(:) outside can be discontinous or smooth depending on smoothing_width */ - Real l1 = L[1] / 4.; - Real l2 = 3.*l1; + Real l1 = L[1]*0.5-radius_cyl; + Real l2 = L[1]*0.5+radius_cyl; amrex::ParallelFor(bx, [=] AMREX_GPU_DEVICE (int i, int j, int k) noexcept { @@ -654,7 +717,7 @@ void InitRhoUmac(std::array< MultiFab, AMREX_SPACEDIM >& umac, for (int n=0; n& umac, const Array4& c = conc.array(mfi); const Array4& rho = rho_in.array(mfi); + const Array4& p = phi_in.array(mfi); amrex::ParallelFor(bx, [=] AMREX_GPU_DEVICE (int i, int j, int k) noexcept { @@ -758,10 +822,11 @@ void InitRhoUmac(std::array< MultiFab, AMREX_SPACEDIM >& umac, } rho_total = 1./sumtot; } - - // calculate rho_i + + // calculate rho_i and make phi=conc for (int n=0; n grad_Epot_old; + /***/ + MultiFab phi_old; + MultiFab phitot_old; + if (restart > 0) { ReadCheckPoint(init_step,time,dt, - rho_old,rhotot_old,pi,umac,Epot,grad_Epot_old, + rho_old,rhotot_old,phi_old,phitot_old,pi,umac,Epot,grad_Epot_old, ba,dmap); } else { @@ -171,6 +175,10 @@ void main_driver(const char* argv) if (use_charged_fluid) { Epot.define(ba, dmap, 1, 1); } + + /***/ + phi_old.define (ba, dmap, nspecies, ng_s); + phitot_old.define (ba, dmap, 1 , ng_s); } // moved this to here so can change dt from value in checkpoint @@ -191,8 +199,9 @@ void main_driver(const char* argv) if (restart < 0) { + /***/ // initialize rho and umac in valid region only - InitRhoUmac(umac,rho_old,geom); + InitRhoUmac(umac,rho_old,phi_old,geom); // initialize pi, including ghost cells pi.setVal(0.); @@ -207,6 +216,9 @@ void main_driver(const char* argv) // pressure ghost cells pi.FillBoundary(geom.periodicity()); MultiFabPhysBC(pi,geom,0,1,PRES_BC_COMP); + /***/ + ComputeRhotot(phi_old,phitot_old); + FillRhoRhototGhost(phi_old,phitot_old,geom); //======================================================= // Build multifabs for all the variables @@ -219,6 +231,10 @@ void main_driver(const char* argv) MultiFab eta (ba, dmap, 1 , 1); MultiFab kappa (ba, dmap, 1 , 1); + /***/ + MultiFab phi_new (ba, dmap, nspecies, ng_s); + MultiFab phitot_new (ba, dmap, 1 , ng_s); + ///////////////////////////////////////// // eta and Temp on nodes (2d) or edges (3d) @@ -506,7 +522,7 @@ void main_driver(const char* argv) // write initial plotfile and structure factor if (plot_int > 0) { - WritePlotFile(0,0.,geom,umac,rhotot_old,rho_old,pi,charge_old,Epot); + WritePlotFile(0,0.,geom,umac,rhotot_old,rho_old,pi,charge_old,Epot,phitot_old,phi_old); if (n_steps_skip == 0 && struct_fact_int > 0) { structFact.WritePlotFile(0,0.,geom,"plt_SF"); } @@ -548,12 +564,14 @@ void main_driver(const char* argv) } else if (algorithm_type == 6) { // boussinesq + /***/ AdvanceTimestepBousq(umac,rho_old,rho_new,rhotot_old,rhotot_new, pi,eta,eta_ed,kappa,Temp,Temp_ed, diff_mass_fluxdiv,stoch_mass_fluxdiv,stoch_mass_flux, grad_Epot_old,grad_Epot_new, charge_old,charge_new,Epot,permittivity, sMassFlux,sMomFlux, + phi_old,phi_new,phitot_old,phitot_new, dt,time,istep,geom); } else { @@ -591,7 +609,7 @@ void main_driver(const char* argv) // write plotfile at specific intervals if (plot_int > 0 && istep%plot_int == 0) { - WritePlotFile(istep,time,geom,umac,rhotot_new,rho_new,pi,charge_new,Epot); + WritePlotFile(istep,time,geom,umac,rhotot_new,rho_new,pi,charge_new,Epot,phitot_new,phi_new); if (istep > n_steps_skip && struct_fact_int > 0) { structFact.WritePlotFile(istep,time,geom,"plt_SF"); } @@ -599,7 +617,7 @@ void main_driver(const char* argv) // write checkpoint at specific intervals if (chk_int > 0 && istep%chk_int == 0) { - WriteCheckPoint(istep,time,dt,rho_new,rhotot_new,pi,umac,Epot,grad_Epot_new); + WriteCheckPoint(istep,time,dt,rho_new,rhotot_new,phi_new,phitot_new,pi,umac,Epot,grad_Epot_new); } // set old state to new state diff --git a/exec/multispec/multispec_test_functions.H b/exec/multispec/multispec_test_functions.H index 2c0cb2b89..0dac6e50e 100644 --- a/exec/multispec/multispec_test_functions.H +++ b/exec/multispec/multispec_test_functions.H @@ -60,6 +60,10 @@ void AdvanceTimestepBousq(std::array< MultiFab, AMREX_SPACEDIM >& umac, MultiFab& permittivity, StochMassFlux& sMassFlux, StochMomFlux& sMomFlux, + MultiFab& phi_old, + MultiFab& phi_new, + MultiFab& phitot_old, + MultiFab& phitot_new, const Real& dt, const Real& time, const int& istep, @@ -73,6 +77,8 @@ void WriteCheckPoint(int step, const amrex::Real dt, const MultiFab& rho, const MultiFab& rhotot, + const MultiFab& phi, + const MultiFab& phitot, const MultiFab& pi, std::array< MultiFab, AMREX_SPACEDIM >& umac, const MultiFab& Epot, @@ -83,6 +89,8 @@ void ReadCheckPoint(int& step, amrex::Real& dt, MultiFab& rho, MultiFab& rhotot, + MultiFab& phi, + MultiFab& phitot, MultiFab& pi, std::array< MultiFab, AMREX_SPACEDIM >& umac, MultiFab& Epot, @@ -98,6 +106,7 @@ void ReadFile(const std::string& filename, Vector& charBuf, void InitRhoUmac(std::array< MultiFab, AMREX_SPACEDIM >& umac, MultiFab& rho_in, + MultiFab& phi_old, const Geometry& geom); /////////////////////////// @@ -108,10 +117,12 @@ void WritePlotFile(const int step, const Geometry geom, std::array< MultiFab, AMREX_SPACEDIM >& umac, const MultiFab& rhotot, - const MultiFab& rho, + const MultiFab& rho, const MultiFab& pres, const MultiFab& charge, - const MultiFab& Epot); + const MultiFab& Epot, + const MultiFab& phitot, + const MultiFab& phi); /////////////////////////// From 7da32c2d45603c24291e25278df9723f6519e315 Mon Sep 17 00:00:00 2001 From: Sreehari Perumanath Date: Tue, 19 Mar 2024 14:43:14 +0000 Subject: [PATCH 2/6] Updated from main --- src_multispec/multispec_functions.cpp | 27 +++++++++++++++++++++++++++ src_multispec/multispec_namespace.H | 5 +++++ 2 files changed, 32 insertions(+) diff --git a/src_multispec/multispec_functions.cpp b/src_multispec/multispec_functions.cpp index 436d051bc..cdaf91b80 100644 --- a/src_multispec/multispec_functions.cpp +++ b/src_multispec/multispec_functions.cpp @@ -18,11 +18,16 @@ AMREX_GPU_MANAGED int multispec::is_ideal_ int multispec::use_lapack; AMREX_GPU_MANAGED int multispec::use_multiphase; AMREX_GPU_MANAGED int multispec::use_flory_huggins; +AMREX_GPU_MANAGED int multispec::use_ice_nucleation; +AMREX_GPU_MANAGED int multispec::use_log_potential; AMREX_GPU_MANAGED amrex::Real multispec::kc_tension; AMREX_GPU_MANAGED amrex::Real multispec::alpha_gex; AMREX_GPU_MANAGED amrex::Array2D multispec::fh_kappa; AMREX_GPU_MANAGED amrex::Array2D multispec::fh_chi; AMREX_GPU_MANAGED amrex::GpuArray multispec::fh_monomers; +AMREX_GPU_MANAGED amrex::Real multispec::fh_tension; +AMREX_GPU_MANAGED amrex::GpuArray multispec::contact_angle_lo; +AMREX_GPU_MANAGED amrex::GpuArray multispec::contact_angle_hi; AMREX_GPU_MANAGED amrex::Real multispec::monomer_mass; AMREX_GPU_MANAGED int multispec::n_gex; AMREX_GPU_MANAGED amrex::GpuArray multispec::c_init_1; @@ -80,10 +85,18 @@ void InitializeMultispecNamespace() { use_lapack = 0; // Use LAPACK or iterative method for diffusion matrix (recommend False) use_multiphase = 0; // for RTIL use_flory_huggins = 0; // for flory huggins + use_ice_nucleation = 0; // for ice nucleation simulations + use_log_potential = 0; // use quartic potential by default kc_tension = 0; // for RTIL alpha_gex = 0; // for RTIL n_gex = 1; // for RTIL chi_iterations = 10; // number of iterations used in Dbar2chi_iterative + fh_tension = 0.; + + for (int i=0; i fh_kappa; extern AMREX_GPU_MANAGED amrex::Array2D fh_chi; extern AMREX_GPU_MANAGED amrex::GpuArray fh_monomers; + extern AMREX_GPU_MANAGED amrex::Real fh_tension; + extern AMREX_GPU_MANAGED amrex::GpuArray contact_angle_lo; + extern AMREX_GPU_MANAGED amrex::GpuArray contact_angle_hi; extern AMREX_GPU_MANAGED amrex::Real monomer_mass; extern AMREX_GPU_MANAGED amrex::Real kc_tension; extern AMREX_GPU_MANAGED amrex::Real alpha_gex; From d2fc679f86217251655ea9682d8a4f6bcdf6896c Mon Sep 17 00:00:00 2001 From: Sreehari Perumanath Date: Thu, 21 Mar 2024 11:29:46 +0000 Subject: [PATCH 3/6] Mobility scale array --- exec/multispec/AdvanceTimestepBousq.cpp | 38 +++++++++++------------ exec/multispec/main_driver.cpp | 5 +-- exec/multispec/multispec_test_functions.H | 1 + src_multispec/multispec_functions.cpp | 12 +++++-- src_multispec/multispec_namespace.H | 10 ++++-- 5 files changed, 40 insertions(+), 26 deletions(-) diff --git a/exec/multispec/AdvanceTimestepBousq.cpp b/exec/multispec/AdvanceTimestepBousq.cpp index 69e91ee19..e492679d9 100644 --- a/exec/multispec/AdvanceTimestepBousq.cpp +++ b/exec/multispec/AdvanceTimestepBousq.cpp @@ -38,6 +38,7 @@ void AdvanceTimestepBousq(std::array< MultiFab, AMREX_SPACEDIM >& umac, MultiFab& phi_new, MultiFab& phitot_old, MultiFab& phitot_new, + MultiFab& local_MobScale, const Real& dt, const Real& time, const int& istep, @@ -645,11 +646,6 @@ if (use_ice_nucleation ==0){ } else { AverageCCToFace(rhotot_old,rhotot_fc_new,0,1,RHO_BC_COMP,geom); - amrex::Real EnScale = rhobar[0]*k_B*T_init[0]*fh_chi(1,0)/monomer_mass; // 2.79e09 - amrex::Real GradEnCoef = rhobar[0]*k_B*T_init[0]*fh_kappa(1,0)/monomer_mass; // 2.73e-6 - amrex::Real PotWellDepr = -2.687e-05*T_init[0]*T_init[0]+0.009943*T_init[0]-0.7128; // For polynomial potential - amrex::Real Mobility = 4.997e6*exp(-4438.0/T_init[0]); // AC Mobility from MATLAB simulations - MultiFab phi_prd(ba,dmap,1,2); FillRhoRhototGhost(phi_old,phitot_old,geom); @@ -658,8 +654,9 @@ if (use_ice_nucleation ==0){ for (MFIter mfi(phi_prd); mfi.isValid(); ++mfi ) { Box bx = mfi.tilebox(); - const Array4& phiOld = phi_old.array(mfi); - const Array4& phiPrd = phi_prd.array(mfi); + const Array4& phiOld = phi_old.array(mfi); + const Array4& phiPrd = phi_prd.array(mfi); + const Array4& MobScale = local_MobScale.array(mfi); const amrex::Array4& u = umac[0].array(mfi); const amrex::Array4& v = umac[1].array(mfi); @@ -674,20 +671,20 @@ if (use_ice_nucleation ==0){ { phiPrd(i,j,k) = phiOld(i,j,k,n) - + dt/2 * Mobility * 2 * GradEnCoef * + + dt/2 * Mobility*MobScale(i,j,k) * 2 * GradEnCoef * ( (phiOld(i+1,j,k,n) - 2.*phiOld(i,j,k,n) + phiOld(i-1,j,k,n)) / (dx[0]*dx[0]) +(phiOld(i,j+1,k,n) - 2.*phiOld(i,j,k,n) + phiOld(i,j-1,k,n)) / (dx[1]*dx[1]) ) - dt/2 * ((u(i+1,j,k)+u_old(i+1,j,k))/2*(phiOld(i+1,j,k,n)+phiOld(i,j,k,n))/2-(u(i,j,k)+u_old(i,j,k))/2*(phiOld(i,j,k,n)+phiOld(i-1,j,k,n))/2)/dx[0] - dt/2 * ((v(i,j+1,k)+v_old(i,j+1,k))/2*(phiOld(i,j+1,k,n)+phiOld(i,j,k,n))/2-(v(i,j,k)+v_old(i,j,k))/2*(phiOld(i,j,k,n)+phiOld(i,j-1,k,n))/2)/dx[1] #if (AMREX_SPACEDIM == 3) - + dt/2 * Mobility * 2 * GradEnCoef * (phiOld(i,j,k+1,n) - 2.*phiOld(i,j,k,n) + phiOld(i,j,k-1,n)) / (dx[2]*dx[2]) + + dt/2 * Mobility*MobScale(i,j,k) * 2 * GradEnCoef * (phiOld(i,j,k+1,n) - 2.*phiOld(i,j,k,n) + phiOld(i,j,k-1,n)) / (dx[2]*dx[2]) - dt/2 * ((w(i,j,k+1)+w_old(i,j,k+1))/2*(phiOld(i,j,k+1,n)+phiOld(i,j,k,n))/2-(w(i,j,k)+w_old(i,j,k))/2*(phiOld(i,j,k,n)+phiOld(i,j,k-1,n))/2)/dx[2] - + variance_coef_mass*sqrt(2.0*k_B*T_init[0]*Mobility*dt/(dx[0]*dx[1]*dx[2]))*amrex::RandomNormal(0,1)/sqrt(2) + + variance_coef_mass*sqrt(2.0*k_B*T_init[0]*Mobility*MobScale(i,j,k)*dt/(dx[0]*dx[1]*dx[2]))*amrex::RandomNormal(0,1)/sqrt(2) #elif (AMREX_SPACEDIM == 2) - + variance_coef_mass*sqrt(2.0*k_B*T_init[0]*Mobility*dt/(dx[0]*dx[1]*cell_depth))*amrex::RandomNormal(0,1)/sqrt(2) + + variance_coef_mass*sqrt(2.0*k_B*T_init[0]*Mobility*MobScale(i,j,k)*dt/(dx[0]*dx[1]*cell_depth))*amrex::RandomNormal(0,1)/sqrt(2) #endif - - dt/2 * Mobility * EnScale*(2*phiOld(i,j,k,n)*(phiOld(i,j,k,n)-1)*(phiOld(i,j,k,n)-1)+2*phiOld(i,j,k,n)*phiOld(i,j,k,n)*(phiOld(i,j,k,n)-1) - PotWellDepr) + - dt/2 * Mobility*MobScale(i,j,k) * EnScale*(2*phiOld(i,j,k,n)*(phiOld(i,j,k,n)-1)*(phiOld(i,j,k,n)-1)+2*phiOld(i,j,k,n)*phiOld(i,j,k,n)*(phiOld(i,j,k,n)-1) - PotWellDepr) ; }); } @@ -697,9 +694,10 @@ if (use_ice_nucleation ==0){ for (MFIter mfi(phi_new); mfi.isValid(); ++mfi ) { Box bx = mfi.tilebox(); - const Array4& phiNew = phi_new.array(mfi); - const Array4& phiOld = phi_old.array(mfi); - const Array4& phiPrd = phi_prd.array(mfi); + const Array4& phiNew = phi_new.array(mfi); + const Array4& phiOld = phi_old.array(mfi); + const Array4& phiPrd = phi_prd.array(mfi); + const Array4& MobScale = local_MobScale.array(mfi); const amrex::Array4& u = umac[0].array(mfi); const amrex::Array4& v = umac[1].array(mfi); @@ -714,20 +712,20 @@ if (use_ice_nucleation ==0){ { phiNew(i,j,k,n) = phiOld(i,j,k,n) - + dt * Mobility * 2 * GradEnCoef * + + dt * Mobility*MobScale(i,j,k) * 2 * GradEnCoef * ( (phiPrd(i+1,j,k) - 2.*phiPrd(i,j,k) + phiPrd(i-1,j,k)) / (dx[0]*dx[0]) +(phiPrd(i,j+1,k) - 2.*phiPrd(i,j,k) + phiPrd(i,j-1,k)) / (dx[1]*dx[1]) ) - dt * ((u(i+1,j,k)+u_old(i+1,j,k))/2*(phiPrd(i+1,j,k)+phiPrd(i,j,k))/2-(u(i,j,k)+u_old(i,j,k))/2*(phiPrd(i,j,k)+phiPrd(i-1,j,k))/2)/dx[0] - dt * ((v(i,j+1,k)+v_old(i,j+1,k))/2*(phiPrd(i,j+1,k)+phiPrd(i,j,k))/2-(v(i,j,k)+v_old(i,j,k))/2*(phiPrd(i,j,k)+phiPrd(i,j-1,k))/2)/dx[1] #if (AMREX_SPACEDIM == 3) - + dt * Mobility * 2 * GradEnCoef * (phiPrd(i,j,k+1) - 2.*phiPrd(i,j,k) + phiPrd(i,j,k-1)) / (dx[2]*dx[2]) + + dt * Mobility*MobScale(i,j,k) * 2 * GradEnCoef * (phiPrd(i,j,k+1) - 2.*phiPrd(i,j,k) + phiPrd(i,j,k-1)) / (dx[2]*dx[2]) - dt * ((w(i,j,k+1)+w_old(i,j,k+1))/2*(phiPrd(i,j,k+1)+phiPrd(i,j,k))/2-(w(i,j,k)+w_old(i,j,k))/2*(phiPrd(i,j,k)+phiPrd(i,j,k-1))/2)/dx[2] - + variance_coef_mass*sqrt(2.0*k_B*T_init[0]*Mobility*dt/(dx[0]*dx[1]*dx[2]))*amrex::RandomNormal(0,1) + + variance_coef_mass*sqrt(2.0*k_B*T_init[0]*Mobility*MobScale(i,j,k)*dt/(dx[0]*dx[1]*dx[2]))*amrex::RandomNormal(0,1) #elif (AMREX_SPACEDIM == 2) - + variance_coef_mass*sqrt(2.0*k_B*T_init[0]*Mobility*dt/(dx[0]*dx[1]*cell_depth))*amrex::RandomNormal(0,1) + + variance_coef_mass*sqrt(2.0*k_B*T_init[0]*Mobility*MobScale(i,j,k)*dt/(dx[0]*dx[1]*cell_depth))*amrex::RandomNormal(0,1) #endif - - dt * Mobility * EnScale*(2*phiPrd(i,j,k)*(phiPrd(i,j,k)-1)*(phiPrd(i,j,k)-1)+2*phiPrd(i,j,k)*phiPrd(i,j,k)*(phiPrd(i,j,k)-1) - PotWellDepr) + - dt * Mobility*MobScale(i,j,k) * EnScale*(2*phiPrd(i,j,k)*(phiPrd(i,j,k)-1)*(phiPrd(i,j,k)-1)+2*phiPrd(i,j,k)*phiPrd(i,j,k)*(phiPrd(i,j,k)-1) - PotWellDepr) ; phiNew(i,j,k,n+1) = 1-phiNew(i,j,k,n); diff --git a/exec/multispec/main_driver.cpp b/exec/multispec/main_driver.cpp index 06701fd46..be633b8a9 100644 --- a/exec/multispec/main_driver.cpp +++ b/exec/multispec/main_driver.cpp @@ -234,7 +234,8 @@ void main_driver(const char* argv) /***/ MultiFab phi_new (ba, dmap, nspecies, ng_s); MultiFab phitot_new (ba, dmap, 1 , ng_s); - + MultiFab local_MobScale (ba, dmap, 1 , 0); + local_MobScale.setVal(1.0); // Change this near to wall BC ///////////////////////////////////////// // eta and Temp on nodes (2d) or edges (3d) @@ -571,7 +572,7 @@ void main_driver(const char* argv) grad_Epot_old,grad_Epot_new, charge_old,charge_new,Epot,permittivity, sMassFlux,sMomFlux, - phi_old,phi_new,phitot_old,phitot_new, + phi_old,phi_new,phitot_old,phitot_new,local_MobScale, dt,time,istep,geom); } else { diff --git a/exec/multispec/multispec_test_functions.H b/exec/multispec/multispec_test_functions.H index 0dac6e50e..3e83e9d4f 100644 --- a/exec/multispec/multispec_test_functions.H +++ b/exec/multispec/multispec_test_functions.H @@ -64,6 +64,7 @@ void AdvanceTimestepBousq(std::array< MultiFab, AMREX_SPACEDIM >& umac, MultiFab& phi_new, MultiFab& phitot_old, MultiFab& phitot_new, + MultiFab& local_MobScale, const Real& dt, const Real& time, const int& istep, diff --git a/src_multispec/multispec_functions.cpp b/src_multispec/multispec_functions.cpp index cdaf91b80..57004ec82 100644 --- a/src_multispec/multispec_functions.cpp +++ b/src_multispec/multispec_functions.cpp @@ -20,6 +20,10 @@ AMREX_GPU_MANAGED int multispec::use_multi AMREX_GPU_MANAGED int multispec::use_flory_huggins; AMREX_GPU_MANAGED int multispec::use_ice_nucleation; AMREX_GPU_MANAGED int multispec::use_log_potential; +AMREX_GPU_MANAGED amrex::Real multispec::EnScale; +AMREX_GPU_MANAGED amrex::Real multispec::GradEnCoef; +AMREX_GPU_MANAGED amrex::Real multispec::PotWellDepr; +AMREX_GPU_MANAGED amrex::Real multispec::Mobility; AMREX_GPU_MANAGED amrex::Real multispec::kc_tension; AMREX_GPU_MANAGED amrex::Real multispec::alpha_gex; AMREX_GPU_MANAGED amrex::Array2D multispec::fh_kappa; @@ -85,8 +89,12 @@ void InitializeMultispecNamespace() { use_lapack = 0; // Use LAPACK or iterative method for diffusion matrix (recommend False) use_multiphase = 0; // for RTIL use_flory_huggins = 0; // for flory huggins - use_ice_nucleation = 0; // for ice nucleation simulations - use_log_potential = 0; // use quartic potential by default + use_ice_nucleation = 0; // for ice nucleation simulations + use_log_potential = 0; // use quartic potential by default + EnScale = 2.79e09; + GradEnCoef = 2.73e-6; + PotWellDepr = -2.687e-05*T_init[0]*T_init[0]+0.009943*T_init[0]-0.7128; // For polynomial potential + Mobility = 0.0001808*T_init[0]*T_init[0]-0.08481*T_init[0]+9.968; // AC Mobility kc_tension = 0; // for RTIL alpha_gex = 0; // for RTIL n_gex = 1; // for RTIL diff --git a/src_multispec/multispec_namespace.H b/src_multispec/multispec_namespace.H index 806f1b7a3..3d01c3fed 100644 --- a/src_multispec/multispec_namespace.H +++ b/src_multispec/multispec_namespace.H @@ -21,8 +21,6 @@ namespace multispec { extern AMREX_GPU_MANAGED int use_lapack; extern AMREX_GPU_MANAGED int use_multiphase; extern AMREX_GPU_MANAGED int use_flory_huggins; - extern AMREX_GPU_MANAGED int use_ice_nucleation; - extern AMREX_GPU_MANAGED int use_log_potential; extern AMREX_GPU_MANAGED amrex::Array2D fh_kappa; extern AMREX_GPU_MANAGED amrex::Array2D fh_chi; extern AMREX_GPU_MANAGED amrex::GpuArray fh_monomers; @@ -62,5 +60,13 @@ namespace multispec { extern amrex::Real L_pos; extern amrex::Real L_trans; extern amrex::Real L_zero; + + // ice-nucleation + extern AMREX_GPU_MANAGED int use_ice_nucleation; + extern AMREX_GPU_MANAGED int use_log_potential; + extern AMREX_GPU_MANAGED amrex::Real EnScale; + extern AMREX_GPU_MANAGED amrex::Real GradEnCoef; + extern AMREX_GPU_MANAGED amrex::Real PotWellDepr; + extern AMREX_GPU_MANAGED amrex::Real Mobility; } From d2721f8e99eefb2a30379da7c9a343939414373a Mon Sep 17 00:00:00 2001 From: Sreehari Perumanath Date: Thu, 21 Mar 2024 12:01:18 +0000 Subject: [PATCH 4/6] Mobility scale array --- src_multispec/InitialProjection.cpp | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/src_multispec/InitialProjection.cpp b/src_multispec/InitialProjection.cpp index 4aa1a869a..7f7567df5 100644 --- a/src_multispec/InitialProjection.cpp +++ b/src_multispec/InitialProjection.cpp @@ -95,11 +95,12 @@ void InitialProjection(std::array< MultiFab, AMREX_SPACEDIM >& umac, if (variance_coef_mass != 0. && algorithm_type != 6) { sMassFlux.fillMassStochastic(); } - + +if (use_ice_nucleation ==0) { ComputeMassFluxdiv(rho,rhotot,Temp,diff_mass_fluxdiv,stoch_mass_fluxdiv, diff_mass_flux,stoch_mass_flux,sMassFlux,dt_eff,time,geom,weights, charge_old,grad_Epot_old,Epot,permittivity); - +} // assumble total fluxes to be used in reservoirs // // From 4db49247fb69c4dd7340c2eac34cc01d96635303 Mon Sep 17 00:00:00 2001 From: Sreehari Perumanath Date: Sun, 24 Mar 2024 10:20:35 +0000 Subject: [PATCH 5/6] Mobility scale array deleted --- exec/multispec/AdvanceTimestepBousq.cpp | 25 ++++++++++++------------- exec/multispec/main_driver.cpp | 6 +++--- src_multispec/multispec_functions.cpp | 1 + 3 files changed, 16 insertions(+), 16 deletions(-) diff --git a/exec/multispec/AdvanceTimestepBousq.cpp b/exec/multispec/AdvanceTimestepBousq.cpp index e492679d9..57aeff971 100644 --- a/exec/multispec/AdvanceTimestepBousq.cpp +++ b/exec/multispec/AdvanceTimestepBousq.cpp @@ -38,7 +38,6 @@ void AdvanceTimestepBousq(std::array< MultiFab, AMREX_SPACEDIM >& umac, MultiFab& phi_new, MultiFab& phitot_old, MultiFab& phitot_new, - MultiFab& local_MobScale, const Real& dt, const Real& time, const int& istep, @@ -656,7 +655,6 @@ if (use_ice_nucleation ==0){ Box bx = mfi.tilebox(); const Array4& phiOld = phi_old.array(mfi); const Array4& phiPrd = phi_prd.array(mfi); - const Array4& MobScale = local_MobScale.array(mfi); const amrex::Array4& u = umac[0].array(mfi); const amrex::Array4& v = umac[1].array(mfi); @@ -671,20 +669,20 @@ if (use_ice_nucleation ==0){ { phiPrd(i,j,k) = phiOld(i,j,k,n) - + dt/2 * Mobility*MobScale(i,j,k) * 2 * GradEnCoef * + + dt/2 * Mobility * 2 * GradEnCoef * ( (phiOld(i+1,j,k,n) - 2.*phiOld(i,j,k,n) + phiOld(i-1,j,k,n)) / (dx[0]*dx[0]) +(phiOld(i,j+1,k,n) - 2.*phiOld(i,j,k,n) + phiOld(i,j-1,k,n)) / (dx[1]*dx[1]) ) - dt/2 * ((u(i+1,j,k)+u_old(i+1,j,k))/2*(phiOld(i+1,j,k,n)+phiOld(i,j,k,n))/2-(u(i,j,k)+u_old(i,j,k))/2*(phiOld(i,j,k,n)+phiOld(i-1,j,k,n))/2)/dx[0] - dt/2 * ((v(i,j+1,k)+v_old(i,j+1,k))/2*(phiOld(i,j+1,k,n)+phiOld(i,j,k,n))/2-(v(i,j,k)+v_old(i,j,k))/2*(phiOld(i,j,k,n)+phiOld(i,j-1,k,n))/2)/dx[1] #if (AMREX_SPACEDIM == 3) - + dt/2 * Mobility*MobScale(i,j,k) * 2 * GradEnCoef * (phiOld(i,j,k+1,n) - 2.*phiOld(i,j,k,n) + phiOld(i,j,k-1,n)) / (dx[2]*dx[2]) + + dt/2 * Mobility * 2 * GradEnCoef * (phiOld(i,j,k+1,n) - 2.*phiOld(i,j,k,n) + phiOld(i,j,k-1,n)) / (dx[2]*dx[2]) - dt/2 * ((w(i,j,k+1)+w_old(i,j,k+1))/2*(phiOld(i,j,k+1,n)+phiOld(i,j,k,n))/2-(w(i,j,k)+w_old(i,j,k))/2*(phiOld(i,j,k,n)+phiOld(i,j,k-1,n))/2)/dx[2] - + variance_coef_mass*sqrt(2.0*k_B*T_init[0]*Mobility*MobScale(i,j,k)*dt/(dx[0]*dx[1]*dx[2]))*amrex::RandomNormal(0,1)/sqrt(2) + + variance_coef_mass*sqrt(2.0*k_B*T_init[0]*Mobility*dt/(dx[0]*dx[1]*dx[2]))*amrex::RandomNormal(0,1)/sqrt(2) #elif (AMREX_SPACEDIM == 2) - + variance_coef_mass*sqrt(2.0*k_B*T_init[0]*Mobility*MobScale(i,j,k)*dt/(dx[0]*dx[1]*cell_depth))*amrex::RandomNormal(0,1)/sqrt(2) + + variance_coef_mass*sqrt(2.0*k_B*T_init[0]*Mobility*dt/(dx[0]*dx[1]*cell_depth))*amrex::RandomNormal(0,1)/sqrt(2) #endif - - dt/2 * Mobility*MobScale(i,j,k) * EnScale*(2*phiOld(i,j,k,n)*(phiOld(i,j,k,n)-1)*(phiOld(i,j,k,n)-1)+2*phiOld(i,j,k,n)*phiOld(i,j,k,n)*(phiOld(i,j,k,n)-1) - PotWellDepr) + - dt/2 * Mobility * EnScale*(2*phiOld(i,j,k,n)*(phiOld(i,j,k,n)-1)*(phiOld(i,j,k,n)-1)+2*phiOld(i,j,k,n)*phiOld(i,j,k,n)*(phiOld(i,j,k,n)-1) - PotWellDepr) ; }); } @@ -697,7 +695,6 @@ if (use_ice_nucleation ==0){ const Array4& phiNew = phi_new.array(mfi); const Array4& phiOld = phi_old.array(mfi); const Array4& phiPrd = phi_prd.array(mfi); - const Array4& MobScale = local_MobScale.array(mfi); const amrex::Array4& u = umac[0].array(mfi); const amrex::Array4& v = umac[1].array(mfi); @@ -712,20 +709,20 @@ if (use_ice_nucleation ==0){ { phiNew(i,j,k,n) = phiOld(i,j,k,n) - + dt * Mobility*MobScale(i,j,k) * 2 * GradEnCoef * + + dt * Mobility * 2 * GradEnCoef * ( (phiPrd(i+1,j,k) - 2.*phiPrd(i,j,k) + phiPrd(i-1,j,k)) / (dx[0]*dx[0]) +(phiPrd(i,j+1,k) - 2.*phiPrd(i,j,k) + phiPrd(i,j-1,k)) / (dx[1]*dx[1]) ) - dt * ((u(i+1,j,k)+u_old(i+1,j,k))/2*(phiPrd(i+1,j,k)+phiPrd(i,j,k))/2-(u(i,j,k)+u_old(i,j,k))/2*(phiPrd(i,j,k)+phiPrd(i-1,j,k))/2)/dx[0] - dt * ((v(i,j+1,k)+v_old(i,j+1,k))/2*(phiPrd(i,j+1,k)+phiPrd(i,j,k))/2-(v(i,j,k)+v_old(i,j,k))/2*(phiPrd(i,j,k)+phiPrd(i,j-1,k))/2)/dx[1] #if (AMREX_SPACEDIM == 3) - + dt * Mobility*MobScale(i,j,k) * 2 * GradEnCoef * (phiPrd(i,j,k+1) - 2.*phiPrd(i,j,k) + phiPrd(i,j,k-1)) / (dx[2]*dx[2]) + + dt * Mobility * 2 * GradEnCoef * (phiPrd(i,j,k+1) - 2.*phiPrd(i,j,k) + phiPrd(i,j,k-1)) / (dx[2]*dx[2]) - dt * ((w(i,j,k+1)+w_old(i,j,k+1))/2*(phiPrd(i,j,k+1)+phiPrd(i,j,k))/2-(w(i,j,k)+w_old(i,j,k))/2*(phiPrd(i,j,k)+phiPrd(i,j,k-1))/2)/dx[2] - + variance_coef_mass*sqrt(2.0*k_B*T_init[0]*Mobility*MobScale(i,j,k)*dt/(dx[0]*dx[1]*dx[2]))*amrex::RandomNormal(0,1) + + variance_coef_mass*sqrt(2.0*k_B*T_init[0]*Mobility*dt/(dx[0]*dx[1]*dx[2]))*amrex::RandomNormal(0,1) #elif (AMREX_SPACEDIM == 2) - + variance_coef_mass*sqrt(2.0*k_B*T_init[0]*Mobility*MobScale(i,j,k)*dt/(dx[0]*dx[1]*cell_depth))*amrex::RandomNormal(0,1) + + variance_coef_mass*sqrt(2.0*k_B*T_init[0]*Mobility*dt/(dx[0]*dx[1]*cell_depth))*amrex::RandomNormal(0,1) #endif - - dt * Mobility*MobScale(i,j,k) * EnScale*(2*phiPrd(i,j,k)*(phiPrd(i,j,k)-1)*(phiPrd(i,j,k)-1)+2*phiPrd(i,j,k)*phiPrd(i,j,k)*(phiPrd(i,j,k)-1) - PotWellDepr) + - dt * Mobility * EnScale*(2*phiPrd(i,j,k)*(phiPrd(i,j,k)-1)*(phiPrd(i,j,k)-1)+2*phiPrd(i,j,k)*phiPrd(i,j,k)*(phiPrd(i,j,k)-1) - PotWellDepr) ; phiNew(i,j,k,n+1) = 1-phiNew(i,j,k,n); @@ -738,6 +735,8 @@ if (use_ice_nucleation ==0){ MultiFab::Copy(phi_old,phi_new,0,0,nspecies,0); + amrex::Print() << "Mobility = " << Mobility <<"\n"; + amrex::Print() << "Advanced phi (phi1_avg = " << phi_new.sum(0)/(n_cells[0]*n_cells[1] #if (AMREX_SPACEDIM == 3) *n_cells[2] diff --git a/exec/multispec/main_driver.cpp b/exec/multispec/main_driver.cpp index be633b8a9..be9497362 100644 --- a/exec/multispec/main_driver.cpp +++ b/exec/multispec/main_driver.cpp @@ -234,8 +234,8 @@ void main_driver(const char* argv) /***/ MultiFab phi_new (ba, dmap, nspecies, ng_s); MultiFab phitot_new (ba, dmap, 1 , ng_s); - MultiFab local_MobScale (ba, dmap, 1 , 0); - local_MobScale.setVal(1.0); // Change this near to wall BC + //MultiFab local_MobScale (ba, dmap, 1 , 0); + //local_MobScale.setVal(1.0); // Change this near to wall BC ///////////////////////////////////////// // eta and Temp on nodes (2d) or edges (3d) @@ -572,7 +572,7 @@ void main_driver(const char* argv) grad_Epot_old,grad_Epot_new, charge_old,charge_new,Epot,permittivity, sMassFlux,sMomFlux, - phi_old,phi_new,phitot_old,phitot_new,local_MobScale, + phi_old,phi_new,phitot_old,phitot_new, dt,time,istep,geom); } else { diff --git a/src_multispec/multispec_functions.cpp b/src_multispec/multispec_functions.cpp index 57004ec82..d7d18d45f 100644 --- a/src_multispec/multispec_functions.cpp +++ b/src_multispec/multispec_functions.cpp @@ -208,6 +208,7 @@ void InitializeMultispecNamespace() { pp.query("use_log_potential",use_log_potential); pp.query("monomer_mass",monomer_mass); pp.query("kc_tension",kc_tension); + pp.query("Mobility",Mobility); pp.query("fh_tension",fh_tension); pp.query("alpha_gex",alpha_gex); pp.query("n_gex",n_gex); From fe16e616112d61e0d85646a1b1674e8ba73a44f5 Mon Sep 17 00:00:00 2001 From: Sreehari Perumanath Date: Sun, 24 Mar 2024 10:25:44 +0000 Subject: [PATCH 6/6] Mobility scale array deleted --- exec/multispec/multispec_test_functions.H | 1 - 1 file changed, 1 deletion(-) diff --git a/exec/multispec/multispec_test_functions.H b/exec/multispec/multispec_test_functions.H index 3e83e9d4f..0dac6e50e 100644 --- a/exec/multispec/multispec_test_functions.H +++ b/exec/multispec/multispec_test_functions.H @@ -64,7 +64,6 @@ void AdvanceTimestepBousq(std::array< MultiFab, AMREX_SPACEDIM >& umac, MultiFab& phi_new, MultiFab& phitot_old, MultiFab& phitot_new, - MultiFab& local_MobScale, const Real& dt, const Real& time, const int& istep,