From Tanya Otte (Otte.Tanya@epamail.epa.gov):
Here are the mods that you need to make to MCIP to add PRESF to the output. As I explained in the reply via m3list, you will only be outputting the levels above the surface (such that the number of full levels output is really one fewer than exist, but matches the number of mid-layers in the model). The pressure at the lowest full-level (the surface) is in METCRO2D in variable PRSFC.
Caveat 1: I have not tested this; it's mostly just looking at what I believe the changes are that need to be made.
Caveat 2: A new version of MCIP will be released with CMAQv5.0 (any day now). You may want to wait for it. **MCIP v4.0 was released Feb 2012**
Caveat 3: If you are using the tipping bucket for precip in WRF, let me know, and I'll give you the mods. The current release of MCIP does not handle the tipping bucket; it's off by default, and it's fairly new.
Also, I think there's a bug in what I put into MCIPv4.0, so I'm working to fix that now. If you have the tipping bucket on, you'll need different code in other parts of MCIP (not related to PRESF).
** NOTE: When I tested this with MCIP 3.6, met was from WRF v3.0, so no tipping bucket**
In mcoutcom_mod.f90:
1. Increase parameter MC3INDEX by 1.
2. Define a REAL, POINTER for "pressf_c" and "pressf_b" (follow x3htf_c and x3htf_b).
3. Add "PRESF" to the array for MC3VNAME.
4. Add units (Pa) to the array for MC3UNITS.
5. Add a text description to the array MC3VDESC.
In alloc_ctm.f90
1. Associate the pointers for PRESSF_C and PRESSF_B under the
allocate statements for MC3 and MB3. Again, follow x3htf_c and x3htf_b.
In dealloc_ctm.f90
1. Nullify the pointers for PRESSF_C and PRESSF_B just before the deallocate statements for MC3 and MB3. Follow x3htf_c and x3htf_b.
In metcro.f90
1. Change the allocate size for DUMARAY0 so that the fourth dimension is changed from "4+" to "5+" in three places.
2. In the triple-loop that fills DUMARAY0, fill dumaray0(c,r,k,5)
with xpresf(c,r,k).
3. Change the filling of XWWIND into the 6th element of DUMARAY0.
4. Change the filling of XTKE into the 6+iwout element of DUMARAY0.
5. Add a call to collapx for xpresf; follow the entry for
xdensaf.
6. Add an entry to fill pressf_c from xpresf; follow x3htm_c. (Note that xpresf is indexed 0:NLAYS rather than 1:NLAYS+1.)
7. Four times: Add an entry to fill pressf_b from xpresf; follow
x3htm_b. (One time for each of the four boundaries.)
8. Refill xpresf with elements from DUMARAY0 using the fourth
dimension of 5.
9. Change the links on the fourth dimension of DUMARAY0 for xwwind and xtke from 5 to 6 and 5+iwout, respectively (toward bottom of code).
Note, in the end, the pressure levels we had for OMI were only mid-layer heights, so due to that restriction we couldn't use PRESF afterall, and had to interpolate mid-level to mid-level and then, estimate OMI full-level pressure heights. Should OMI (or other satellite data) be distributed with full pressure heights, this could come in handy, but not for the current WHIPS-CMAQ-MATLAB comparison scheme.
ReplyDelete