1 #ifndef ERF_FFT_UTILS_H_
2 #define ERF_FFT_UTILS_H_
8 inline Array<std::pair<FFT::Boundary,FFT::Boundary>,AMREX_SPACEDIM>
9 get_fft_bc (Geometry
const& lev_geom,
10 Array<std::string,2*AMREX_SPACEDIM> l_domain_bc_type,
11 Box
const& bounding_box,
bool use_real_bcs) noexcept
13 Array<std::pair<FFT::Boundary,FFT::Boundary>,AMREX_SPACEDIM> r;
15 FFT::Boundary first, second;
17 for (
int dir = 0; dir <= 2; dir++)
19 auto bc_type_lo = l_domain_bc_type[Orientation(dir,Orientation::low)];
20 if ( lev_geom.isPeriodic(dir) &&
21 (lev_geom.Domain().smallEnd(dir) == bounding_box.smallEnd(dir)) )
23 first = FFT::Boundary::periodic;
27 else if ( (lev_geom.Domain().smallEnd(dir) == bounding_box.smallEnd(dir)) &&
28 (bc_type_lo ==
"Outflow" || bc_type_lo ==
"Open") && (dir == 2 || !use_real_bcs) )
30 first = FFT::Boundary::odd;
36 first = FFT::Boundary::even;
40 auto bc_type_hi = l_domain_bc_type[Orientation(dir,Orientation::high)];
41 if ( lev_geom.isPeriodic(dir) &&
42 (lev_geom.Domain().bigEnd(dir) == bounding_box.bigEnd(dir)) )
44 second = FFT::Boundary::periodic;
48 else if ( (lev_geom.Domain().bigEnd(dir) == bounding_box.bigEnd(dir)) &&
49 (bc_type_hi ==
"Outflow" || bc_type_hi ==
"Open") && (dir == 2 || !use_real_bcs) )
51 second = FFT::Boundary::odd;
57 second = FFT::Boundary::even;
61 r[dir] = std::make_pair(first,second);
Definition: ERF_ConsoleIO.cpp:12