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" ))
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real pp(amrex::Real y)
Definition: ERF_MicrophysicsUtils.H:219
amrex::Vector< amrex::IntVect > zero_yflux
Definition: ERF_AdvStruct.H:301
AdvType adv_type_convert_string_to_advtype(std::string adv_string)
Definition: ERF_AdvStruct.H:245
bool use_efficient_advection
Definition: ERF_AdvStruct.H:281
std::string pp_prefix
Definition: ERF_AdvStruct.H:277
amrex::Vector< amrex::IntVect > zero_xflux
Definition: ERF_AdvStruct.H:300
amrex::Vector< amrex::IntVect > zero_zflux
Definition: ERF_AdvStruct.H:302
bool have_zero_flux_faces
Definition: ERF_AdvStruct.H:303