1 #ifndef ERF_SOLVER_UTILS_H_
2 #define ERF_SOLVER_UTILS_H_
4 #include "AMReX_LO_BCTYPES.H"
12 inline Array<LinOpBCType,AMREX_SPACEDIM>
14 Array<std::string,2*AMREX_SPACEDIM> l_domain_bc_type)
16 amrex::Array<amrex::LinOpBCType,AMREX_SPACEDIM> r;
17 for (
int dir = 0; dir < AMREX_SPACEDIM; ++dir) {
18 if ( lev_geom.isPeriodic(dir) )
20 r[dir] = LinOpBCType::Periodic;
22 auto bc_type = l_domain_bc_type[Orientation(dir,Orientation::low)];
23 if (bc_type ==
"Outflow" || bc_type ==
"Open") {
24 r[dir] = LinOpBCType::Dirichlet;
26 r[dir] = LinOpBCType::Neumann;
33 inline Array<LinOpBCType,AMREX_SPACEDIM>
35 Array<std::string,2*AMREX_SPACEDIM> l_domain_bc_type)
37 amrex::Array<amrex::LinOpBCType,AMREX_SPACEDIM> r;
38 for (
int dir = 0; dir < AMREX_SPACEDIM; ++dir) {
39 if ( lev_geom.isPeriodic(dir) )
41 r[dir] = LinOpBCType::Periodic;
43 auto bc_type = l_domain_bc_type[Orientation(dir,Orientation::high)];
44 if (bc_type ==
"Outflow" || bc_type ==
"Open") {
45 r[dir] = LinOpBCType::Dirichlet;
47 r[dir] = LinOpBCType::Neumann;
56 inline Array<std::pair<FFT::Boundary,FFT::Boundary>,AMREX_SPACEDIM>
57 get_fft_bc (Geometry
const& lev_geom,
58 Array<std::string,2*AMREX_SPACEDIM> l_domain_bc_type,
59 Box
const& bounding_box,
bool use_real_bcs) noexcept
61 Array<std::pair<FFT::Boundary,FFT::Boundary>,AMREX_SPACEDIM> r;
63 FFT::Boundary first, second;
65 for (
int dir = 0; dir <= 2; dir++)
67 auto bc_type_lo = l_domain_bc_type[Orientation(dir,Orientation::low)];
68 if ( lev_geom.isPeriodic(dir) &&
69 (lev_geom.Domain().smallEnd(dir) == bounding_box.smallEnd(dir)) )
71 first = FFT::Boundary::periodic;
75 else if ( (lev_geom.Domain().smallEnd(dir) == bounding_box.smallEnd(dir)) &&
76 (bc_type_lo ==
"Outflow" || bc_type_lo ==
"Open") && (dir == 2 || !use_real_bcs) )
78 first = FFT::Boundary::odd;
84 first = FFT::Boundary::even;
88 auto bc_type_hi = l_domain_bc_type[Orientation(dir,Orientation::high)];
89 if ( lev_geom.isPeriodic(dir) &&
90 (lev_geom.Domain().bigEnd(dir) == bounding_box.bigEnd(dir)) )
92 second = FFT::Boundary::periodic;
96 else if ( (lev_geom.Domain().bigEnd(dir) == bounding_box.bigEnd(dir)) &&
97 (bc_type_hi ==
"Outflow" || bc_type_hi ==
"Open") && (dir == 2 || !use_real_bcs) )
99 second = FFT::Boundary::odd;
105 second = FFT::Boundary::even;
109 r[dir] = std::make_pair(first,second);
Array< LinOpBCType, AMREX_SPACEDIM > get_lo_projection_bc(Geometry const &lev_geom, Array< std::string, 2 *AMREX_SPACEDIM > l_domain_bc_type)
Definition: ERF_SolverUtils.H:13
Array< LinOpBCType, AMREX_SPACEDIM > get_hi_projection_bc(Geometry const &lev_geom, Array< std::string, 2 *AMREX_SPACEDIM > l_domain_bc_type)
Definition: ERF_SolverUtils.H:34
Definition: ERF_ConsoleIO.cpp:12