-
Notifications
You must be signed in to change notification settings - Fork 1
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Standard names: *ocean model grid information* #219
Comments
Thank you for your proposal. These terms will be added to the cfeditor (http://cfeditor.ceda.ac.uk/proposals/1) shortly. Your proposal will then be reviewed and commented on by the community and Standard Names moderator. |
Dear Jenny @jmecki It is interesting that standard names haven't previously been defined for the horizontal size of gridcells. Usually this information is not necessary to store as a data variable, because you can calculate it when needed from the bounds of the latitude and longitude coordinate variables. Please could you describe why these standard names are needed? Best wishes and thanks Jonathan |
I'd note also that these would only apply for north-east aligned rectangular grids. maybe there's a more general standard name that could be used? |
Thank you for your responses, it's the first time I've proposed variable names so I might have missed something when I looked things up. In response to Jonathan's comment, while you can compute it from the latitude and longitude (bounds/vertices) models often artificially narrow channels, for example the Strait of Gibraltar and in the Indonesian Throughflow region. This is especially true for models that have ocean model resolution similar to the models used in CMIP6 (i.e. 1 degree), therefore giving incorrect values. In response to Chris Barker's comment, what I had in mind were the lengths/widths of the grid boxes which if they are on an irregular grid then they wouldn't be strictly northward or eastward but along the model grid lines. Maybe the names: However, how length and width are defined might be unclear. |
very interesting -- I had no idea. So yes, this does make sense to me as something to capture in a standard_name Is "gridbox" the correct term, however? though I have idea what a bette tem might be: channel_width? or some such?
yes, that's a trick -- "x" and "y" -- I can't recall if those terms are currently used to mean "logical x [y]" rather than literal. |
The convention so far in standard names is to use x and y, e.g., "ocean_heat_x_transport: "x" indicates a vector component along the grid x-axis, positive with increasing x" |
thanks @atreguier -- then "x" and "y" do seem to mean the correct thing in this context. |
Could this information be provided using the mesh topology attributes defined in Appendix K of the CF conventions? |
Dear Jenny I'm a bit puzzled. In answer to my question above you agreed you can get gridcell dimensions from the cell bounds, but you say that these are not necessarily the "right" answers. Surely they are the true answers for the grid, even if not for reality. Is it perhaps not the gridcell dimensions that you want to record and give standard names to, but the real distances across straits etc? Best wishes Jonathan |
Hi Jenny, I would find it helpful if you could describe how a model actually treats the processes in these "special" grid cells where somehow the equations governing the ocean are modified to take into account a channel that is narrower than the what the cell can represent. Is there a reference for how they are treated? thanks, |
Dear Karl, dear Jenny, |
Thank you Anne-Marie, I agree with what you are saying and I am also most familiar with NEMO. The variables I'm looking for are basically the equivalent of the NEMO variables 'e1t, e2t, e1u, e2u, etc...' while the e3* variables are a bit easier to estimate (I also opened the issue 220 for these). Not having this specifically has lead to difficulties in estimating transports in models. I think just having widths of channels will not be sufficient because the channels with artificial narrowing might end up being different in different models and resolutions. I tried estimating the grid box dx/e1* and dy/e2* (lengths and widths) from the information provided in the CMIP5 and CMIP6 database at T,U and V points and have found that several models have had this issue but mainly the NEMO based ones. |
This issue has had no activity in the last 30 days. Accordingly:
Standard name moderators are also reminded to review @feggleton @japamment @efisher008 |
Has there been a decision made about having a name for this? It would be useful to have one even if all models might not be able to provide this field. Would a possible suggestion now be: ocean_gridbox_x_length_at _t_point |
Dear Jenny Speaking for myself, I don't think it's yet clear what these quantities actually are. Please could you describe them in geophysical terms, as we need for standard names? How do you use them in a calculation, for example? That might clarify the issue. I think that "gridbox lengths" would generally be understood as the distance between coordinates, as I interpreted it before. Also, I don't think we would mention T, U and V points in standard names. CF doesn't have a notion of grid arrangements, to which that refers. (Maybe it should, as has been discussed a few times, but that's not the issue here.) I think we need to give a name to a distance needed for some purpose; the gridpoints it applies to should be obvious from the coordinates or bounds. Please don't give up. These discussions are often difficult, but usually achieve a good result! Best wishes Jonathan |
Hi, I agree that having these terms would be great to recompute fluxes, or to compute fluxes over non-standard straits. François |
I'm trying to understand how your model handles a single grid cell or column of single cells (representing a strait). For a strait separating a northern and southern body of water, are the equations applied there the same as for grid cells elsewhere (but, of course, with no east-west transport)? Or is that grid cell narrowed to the size of the actual strait? If the equations are applied to a grid cell that is narrower than the nearby cells, then I would say your grid is not a simple latxlon grid, but rather a special 2-d grid which is mostly identical to a latxlon grid except for a few grid cells. You could represent the true grid as described in section 5.2 of the conventions and define the cell shapes following the approach described is section 7.1 under Bounds for 2-D coordinate variables with 4-sided cells. The true area of the grid cell (as represented in the model) could then be calculated using these bounds for 2-D coordinate variables. You wouldn't be able to correctly calculate the grid cell area (which is useful for several purposes) if your longitude bounds as defined in the model formulation are not correctly given everywhere (even for the strait cells). Of course, I might be misinterpreting how the model handles these special "strait" grid cells. It would seem if it solves the equations assuming the strait cells are narrower than nearby cells, then I would think there would be real problems calculating the vertical exchanges between the ocean and the atmosphere. Are those calculations also performed assuming the cells are narrow? If so, then the land model must have wider than normal cells on either side of the strait. That seems unlikely, so maybe the above is all wrong. |
@Mecki Hi Jenny, Somehow I got an email from you that was, I think, supposed to be posted here, so I've copied it here:
Perhaps something has been lost in the rendering. (width of strait)*(depth of strait) will give you the cross-sectional area (in the x-z plane) spanning the strait (separating a more-or-less northern ocean basin from a southern ocean basin). To get a volume transport you would multiply this by a velocity, but that's missing from your formula. The following remains unclear to me: Has the velocity reported in model output been calculated by the model on a regular grid and then inflated to account for the fact that the strait is narrower than the grid cell? If that's the case, then I see that you must know what the model assumed to be the true strait width if you want to calculate a volume transport. |
I edited the TeX in the post -- I think I got it right, but please do correct it if I misunderstood what it was supposed to be. But as to the topic -- in some models (ROMS), what is computed is the flux through a gird cell -- though it may be provided in the output as a velocity -- in that case, you'd need to know the cross sectional area of the channel -- and it that doesn't match the area of the cell face, you'd need to know that -- is that what this is for? |
Thanks, I was really struggling with the latex in github and accidentally posted it before it was finished. I will post a more complete response once I have it typed up better. |
Hi All, Sorry it took me a while to respond. A simple example for which I would use dx on the v grid points would be to compute the volume transport through a section as follows: where you would have to compute dx on the v points either from the vertices or the centre points of the grid points of the grid boxes where the computation would differ depending on the Arakara grid used in the model. While this isn't too complex it gets more complex when changing to temperature/heat and salinity/freshwater transports where you have to move all the data (temperature, salinity and velocity) to the same grid point, typically along the grid box edge of the t-points. This again is dependent on the model grid used and having dx, dy and dz on the different grid points (i.e. t,u,v,etc). In terms of the comment related to ROMS, yes this is something that it would be used for. Furthermore, as mentioned before if the grid boxes have an artificially narrowed point for some channels, often estimating dx, dy, and dz give the wrong value leading to spikes that shouldn't be there... In Mecking and Drijfhout 2023 in the methods we made the comment: 'In global and Indo-Pacific computations of OHT there are spikes at the latitudes which are impacted by Indonesian throughflow in some models. Several ocean models which do not have high enough horizontal resolution to resolve the narrow ocean channels, like the ones present in the Indonesian throughflow, artificially narrow these channels but only on either the U- or V-grid points. The information available in the CMIP5/6 archives only contains information about the grid size on the T-grid points. For the models where these spikes occur, we removed the data from the latitudes where the spikes appear.' While it is possible to compute dx and dy from the grid box vertices this is not always provided and it adds extra computations and may not give the correct values, especially if there are artificially narrows channels. Please correct me if I'm wrong, I'm not a model developer, but from the ocean model code I have looked at, in both Arakawa-B and Arakawa-C grid models they used dx and dy values at the t,u and v grid points in the computations as opposed to the vertices. I believe that it would still be very useful to have names for these variables even if there might be work arounds. |
I think that "artificially narrows channels" is the key point here -- otherwise, the grid is well defined, and I don't think we need standard names. But if there's been an adjustment in the model, such that you can't compute the correct flux from the grid geometry, then you absolutely need to know the "virtual" channel size. So I support the idea -- but have no opinion about how to exactly spell the name :-) |
Hi everybody, I just realized that this procedure to artificially narrow some straits is well explained in the NEMO manual , with a nice figure. Here it is |
Dear Jenni @jmecki et al. Thanks for explaining. I agree that working out dx and dy on velocity points from the tracer grid is quite intricate, so it's convenient to record them as data variables with metadata to identify them. We can regard dx and dy as metrics of the grid. We already have a standard name for dz, namely However, if straits have effective widths that differ from what the gridpoint coordinates indicate, that's not a metric of the grid, and you can't work them out. I don't exactly understand your equation, because of three appearances of v on the right-hand side. I think we can write the northward volume transport in where is the contribution from gridbox This is the ratio of the Best wishes Jonathan PS How marvellous that you can write |
Hi All, sorry about all the v's in the equation. That's my bad, in my head I think of dx on the v grid points as dxv and similarly dy as dyv and dz as dzv I should have been more precise and defined this. I like Jonathan's suggestion about using |
what does NEMO call these in its docs? are there "wordier" terms than I really don't like this:
|
@ChrisBarker-NOAA. Are you happy with |
Thanks for everyone's input. I think that using cell_x_width_for_ocean_transport might be a bit too specific and just addressing one use for these values. Having dx and dy available (along with thkcello) would make it easier to compute things like section averages. For accurate computations of these things it is best to use the same values as the ones used in the ocean model and for some models the values of dx and dy are part of the grid definition of the model. Furthermore, I don't understand why the dx and dy values can't have a name defined for them, even if they can for the most part be derived from the grid box verticies, however fiddly that might be and dependent on Arakawa grid used. Do we need to have a specific purpose of a variable to have a name defined for it? dx and dy ultimately have several uses not just transport computations. My preferred suggestion is @ChrisBarker-NOAA suggestion of effective_cell_x_width . This will eliminate the suggesting that these values are only needed for transport computations. Another thing, the values of dx and dy differ on the t,u,v,,w and f grid points. Do we need anything that specifies the grid point? If so, that would also be needed for cell_thickness, since that differs on the different grid points. How is the naming for this typically handled? Just in the short variable name? |
It would be difficult for those not "in the know" to understand what is meant by "effective cell width". What other quantities reported from a model need this modified width to compute a section average? |
Dear Jenny @jmecki I agree with Karl, because standard names are intended to identify well-defined geophysical quantities, so that data-users can tell whether variables from different sources are the "same thing". "Effective cell width" is generic. In other models or applications, other quantities might be described like that. That is why I suggested "for transport", as a description of the purpose for which this version of the cell width is used. Karl's question is useful: what other kinds of calculation use this effective cell width? If my suggestion is too specific, we can probably think of something more general that describes the physical purposes for this quantity. I think the dx and dy values computed from the gridpoints would be called No, we would not indicate in the standard name which of the grids it applies to, because the grid is described by the coordinates. For different grids they could be given different PCDMI names (I don't know the practice with that), but they'd have the same CF standard name, because a physical quantity is the same regardless of the locations of its gridpoints. Best wishes and thanks for pursuing this Jonathan |
Hello, Just a specific comment: Would the names Thanks, |
Yes, I agree that |
This is critical, actually -- it may well be that gird metrics are by definition model specific -- ROMS may use it differently than NEMO, etc. So perhaps a standard name is simply not appropriate for this kind of thing. "Effective cell width" is generic. In other models or applications, other quantities might be described like that. That is why I suggested "for transport" The generic name is deliberate, because the width (or length) or the cell is used for multiple calculations -- and outside of standard names anyway, we avoid having two ways to describe the same thing in CF -- i.e. generic is what we are going for :-) But again, this may be pointing to this not being appropriate for a standard name -- are there any other analogous standard names for things like grid metrics? @jmecki: I suggest you take a look at: https://sgrid.github.io/sgrid/ It isn't (and may never be) a part of CF, but it is supposed to be CF compatible, and that may be a better place to define these sorts of metrics. It's managed here: https://github.com/sgrid/sgrid And has not seen any activity for a while, but it is being used, at least a bit :-) |
@ChrisBarker-NOAA. Yes, "we avoid having two ways to describe the same thing in CF". That applies to standard names as well. We take great care to avoid giving a new standard name to a quantity that already has one. But the cell length according to the grid is not the same thing as the "artificially narrowed" cell length for ocean transport calculations (or some other description that better describes what it is used for). That is why they need different standard names. Yes, it is consistent with past practice to give standard names to grid metrics. There are existing standard names of |
I think we need to wait to hear from @jmecki as to how the cell length quantity is used (besides in computing transports) before we can come up with a more general term that is still specific enough to be able to distinguish it meaningfully from simply "cell_length". |
The question is whether the cell metric at hand is used in all (many, most?) models the same way -- or at least having the same meaning. If so, then a standard name may make sense, if not, then maybe not. |
Hi all, As a suggestion, how about defining names for |
Thanks for your comment, Adam @atb299. If it's easier to provide a scale factor than the modified cell length, we could certainly consider giving it a standard name. However, I still think it's necessary for the standard name to mention what the factor is intended for. The purpose of standard names is to indicate what quantities are "the same thing". Two quantities, both named "cell length scale factor", which come e.g. one from an ocean model, the other from a land ice model, are unlikely to refer to the geoscientific concept, so they shouldn't have the same standard name. If "ocean transport" is too limited to describe all the purposes for the scaled "artificially narrowed" cell length in NEMO, how would you characterise it, generally? |
@JonathanGregory, @taylor13, I've spent a little time today trying to find out whether there are use cases beyond ocean transports, such as reducing volume or area of a cell which could affect calculation of volume integrals or surface fluxes for example. I've not found any yet, but that doesn't mean they don't exist. I have found that it's not just NEMO that this affects. Edited scale factors are mentioned in NorESM. |
thanks -- and I"m sure there are other model's that do similar things as well. The question is whether all (most, many?) models do these kinds of things the same way -- that is, is there a single "thing" that we can define a standard name for -- or is the meaning of these these grid metric adjustments particular to each model? I've done a lot of work with ROMS results for example -- and I go to the ROMS docs to make sure I understand what the outputs mean. maybe they are the same for all Arakawa C grids -- or all grids? but I doubt it :-( I guess what I'm getting at is that it may not be possible to have a. standard name for everything -- and that's OK. |
Nice find, @atb299! There is one sentence in the NorESM documentation of real relevance:
So apparently, one internal model use of the scale factors is to compute more realistic velocities (and shears), so that the mixing parameterization yields a more realistic result. I think this still falls under the category of "for ocean transport" (if velocity can be thought of as a "transport of non-dimensional 'stuff' of unit value"). |
Here is a couple of thoughts from an outside perspective. My understanding is that this scale factor is used to mimic a more realistic channel geometry (in particular its cross-section) than what is allowed by a particular model grid resolution. This is done to allow the model to produce more realistic through-channel flow. As such this factor is not directly adjusting the flow as such. How about |
How was this issue resolved when the name " |
I think I disagree with this statement. The cell widths are used by the model to compute transports/fluxes through the face of the model cell. If you try to use a different cell width (e.g. the distance between two f points on an Arakawa C grid) to compute transports using velocities offline you will get the wrong answer. Unless the cell widths used by the model are provided it is (almost) impossible to accurately calculate transports for these cells offline. |
That's a good question. I don't remember, but I suspect it wasn't discussed. The
Certainly you could, but that not be a CF convention, which doesn't standardise the contents of Best wishes Jonathan |
Hi All, Sorry for not responding in a while. As suggested by @atb299 I think the names cell_x_width and cell_y_width seem like a good choice. It is a 2D time invariant variable which can be defined for different grid points (i.e. T,U and V points) Also, to add to the discussion similar to cell_thickness how was cell_area accepted? What still needs to be done to have a decision for a name for this variable or what information is still required? Kind Regards, |
Hi Jenny, The problem is that in NEMO these quantities must be utilized only to compute transports, and thus are required at U and V points of the C grid. The width used to compute tracers (heat and salt content, for example) are not the same and are not modified in the straits, as shown by the pages of the NEMO manual I added to my nov 9 post. I don't know how it is done in NorESM, but NEMO is used by many groups in CMIP and thus the names should at least be clear for NEMO users. I would favor rather something like cell_x_width_velocity_scale_factor and cell_y_width_velocity_scale_factor, a bit like @atb299 but with "velocity" added. this would give the hint to the user that they are applicable to velocities. Anyway, the best if for modellers to output directly umo and vmo (the mass transports) on the native grid. These are among the baseline variables, I think. But unfortunately you found out that the groups didn't all do it for CMIP6. Anne Marie |
Thanks Anne Marie, I'm still unclear why it is discouraged to include cell_x_width and cell_y_width in a similar way to how areacello is included in the CMIP output. It would be very useful to have them output for all the grid points (i.e. T, U, V points), regardless of whether or not the model uses narrowed straits. They would also be useful on T-points not just U and V points since it would make computing section averages much easier. Also, in CMIP models areacello is only available on T-points. However, I think that whether or not these variables are included or should be included in CMIP output is another issue. And as a first step would be to have a standard name for them, whether or not it's output is another issue. It would be great to have one in a similar way areacello has a name. Jenny |
I would understand "scale factor" to mean something dimensionless. Are the quantities lengths or scaling factors, Jenny? If they are lengths, then |
Hi Jonathan, The quantities I was thinking of are lengths not scale factors. The example of the narrow channels are a region where having these variables would be extremely useful. But I think that a 2D fields containing dx (cell_x_width), and dy (cell_y_width) for every grid box and that can be defined for each grid point (i.e. T,U,V) would be useful none the less. The relationship with areacello should be dx*dy = areacello. I hope that makes more sense. I agree that length is clearer than width. Jenny |
Shall we add four new standard names, then:
2D fields of these quantities would be fine in CF. What should be archived in CMIP isn't a CF question, of course. |
Hi Jonathan, That sounds like a good plan. Only one thing to be aware of is cell_x_length_for_velocity and cell_y_length_for_velocity will be different on C-grid but the same on B-grid models. Jenny |
Yes. CF doesn't have a way to describe Arakawa grid relationships, though it's been mentioned a few times. However, if you provide these cell-length fields as 2D, the user can compute some things, just by using the metric on the appropriate grid, without having to understand Arakawa grids. |
I agree, making having these variables very handy :) |
Before submitting an issue be sure you have read and understood the rules for vocabulary changes and review the guidance for constructing standard names
Please note that it is fine to group together a number of proposals in a single GitHub issue (i.e. it is not necessary to open a separate issue for each vocabulary term). Change proposals should include the following information as applicable.
Proposer's name
Jenny Mecking
Date
Sept. 8 2024
For each term please try to give the following:
- Term
eastward_ocean_gridbox_length_at _t_point
- Description
The length of the gridbox in the east/west direction for the t-point gridbox
- Units (If applicable).
m
- Term
northward_ocean_gridbox_length_at _t_point
- Description
The length of the gridbox in the north/south direction for the t-point gridbox (i.e dy on t-points)
- Units (If applicable).
m
- Term
eastward_ocean_gridbox_length_at _u_point
- Description
The length of the gridbox in the east/west direction for the u-point gridbox
- Units (If applicable).
m
- Term
northward_ocean_gridbox_length_at _u_point
- Description
The length of the gridbox in the north/south direction for the t-point gridbox (i.e dy on u-points)
- Units (If applicable).
m
- Term
eastward_ocean_gridbox_length_at _v_point
- Description
The length of the gridbox in the east/west direction for the v-point gridbox
- Units (If applicable).
m
- Term
northward_ocean_gridbox_length_at _v_point
- Description
The length of the gridbox in the north/south direction for the t-point gridbox (i.e dy on v-points)
- Units (If applicable).
m
The text was updated successfully, but these errors were encountered: