1 #ifndef ERF_ADV_STRUCT_H_
2 #define ERF_ADV_STRUCT_H_
7 #include <AMReX_ParmParse.H>
8 #include <AMReX_Print.H>
10 #include <AMReX_Geometry.H>
27 std::string dycore_horiz_adv_string =
"" ; std::string dycore_vert_adv_string =
"";
28 std::string dryscal_horiz_adv_string =
"" ; std::string dryscal_vert_adv_string =
"";
29 pp.query(
"dycore_horiz_adv_type" , dycore_horiz_adv_string);
30 pp.query(
"dycore_vert_adv_type" , dycore_vert_adv_string);
31 pp.query(
"dryscal_horiz_adv_type" , dryscal_horiz_adv_string);
32 pp.query(
"dryscal_vert_adv_type" , dryscal_vert_adv_string);
34 std::string moistscal_horiz_adv_string =
""; std::string moistscal_vert_adv_string =
"";
35 pp.query(
"moistscal_horiz_adv_type", moistscal_horiz_adv_string);
36 pp.query(
"moistscal_vert_adv_type" , moistscal_vert_adv_string);
39 amrex::Print() <<
"Using efficient advection scheme" << std::endl;
42 if ( (dycore_horiz_adv_string ==
"Blended_3rd4th") ||
43 (dycore_horiz_adv_string ==
"Blended_5th6th") )
47 "The dycore horizontal upwinding fraction must be between 0 and 1");
50 if ( (dycore_vert_adv_string ==
"Blended_3rd4th") ||
51 (dycore_vert_adv_string ==
"Blended_5th6th") )
55 "The dycore vertical upwinding fraction must be between 0 and 1");
58 if ( (dryscal_horiz_adv_string ==
"Blended_3rd4th") ||
59 (dryscal_horiz_adv_string ==
"Blended_5th6th") )
63 "The dry scalar horizontal upwinding fraction must be between 0 and 1");
66 if ( (dryscal_vert_adv_string ==
"Blended_3rd4th") ||
67 (dryscal_vert_adv_string ==
"Blended_5th6th") )
71 "The dry scalar vertical upwinding fraction must be between 0 and 1");
74 if ( (moistscal_horiz_adv_string ==
"Blended_3rd4th") ||
75 (moistscal_horiz_adv_string ==
"Blended_5th6th") )
79 "The moist scalar horizontal upwinding fraction must be between 0 and 1");
82 if ( (moistscal_vert_adv_string ==
"Blended_3rd4th") ||
83 (moistscal_vert_adv_string ==
"Blended_5th6th") )
87 "The moist scalar vertical upwinding fraction must be between 0 and 1");
90 if ( (dycore_horiz_adv_string ==
"Centered_2nd") ||
91 (dycore_horiz_adv_string ==
"Upwind_3rd" ) ||
92 (dycore_horiz_adv_string ==
"Blended_3rd4th") ||
93 (dycore_horiz_adv_string ==
"Centered_4th") ||
94 (dycore_horiz_adv_string ==
"Upwind_5th" ) ||
95 (dycore_horiz_adv_string ==
"Blended_5th6th") ||
96 (dycore_horiz_adv_string ==
"Centered_6th") )
101 if ( (dycore_vert_adv_string ==
"Centered_2nd") ||
102 (dycore_vert_adv_string ==
"Upwind_3rd" ) ||
103 (dycore_vert_adv_string ==
"Blended_3rd4th") ||
104 (dycore_vert_adv_string ==
"Centered_4th") ||
105 (dycore_vert_adv_string ==
"Upwind_5th" ) ||
106 (dycore_vert_adv_string ==
"Blended_5th6th") ||
107 (dycore_vert_adv_string ==
"Centered_6th") )
112 if ( (dryscal_horiz_adv_string ==
"Centered_2nd") ||
113 (dryscal_horiz_adv_string ==
"Upwind_3rd" ) ||
114 (dryscal_horiz_adv_string ==
"Blended_3rd4th") ||
115 (dryscal_horiz_adv_string ==
"Centered_4th") ||
116 (dryscal_horiz_adv_string ==
"Upwind_5th" ) ||
117 (dryscal_horiz_adv_string ==
"Blended_5th6th") ||
118 (dryscal_horiz_adv_string ==
"Centered_6th") ||
119 (dryscal_horiz_adv_string ==
"WENO3" ) ||
120 (dryscal_horiz_adv_string ==
"WENOZ3" ) ||
121 (dryscal_horiz_adv_string ==
"WENOMZQ3" ) ||
122 (dryscal_horiz_adv_string ==
"WENO5" ) ||
123 (dryscal_horiz_adv_string ==
"WENOZ5" ) ||
124 (dryscal_horiz_adv_string ==
"WENO7" ) ||
125 (dryscal_horiz_adv_string ==
"WENOZ7" ) )
130 if ( (dryscal_vert_adv_string ==
"Centered_2nd") ||
131 (dryscal_vert_adv_string ==
"Upwind_3rd" ) ||
132 (dryscal_vert_adv_string ==
"Blended_3rd4th") ||
133 (dryscal_vert_adv_string ==
"Centered_4th") ||
134 (dryscal_vert_adv_string ==
"Upwind_5th" ) ||
135 (dryscal_vert_adv_string ==
"Blended_5th6th") ||
136 (dryscal_vert_adv_string ==
"Centered_6th") ||
137 (dryscal_vert_adv_string ==
"WENO3" ) ||
138 (dryscal_vert_adv_string ==
"WENOZ3" ) ||
139 (dryscal_vert_adv_string ==
"WENOMZQ3" ) ||
140 (dryscal_vert_adv_string ==
"WENO5" ) ||
141 (dryscal_vert_adv_string ==
"WENOZ5" ) ||
142 (dryscal_vert_adv_string ==
"WENO7" ) ||
143 (dryscal_vert_adv_string ==
"WENOZ7" ))
148 if ( (moistscal_horiz_adv_string ==
"Centered_2nd") ||
149 (moistscal_horiz_adv_string ==
"Upwind_3rd" ) ||
150 (moistscal_horiz_adv_string ==
"Blended_3rd4th") ||
151 (moistscal_horiz_adv_string ==
"Centered_4th") ||
152 (moistscal_horiz_adv_string ==
"Upwind_5th" ) ||
153 (moistscal_horiz_adv_string ==
"Blended_5th6th") ||
154 (moistscal_horiz_adv_string ==
"Centered_6th") ||
155 (moistscal_horiz_adv_string ==
"WENO3" ) ||
156 (moistscal_horiz_adv_string ==
"WENOZ3" ) ||
157 (moistscal_horiz_adv_string ==
"WENOMZQ3" ) ||
158 (moistscal_horiz_adv_string ==
"WENO5" ) ||
159 (moistscal_horiz_adv_string ==
"WENOZ5" ) ||
160 (moistscal_horiz_adv_string ==
"WENO7" ) ||
161 (moistscal_horiz_adv_string ==
"WENOZ7" ))
166 if ( (moistscal_vert_adv_string ==
"Centered_2nd") ||
167 (moistscal_vert_adv_string ==
"Upwind_3rd" ) ||
168 (moistscal_vert_adv_string ==
"Blended_3rd4th") ||
169 (moistscal_vert_adv_string ==
"Centered_4th") ||
170 (moistscal_vert_adv_string ==
"Upwind_5th" ) ||
171 (moistscal_vert_adv_string ==
"Blended_5th6th") ||
172 (moistscal_vert_adv_string ==
"Centered_6th") ||
173 (moistscal_vert_adv_string ==
"WENO3" ) ||
174 (moistscal_vert_adv_string ==
"WENOZ3" ) ||
175 (moistscal_vert_adv_string ==
"WENOMZQ3" ) ||
176 (moistscal_vert_adv_string ==
"WENO5" ) ||
177 (moistscal_vert_adv_string ==
"WENOZ5" ) ||
178 (moistscal_vert_adv_string ==
"WENO7" ) ||
179 (moistscal_vert_adv_string ==
"WENOZ7" ))
192 amrex::Print() <<
"Advection Choices: " << std::endl;
195 amrex::Print() << std::endl;
198 amrex::Print() << std::endl;
201 amrex::Print() << std::endl;
204 amrex::Print() << std::endl;
207 amrex::Print() << std::endl;
210 amrex::Print() << std::endl;
217 return "Centered_2nd";
221 return "Centered_4th";
225 return "Centered_6th";
247 if (adv_string ==
"Centered_2nd") {
249 }
else if ((adv_string ==
"Upwind_3rd") || (adv_string ==
"Blended_3rd4th")) {
251 }
else if (adv_string ==
"Centered_4th") {
253 }
else if (adv_string ==
"Upwind_5th" || (adv_string ==
"Blended_5th6th")) {
255 }
else if (adv_string ==
"Centered_6th") {
257 }
else if (adv_string ==
"WENO3") {
259 }
else if (adv_string ==
"WENOZ3") {
261 }
else if (adv_string ==
"WENO5") {
263 }
else if (adv_string ==
"WENOZ5") {
265 }
else if (adv_string ==
"WENOMZQ3") {
267 }
else if (adv_string ==
"WENO7") {
269 }
else if (adv_string ==
"WENOZ7") {
AdvType
Definition: ERF_IndexDefines.H:191
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real pp(amrex::Real y)
Definition: ERF_MicrophysicsUtils.H:219
Definition: ERF_AdvStruct.H:19
amrex::Vector< amrex::IntVect > zero_yflux
Definition: ERF_AdvStruct.H:301
void display()
Definition: ERF_AdvStruct.H:190
AdvType adv_type_convert_string_to_advtype(std::string adv_string)
Definition: ERF_AdvStruct.H:245
amrex::Real dryscal_vert_upw_frac
Definition: ERF_AdvStruct.H:295
AdvType moistscal_horiz_adv_type
Definition: ERF_AdvStruct.H:286
AdvType dycore_vert_adv_type
Definition: ERF_AdvStruct.H:283
AdvType moistscal_vert_adv_type
Definition: ERF_AdvStruct.H:287
amrex::Real moistscal_vert_upw_frac
Definition: ERF_AdvStruct.H:297
amrex::Real dycore_vert_upw_frac
Definition: ERF_AdvStruct.H:293
bool use_efficient_advection
Definition: ERF_AdvStruct.H:281
void init_params()
Definition: ERF_AdvStruct.H:21
std::string pp_prefix
Definition: ERF_AdvStruct.H:277
amrex::Real moistscal_horiz_upw_frac
Definition: ERF_AdvStruct.H:296
AdvType dryscal_horiz_adv_type
Definition: ERF_AdvStruct.H:284
amrex::Vector< amrex::IntVect > zero_xflux
Definition: ERF_AdvStruct.H:300
amrex::Vector< amrex::IntVect > zero_zflux
Definition: ERF_AdvStruct.H:302
AdvType dycore_horiz_adv_type
Definition: ERF_AdvStruct.H:282
bool have_zero_flux_faces
Definition: ERF_AdvStruct.H:303
amrex::Real dycore_horiz_upw_frac
Definition: ERF_AdvStruct.H:292
std::string adv_type_convert_int_to_string(AdvType adv_int)
Definition: ERF_AdvStruct.H:214
AdvType dryscal_vert_adv_type
Definition: ERF_AdvStruct.H:285
amrex::Real dryscal_horiz_upw_frac
Definition: ERF_AdvStruct.H:294