Skip to content
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

Need help with grid configuration #42

Closed
suyashbire1 opened this issue Aug 12, 2015 · 8 comments
Closed

Need help with grid configuration #42

suyashbire1 opened this issue Aug 12, 2015 · 8 comments

Comments

@suyashbire1
Copy link
Contributor

I have a setup with a spherical grid being forced by restoring buoyancy at the surface. This set up runs great.

For my future runs, because my focus is on the eastern boundary (EB), I want to set up the grid such that zonal resolution is high near EB and becomes coarse as we go towards the west. Not being familiar with mosaic, I decided to meddle around with MOM_grid_initialization.F90 to achieve this.

I have questions about dxC and dxB. In set_grid_metrics_spherical, dlon is constant throughout. I have a varying dlon, which is used to set up B points. I compute T points as simply the midpoints of successive B points. So, in this case, how do I calculate dxC and dxB? Should they be centered, forward or backward?

Here's the routine I modified from set_grid_metrics_spherical. I don't know if there is a better way to do this? May be mosaic? It would be great if someone more proficient with MOM6 could help me out here. Please excuse me if I'm asking for too much.

Suyash Bire
Stony Brook University

subroutine set_grid_metrics_spherical_nonuniformx(G, param_file)
  type(ocean_grid_type), intent(inout) :: G
  type(param_file_type), intent(in)    :: param_file
! Arguments:
!  (inout)   G - The ocean's grid structure.
!  (in)      param_file - A structure indicating the open file to parse for
!                         model parameter values.

!    Calculate the values of the metric terms that might be used
!  and save them in arrays.
!    Within this subroutine, the x- and y- grid spacings and their
!  inverses and the cell areas centered on h, q, u, and v points are
!  calculated, as are the geographic locations of each of these 4
!  sets of points.
  real :: PI, PI_180! PI = 3.1415926... as 4*atan(1)
  integer :: i, j, isd, ied, jsd, jed
  integer :: is, ie, js, je, Isq, Ieq, Jsq, Jeq, IsdB, IedB, JsdB, JedB
  integer :: i_offset, j_offset, N
  real :: grid_latT(G%jsd:G%jed), grid_latB(G%JsdB:G%JedB)
  real :: grid_lonT(G%isd:G%ied), grid_lonB(G%IsdB:G%IedB)
  real :: dLon,dLat,latitude,longitude,dL_di, dLonmin, dLonmax
  character(len=48)  :: mod  = "MOM_grid_init set_grid_metrics_spherical_nonuniformx"

  is = G%isc ; ie = G%iec ; js = G%jsc ; je = G%jec
  isd = G%isd ; ied = G%ied ; jsd = G%jsd ; jed = G%jed
  Isq = G%IscB ; Ieq = G%IecB ; Jsq = G%JscB ; Jeq = G%JecB
  IsdB = G%IsdB ; IedB = G%IedB ; JsdB = G%JsdB ; JedB = G%JedB
  i_offset = G%isd_global - isd; j_offset = G%jsd_global - jsd

  call callTree_enter("set_grid_metrics_spherical_nonuniformx(), MOM_grid_initialize.F90")

!    Calculate the values of the metric terms that might be used
!  and save them in arrays.
  PI = 4.0*atan(1.0); PI_180 = atan(1.0)/45.

  call get_param(param_file, mod, "AXIS_UNITS", G%axis_units, default="degrees")
  if (trim(G%axis_units) == "") G%axis_units = "degrees"
  if (trim(G%axis_units) .ne. "degrees") call MOM_error(FATAL, &
    "MOM_grid_init.F90, set_grid_metrics_simple_spherical_nonuniformx: "// &
    "axis_units must be degrees")
  call get_param(param_file, mod, "SOUTHLAT", G%south_lat, &
                 "The southern latitude of the domain.", units="degrees", &
                 fail_if_missing=.true.)
  call get_param(param_file, mod, "LENLAT", G%len_lat, &
                 "The latitudinal length of the domain.", units="degrees", &
                 fail_if_missing=.true.)
  call get_param(param_file, mod, "WESTLON", G%west_lon, &
                 "The western longitude of the domain.", units="degrees", &
                 default=0.0)
  call get_param(param_file, mod, "LENLON", G%len_lon, &
                 "The longitudinal length of the domain.", units="degrees", &
                 fail_if_missing=.true.)
  call get_param(param_file, mod, "RAD_EARTH", G%Rad_Earth, &
                 "The radius of the Earth.", units="m", default=6.378e6)

  call get_param(param_file, mod, "DLON_MIN", dLonmin, &
                 "The desired minimum grid size in x direction.", units="degrees", &
                 fail_if_missing=.true.)

  N = G%Domain%niglobal
! dLon = G%len_lon/G%Domain%niglobal
! dLonmin is the resolution near the eastern boundary and dLonmax is the resolution 
! near the western boundary. dLonmax has to be calculated based upon domain length,
! number of grid points and dLonmin.
  dLonmax = (PI*G%len_lon - 2.0*(N)*dLonmin)/((N)*(PI-2.0))
  dLat = G%len_lat/G%Domain%njglobal

  do j=G%JsgB,G%JegB
    latitude = G%south_lat + dLat*(REAL(J-(G%jsg-1)))
    G%gridLatB(J) = MIN(MAX(latitude,-90.),90.)
  enddo
  do j=G%jsg,G%jeg
    latitude = G%south_lat + dLat*(REAL(j-G%jsg)+0.5)
    G%gridLatT(j) = MIN(MAX(latitude,-90.),90.)
  enddo
   do i=G%IsgB,G%IegB
    dlon = (dLonmin-dLonmax)*sin(i*PI/2.0/REAL(N)) + dLonmax
    if (i==G%IsgB) then
      G%gridLonB(I) = G%west_lon + dLon*(REAL(I-(G%isg-1)))
    else
      G%gridLonB(I) = G%gridLonB(I-1) + dLon
    endif
  enddo
  do i=G%isg,G%ieg
!    dlon = (dLonmin-dLonmax)*sin(i*PI/2.0/REAL(N)) + dLonmax
    if (i==G%isg) then
      G%gridLonT(i) = (G%west_lon + G%gridLonB(I))/2.0
    else
      G%gridLonT(i) = (G%gridLonB(I) + G%gridLonB(I-1))/2.0
    endif
  enddo

  do J=JsdB,JedB
    latitude = G%south_lat + dLat* REAL(J+J_offset-(G%jsg-1))
    grid_LatB(J) = MIN(MAX(latitude,-90.),90.)
  enddo
  do j=jsd,jed
    latitude = G%south_lat + dLat*(REAL(j+J_offset-G%jsg)+0.5)
    grid_LatT(j) = MIN(MAX(latitude,-90.),90.)
  enddo
  do I=IsdB,IedB
    dlon = (dLonmin-dLonmax)*sin(I*PI/2.0/REAL(N)) + dLonmax
    if (i==IsdB) then
      grid_LonB(I) = G%west_lon + dLon*REAL(I+I_offset-(G%isg-1))
    else
      grid_LonB(I) = grid_LonB(I-1) + dLon
    endif
  enddo
  do i=isd,ied
!    dlon = (dLonmin-dLonmax)*sin(i*PI/2.0/REAL(N)) + dLonmax
    if (i==isd) then
      grid_LonT(i) = (G%west_lon + grid_LonB(I))/2.0
    else
      grid_LonT(i) = (grid_LonB(i) + grid_LonB(i-1))/2.0
    endif
  enddo
!  dL_di = (G%len_lon * 4.0*atan(1.0)) / (180.0 * G%Domain%niglobal)
  do J=JsdB,JedB ; do I=IsdB,IedB
    G%geoLonBu(I,J) = grid_lonB(I)
    G%geoLatBu(I,J) = grid_latB(J)

    dlon = (dLonmin-dLonmax)*sin(i*PI/2.0/REAL(N)) + dLonmax
! The following line is needed to reproduce the solution from
! set_grid_metrics_mercator when used to generate a simple spherical grid.
!   G%dxBu(I,J) = G%Rad_Earth * COS( G%geoLatBu(I,J)*PI_180 ) * dL_di
    G%dxBu(I,J) = G%Rad_Earth * dLon*PI_180 * COS( G%geoLatBu(I,J)*PI_180 )
    G%dyBu(I,J) = G%Rad_Earth * dLat*PI_180
    G%areaBu(I,J) = G%dxBu(I,J) * G%dyBu(I,J)
  enddo; enddo

  do J=JsdB,JedB ; do i=isd,ied
    G%geoLonCv(i,J) = grid_LonT(i)
    G%geoLatCv(i,J) = grid_latB(J)

     dlon = (dLonmin-dLonmax)*sin(i*PI/2.0/REAL(N)) + dLonmax
! The following line is needed to reproduce the solution from
! set_grid_metrics_mercator when used to generate a simple spherical grid.
!   G%dxCv(i,J) = G%Rad_Earth * COS( G%geoLatCv(i,J)*PI_180 ) * dL_di
    G%dxCv(i,J) = G%Rad_Earth * (dLon*PI_180) * COS( G%geoLatCv(i,J)*PI_180 )
    G%dyCv(i,J) = G%Rad_Earth * dLat*PI_180
  enddo; enddo

  do j=jsd,jed ; do I=IsdB,IedB
    G%geoLonCu(I,j) = grid_lonB(I)
    G%geoLatCu(I,j) = grid_LatT(j)

    dlon = (dLonmin-dLonmax)*sin(i*PI/2.0/REAL(N)) + dLonmax
! The following line is needed to reproduce the solution from
! set_grid_metrics_mercator when used to generate a simple spherical grid.
!   G%dxCu(I,j) = G%Rad_Earth * COS( G%geoLatCu(I,j)*PI_180 ) * dL_di
    G%dxCu(I,j) = G%Rad_Earth * dLon*PI_180 * COS( G%geoLatCu(i,J)*PI_180 )
    G%dyCu(I,j) = G%Rad_Earth * dLat*PI_180
  enddo; enddo

  do j=jsd,jed ; do i=isd,ied
    G%geoLonT(i,j) = grid_LonT(i)
    G%geoLatT(i,j) = grid_LatT(j)
    dlon = (dLonmin-dLonmax)*sin(i*PI/2.0/REAL(N)) + dLonmax
! The following line is needed to reproduce the solution from
! set_grid_metrics_mercator when used to generate a simple spherical grid.
!   G%dxT(i,j) = G%Rad_Earth * COS( G%geoLatT(i,j)*PI_180 ) * dL_di
    G%dxT(i,j) = G%Rad_Earth * dLon*PI_180 * COS( G%geoLatT(i,j)*PI_180 )
    G%dyT(i,j) = G%Rad_Earth * dLat*PI_180

!   latitude = G%geoLatCv(i,J)*PI_180             ! In radians
!   dL_di    = G%geoLatCv(i,max(jsd,J-1))*PI_180  ! In radians
!   G%areaT(i,j) = Rad_Earth**2*dLon*dLat*ABS(SIN(latitude)-SIN(dL_di))
    G%areaT(i,j) = G%dxT(i,j) * G%dyT(i,j)
  enddo; enddo

  call callTree_leave("set_grid_metrics_spherical_nonuniformx()")
end subroutine set_grid_metrics_spherical_nonuniformx
@adcroft
Copy link
Member

adcroft commented Aug 13, 2015

I think writing a custom grid routine for this task is the right approach. Generating mosaic files is not too hard but working with pre-processed files is more cumbersome if you want to change resolution regularly.

The expressions for gridLonB(I) in your code are assuming that dLon is uniform (because it is multiplied by REAL(I)).

    dlon = (dLonmin-dLonmax)*sin(i*PI/2.0/REAL(N)) + dLonmax
    if (i==G%IsgB) then
      G%gridLonB(I) = G%west_lon + dLon*(REAL(I-(G%isg-1)))
    else
      G%gridLonB(I) = G%gridLonB(I-1) + dLon
    endif

What you are trying to do is a cumulative sum of dLon from the western most edge - which is challenging in a parallel environment. Instead, I recommend doing the math to calculate longitudes directly from "I" and then calculate dLon as the difference. It is not as accurate (because dLon is the difference of two numbers) but it will at least be consistent. e.g. To get dx/di = b + c sin( pi*(i+G%isg)/N ) you want something like x = a + b ( i+G%isg ) + c N/pi cos( pi*(i+G%isg)/N ). In effect, this approximates your sin function as a difference of cos, which is quite reasonable here.

Concerning the dxBu and dxCu metrics, the declaration comments are precise and there is a schematic for those variables in MOM_grid_initialize.F90. To calculate them, I would apply the expression above as a difference of longitudes at T points to get the distance centered at U and Q points, and difference the longitudes at U/Q points to get the distance at T,V points. Make sense?

Your question has suggested an interesting idea. As is done when reading mosaics, we could analytically define the supergrid (twice the resolution of the model grid) and then aggregate the supergrid appropriately into the B, T and U grids. This would make specifying these grids a lot simpler; you would only provide the corner positions of the double-resolution grid. This last comment might not make sense without a lot more explanation but is here as a reminder to us to explore simplifying/unifying the grid initialization.

@suyashbire1
Copy link
Contributor Author

Thank you for your quick reply.

To get dx/di = b + c sin( pi_(i+G%isg)/N ) you want something like x = a + b ( i+G%isg ) + c N/pi cos( pi_(i+G%isg)/N ). In effect, this approximates your sin function as a difference of cos, which is quite reasonable here.

Yes, this is very clear, and I'll implement it as you suggest. I did a cumulative sum of all the dlons because I was unsure of what all the indices mean. For example, can you explain the difference between isg and isd? I see that isg is used for gridlon and isd for geolon. So, why is there a difference between gridlon and geolon? Also, why is geolon offset from gridlon?

Concerning the dxBu and dxCu metrics, the declaration comments are precise and there is a schematic for those variables in MOM_grid_initialize.F90. To calculate them, I would apply the expression above as a difference of longitudes at T points to get the distance centered at U and Q points, and difference the longitudes at U/Q points to get the distance at T,V points. Make sense?

Thank you very much. What should I do for dxBu/dxCu at the eastern boundary, because there would be no V/T points to the east of Q/U points there?

Your question has suggested an interesting idea. As is done when reading mosaics, we could analytically define the supergrid (twice the resolution of the model grid) and then aggregate the supergrid appropriately into the B, T and U grids.

Yes, this makes complete sense and is a much better way than taking midpoints of B points to get T points. In fact I was planning to do this myself. I just wanted to keep it simple for my first attempt.

@adcroft
Copy link
Member

adcroft commented Aug 13, 2015

Edit: the original response was wrong in defining isg and i_absolute and has been corrected.


  • isd is the locally referenced index of the start of the local array, ied is the end.
    • Declarations are typically isd:ied.
  • isc is the locally referenced index of the start of the computational part of the local array, isc is the end.
    • Most loops are over isc:iec, or variants.
  • The halo regions (copies of data from other processors) are the space isd:isc-1 and iec+1:ied.
  • Thus, isd<isc<iec<ied, but all these indexes are local to the processor. The same values will appear on different processors for uniform parallel decompositions.
  • isg is the absolute index of the first computational point in the global array and is always =1. ieg is the end.
    • Thus, i_absolute = (i - isd) + isd_global, when i is in a isc:iec or isd:ied loop.

The tricky part to get used to is that none of the above lets you work with a truly global array within one processor (which do not exist for good reason) so you always have to think about how to do things without relying on what might have happened earlier in a spatial loop (e.g. cumulative sums).

So, why is there a difference between gridlon and geolon? Also, why is geolon offset from gridlon?

geoLon_, geoLat_ are 2D arrays the model uses (e.g. to set Coriolis, do interpolation of forcing, ...). gridLon_, gridLat_ are 1D arrays use solely for labelling diagnostic axes. You'll notice, unlike most arrays in the model, they are declared using isg:ieg, i.e. have completely different address spaces to the rest of the model. I think this is part of the API for the diag_manager, though I'm not sure (it predates me).

Side note: It has been a point of confusion about the output, arising from the CF standard, that these values are the model coordinates because they have geographic values even when the grid is not necessarily a spherical grid. We have been considering deliberately changing these values because so much "CF compliant" software misuses this data.

What should I do for dxBu/dxCu at the eastern boundary, because there would be no V/T points to the east of Q/U points there?

It would be simplest to assume the grid is smooth and simply calculate those metrics as if the points did exist.


The original response before editting had

  • isg is the absolute index of the first computational point in the local array.
    • Thus, i_absolute = (i - isc) + isg, when i is in a isc:iec loop.

which is wrong (see above).

@suyashbire1
Copy link
Contributor Author

Thank you very much. Documentation in MOM_grid.F90 isn't very helpful when it comes to the difference between isc and isd. Your explanation makes it crystal clear that isd:ied also encompasses halo points along with computational points.

I still have doubts about isg. I understand that isg represents the global index of the first computational point in the local array. In that case, the following code from set_grid_metrics_spherical does not make sense to me.

  do i=G%isg,G%ieg
    G%gridLonT(i) = G%west_lon + dLon*(REAL(i-G%isg)+0.5)
  enddo

Shouldn't this just be :

  do i=G%isg,G%ieg
    G%gridLonT(i) = G%west_lon + dLon*(REAL(i)+0.5)
  enddo

Also, in the following snippet,

  do i=isd,ied
    grid_LonT(i) = G%west_lon + dLon*(REAL(i+I_offset-G%isg)+0.5)
  enddo

suppose, i=isd, then i+I_offset = G%isd_global, which is less then G%isg. So, we're subtracting something from G%west_lon, which is quite confusing.

In the following snippet, i and j are local indices. So how come they are being used to set global values in G%*?

  do j=jsd,jed ; do i=isd,ied
    G%geoLonT(i,j) = grid_LonT(i)
    G%geoLatT(i,j) = grid_LatT(j)

! The following line is needed to reproduce the solution from
! set_grid_metrics_mercator when used to generate a simple spherical grid.
    G%dxT(i,j) = G%Rad_Earth * COS( G%geoLatT(i,j)*PI_180 ) * dL_di
!   G%dxT(i,j) = G%Rad_Earth * dLon*PI_180 * COS( latitude )
    G%dyT(i,j) = G%Rad_Earth * dLat*PI_180

!   latitude = G%geoLatCv(i,J)*PI_180             ! In radians
!   dL_di    = G%geoLatCv(i,max(jsd,J-1))*PI_180  ! In radians
!   G%areaT(i,j) = Rad_Earth**2*dLon*dLat*ABS(SIN(latitude)-SIN(dL_di))
    G%areaT(i,j) = G%dxT(i,j) * G%dyT(i,j)
  enddo; enddo

Please pardon me if I'm asking too many questions. I have spent a lot of time trying to come up with explanations myself but the indices still baffle me.

@adcroft
Copy link
Member

adcroft commented Aug 14, 2015

I stand corrected about isg - it is not the global index of the first computational cell. isg is always=1 and ieg is always the global number of points. I was explaining how I would have defined things if I'd been involved in defining them - my bad! As it is, the code is creating global arrays which is something we want to avoid and will have to fix.

Here are the values for a 4 processor break down of double_gyre that uses a spherical grid with a halo of 4:

PE= 0 isd= 1 isc= 5 isg= 1 isd_global= -3
PE= 0 ied= 30 iec= 26 ieg= 44
PE= 1 isd= 1 isc= 5 isg= 1 isd_global= 19
PE= 1 ied= 30 iec= 26 ieg= 44
PE= 2 isd= 1 isc= 5 isg= 1 isd_global= -3
PE= 2 ied= 30 iec= 26 ieg= 44
PE= 3 isd= 1 isc= 5 isg= 1 isd_global= 19
PE= 3 ied= 30 iec= 26 ieg= 44

So the absolute index calculated from I = isc:iec (or I = isd:ied) is:
i_absolute = (i - isd) + isd_global

so that PEs 0 and 3 have at i=isc i_absolute=1 and PEs 1 and 2 have at i=isc i_absolute=23

The models uses what is known as "north-east indexing" (u,v,q points are north-east of h,T points with the same index) so you will need to subtract 0.5 for the real(i) location of h-points.

I will correct my previous response also.

@adcroft
Copy link
Member

adcroft commented Aug 14, 2015

Update on full-size global arrays: @Hallberg-NOAA , @MJHarrison-GFDL and I were looking at the interfaces to the diag_manager code (FMS) and have concluded that the axis data for diagnostics does need to be global. If such an array is needed for the diag_manager then there is no argument for not making use of the same during the grid initialization. This is not to say global 2D arrays should be allowed; @Zhi-Liang successfully removed any use of global 2D arrays when reading mosaics which were found to be causing slow initializations and to sometimes not fit in memory for high-resolution models.

@suyashbire1
Copy link
Contributor Author

Thank you very much. That cleared it all up. So here's the final routine and it works like a charm.

EDIT: The final routine is here. It makes use of this function.
This routine now allows for variation of grid resolution in both x and y directions. Also, you can now specify grid modes:

  • 111 for uniform grid
  • 131 for finer grids at the boundaries
  • 313 for finer grid in the middle
  • 123 for finer grid at the western/southern boundary
  • 321 for finer grid at the eastern/northern boundary.

adcroft added a commit that referenced this issue Sep 2, 2016
- NOAA-GFDL/SIS2@44382d6 Merge branch 'user/nnz/fix_restart_issue42' into dev/master
- NOAA-GFDL/SIS2@39eb2ff Merge branch 'dev/master' into user/nnz/fix_restart_issue42
- NOAA-GFDL/SIS2@23d7cb6 Merge branch 'user/nnz/fix_openmp_issues_20160829' into dev/master
- NOAA-GFDL/SIS2@81ba1ed Fix restart issue #42
- NOAA-GFDL/SIS2@503bfe2 Fix compilation issues with -openmp
@adcroft
Copy link
Member

adcroft commented Sep 30, 2016

Global indexing is described in the documentation at http://noaa-gfdl.github.io/MOM6/APIs/db/dde/Horizontal_indexing.html so I am closing this issue.

@adcroft adcroft closed this as completed Sep 30, 2016
Hallberg-NOAA added a commit that referenced this issue Apr 24, 2018
  Merged an extensive set of changes from dev/ncar onto dev/master.  The list of
commits include:
 - NOAA-GFDL/MOM6@77a97ba Merge branch 'NCAR-dev/ncar' into dev/master
 - NOAA-GFDL/MOM6@8050958 Merge pull request #55 from gustavo-marques/deallocate_diabatic
 - NOAA-GFDL/MOM6@648f31b Replace cvmix with CVMix
 - NOAA-GFDL/MOM6@4b21263 Merge pull request #54 from gustavo-marques/deallocate_diabatic
 - NOAA-GFDL/MOM6@165a5eb Comment call diabatic_driver_end
 - NOAA-GFDL/MOM6@9f4ce3a Un-comment call diabatic_driver_end
 - NOAA-GFDL/MOM6@4671c07 Comment call diabatic_driver_end to check if Travis still fails
 - NOAA-GFDL/MOM6@e90fbe9 Return if CS is not associated
 - NOAA-GFDL/MOM6@65527d6 Set useKPP = .false. (default) and comment call to diag_grid_storage_end
 - NOAA-GFDL/MOM6@2800524 Uncomment calls to deallocate KPP related arrays
 - NOAA-GFDL/MOM6@dab30b6 Merge pull request #52 from alperaltuntas/initialize_tidal_ctrl_vars
 - NOAA-GFDL/MOM6@334f124 Merge remote-tracking branch 'gmarques/fix_travis_deallocation' into initialize_tidal_ctrl_vars
 - NOAA-GFDL/MOM6@5153869 initialize boolean control vars in tidal mixing mod
 - NOAA-GFDL/MOM6@43b7968 Commenting out call to diabatic_driver_end in MOM.F90
 - NOAA-GFDL/MOM6@dde5a59 Commenting out deallocation of KPP related arrays
 - NOAA-GFDL/MOM6@dc82c48 Return call if CS is not allocated
 - NOAA-GFDL/MOM6@dabe31b Update CVMix
 - NOAA-GFDL/MOM6@5640daf Attempt to fix deallocating unallocated arrays
 - NOAA-GFDL/MOM6@93eee52 Merge pull request #49 from gustavo-marques/update_cvmix
 - NOAA-GFDL/MOM6@d07120c Remove trailing space
 - NOAA-GFDL/MOM6@69bf4fa Updates CVMix
 - NOAA-GFDL/MOM6@5f19507 Merge pull request #48 from gustavo-marques/fix_cvmix_convection
 - NOAA-GFDL/MOM6@caf1d1e Fixes bug and renames variables
 - NOAA-GFDL/MOM6@869d32f Merge pull request #47 from alperaltuntas/introduce_cvmix_tidal
 - NOAA-GFDL/MOM6@01578c5 fix tidal_mixing_init return
 - NOAA-GFDL/MOM6@86e7074 Merge pull request #46 from alperaltuntas/introduce_cvmix_tidal
 - NOAA-GFDL/MOM6@bf322c8 add tidal mixing-specific prandtl number
 - NOAA-GFDL/MOM6@81a5ef8 Merged with latest master
 - NOAA-GFDL/MOM6@696462c MOM_tidal_mixing. cleaanup
 - NOAA-GFDL/MOM6@3e7cab8 debug calculate_cvmix_tidal
 - NOAA-GFDL/MOM6@78bb40c Merge pull request #44 from NCAR/adding_cvmix
 - NOAA-GFDL/MOM6@4dde603 Avoided a possible seg. fault in set_diffusivity_end
 - NOAA-GFDL/MOM6@36f7a06 Changed kv to a pointer since it might not always be associated
 - NOAA-GFDL/MOM6@0ce9980 By pass reading BULKMIXEDLAYER via get_param
 - NOAA-GFDL/MOM6@1218973 Raname variables Kd -> kd_lay; visc%Kv_slow - > kv
 - NOAA-GFDL/MOM6@ea813b8 add tidal diagnostics for cvmix
 - NOAA-GFDL/MOM6@648018e Rename kv_conv -> kv_conv_const; kd_conv -> kd_conv_const
 - NOAA-GFDL/MOM6@c1acec8 Add vertical background viscosity into visc%Kv_slow
 - NOAA-GFDL/MOM6@a2498a1 Changed name in register_diag_field kd_shear -> kd_shear_cvmix; kv_shear -> kv_shear_cvmix
 - NOAA-GFDL/MOM6@37ca38f Renamed kd_bkgnd_3d -> kd_bkgnd; kv_bkgnd_3d -> kv_bkgnd
 - NOAA-GFDL/MOM6@105094f Add viscosities due to convection into visc%Kv_slow
 - NOAA-GFDL/MOM6@e544290 Allocated/deallocate visc%Kv_slow
 - NOAA-GFDL/MOM6@801a86a Added variable Kv_slow in visc type
 - NOAA-GFDL/MOM6@8977888 Move tidal diagnostics to MOM_tidal_mixing module
 - NOAA-GFDL/MOM6@2430f6e correct tidal energy file dir
 - NOAA-GFDL/MOM6@a3155d6 Add tidal parameter consistency checks.
 - NOAA-GFDL/MOM6@80c33a4 Replaced Kv_turb -> Kv_shear
 - NOAA-GFDL/MOM6@644f200 Replaced Kv_turb -> Kv_shear
 - NOAA-GFDL/MOM6@6a2e864 Replaced Kd_turb -> Kd_shear and Kv_turb -> Kv_shear
 - NOAA-GFDL/MOM6@7376f49 update Kd
 - NOAA-GFDL/MOM6@69ab998 Added a unique Prandtl # for convection and background
 - NOAA-GFDL/MOM6@4cac1e1 Renamed variables (KH to kd; KM to kv) and added diagnostics
 - NOAA-GFDL/MOM6@e992292 Added calculate_cvmix_tidal interface
 - NOAA-GFDL/MOM6@2c451c8 Merge pull request #43 from alperaltuntas/dev/ncar
 - NOAA-GFDL/MOM6@d1cee89 Add timestep initializations to calculate_cvmix_tidal
 - NOAA-GFDL/MOM6@7a81871 Re-structured MOM_bkgnd_mixing
 - NOAA-GFDL/MOM6@3fcdb4c Update to new CVMix tag with tidal mixing changes
 - NOAA-GFDL/MOM6@f361002 Read in tidal energy dissipation
 - NOAA-GFDL/MOM6@4e8dd5a Added a if statement to check if Int_tide_dissipation and Bryan_Lewis are used at the same time.
 - NOAA-GFDL/MOM6@8ef5a1b Renamed Bryan&Lewis coeffs and added a 3D array for depth
 - NOAA-GFDL/MOM6@08db85c Deleted code that has been moved to MOM_bkgnd_mixing.F90
 - NOAA-GFDL/MOM6@1be0248 Added first version of MOM_bkgnd_mixing
 - NOAA-GFDL/MOM6@1116f49 Fixed a problem in cvmix_init_bkgnd_BryanLewis_low
 - NOAA-GFDL/MOM6@83089ff Updated CVMix
 - NOAA-GFDL/MOM6@a101e49 Reduced the numbers of characters in a line
 - NOAA-GFDL/MOM6@53004ec Deleted module MOM_diffConvection
 - NOAA-GFDL/MOM6@0bb899a uncomment cvmix_init_tidal
 - NOAA-GFDL/MOM6@22902de Mv add_int_tide_diffusivity to tidal_mixing module
 - NOAA-GFDL/MOM6@c34ab63 Move diags back from MOM_tidal_mixing to MOM_set_diffusivity (for now)
 - NOAA-GFDL/MOM6@76546aa Move tidal mixing initialization to MOM_tidal_mixing
 - NOAA-GFDL/MOM6@95406ff Rename MOM_cvmix_tidal module as MOM_tidal_mixing (for now)
 - NOAA-GFDL/MOM6@c2dea88 update diabatic driver for MOM_cvmix_tidal module
 - NOAA-GFDL/MOM6@bb7917a comment out call ocn_domain_mct to avoid uninitialized vars for now. more comprehensive cleanup is to come.
 - NOAA-GFDL/MOM6@941bfb6 Updated mixing coeff. due to convection
 - NOAA-GFDL/MOM6@ba2a0a4 Added function cvmix_conv_is_used and register restart fields.
 - NOAA-GFDL/MOM6@c78ac9a Add the new module MOM_cvmix_tidal
 - NOAA-GFDL/MOM6@1d850a6 Changed hbl to an optional pointer; do not apply mixing due to convection within the boundary layer
 - NOAA-GFDL/MOM6@afd8f59 Fixed a bug in the deallocate call
 - NOAA-GFDL/MOM6@a77d114 Fixed a bug in the deallocate call
 - NOAA-GFDL/MOM6@f12702c Dealocate memory via cvmix_shear_end and changed some var names to snake_case convention
 - NOAA-GFDL/MOM6@a209b7a Added a call to diabatic_driver_end
 - NOAA-GFDL/MOM6@e84f706 Fix array allocattion/dealocation
 - NOAA-GFDL/MOM6@7f6d8f1 Added call to KPP_get_BLD
 - NOAA-GFDL/MOM6@fc00e77 Added function to copy KPP surface boundary layer depth into BLD
 - NOAA-GFDL/MOM6@c99e94b Updates visc%Kd_turb and visc%Kv_turb after convection is applied
 - NOAA-GFDL/MOM6@97152b1 Adding first version of convection calls via CVMix
 - NOAA-GFDL/MOM6@dca5736 Add comments for adding additonal CVMix components and clean module
 - NOAA-GFDL/MOM6@c6327d6 Copy OBLdepth from KPP into visc%MLD and Hml
 - NOAA-GFDL/MOM6@71ff26b Changed multi-word names from camelCase to snake_case
 - NOAA-GFDL/MOM6@8095e8f Merge pull request #42 from gustavo-marques/merge-dev-master-2018-02-28
 - NOAA-GFDL/MOM6@bd80a20 Merge branch 'dev/master' into merge-dev-master-2018-02-28
 - NOAA-GFDL/MOM6@2f79ffc Merge pull request #41 from gustavo-marques/merge_dev_master_20feb2018
Hallberg-NOAA added a commit that referenced this issue Apr 25, 2018
  Merged an extensive set of changes from dev/ncar onto dev/master, and then
from dev/master into dev/gfdl.  The list of commits include:
 - NOAA-GFDL/MOM6@3c70582 Merge branch 'dev/master' into dev/gfdl
 - NOAA-GFDL/MOM6@77a97ba Merge branch 'NCAR-dev/ncar' into dev/master
 - NOAA-GFDL/MOM6@8050958 Merge pull request #55 from gustavo-marques/deallocate_diabatic
 - NOAA-GFDL/MOM6@648f31b Replace cvmix with CVMix
 - NOAA-GFDL/MOM6@4b21263 Merge pull request #54 from gustavo-marques/deallocate_diabatic
 - NOAA-GFDL/MOM6@165a5eb Comment call diabatic_driver_end
 - NOAA-GFDL/MOM6@9f4ce3a Un-comment call diabatic_driver_end
 - NOAA-GFDL/MOM6@4671c07 Comment call diabatic_driver_end to check if Travis still fails
 - NOAA-GFDL/MOM6@e90fbe9 Return if CS is not associated
 - NOAA-GFDL/MOM6@65527d6 Set useKPP = .false. (default) and comment call to diag_grid_storage_end
 - NOAA-GFDL/MOM6@2800524 Uncomment calls to deallocate KPP related arrays
 - NOAA-GFDL/MOM6@dab30b6 Merge pull request #52 from alperaltuntas/initialize_tidal_ctrl_vars
 - NOAA-GFDL/MOM6@334f124 Merge remote-tracking branch 'gmarques/fix_travis_deallocation' into initialize_tidal_ctrl_vars
 - NOAA-GFDL/MOM6@5153869 initialize boolean control vars in tidal mixing mod
 - NOAA-GFDL/MOM6@43b7968 Commenting out call to diabatic_driver_end in MOM.F90
 - NOAA-GFDL/MOM6@dde5a59 Commenting out deallocation of KPP related arrays
 - NOAA-GFDL/MOM6@dc82c48 Return call if CS is not allocated
 - NOAA-GFDL/MOM6@dabe31b Update CVMix
 - NOAA-GFDL/MOM6@5640daf Attempt to fix deallocating unallocated arrays
 - NOAA-GFDL/MOM6@93eee52 Merge pull request #49 from gustavo-marques/update_cvmix
 - NOAA-GFDL/MOM6@d07120c Remove trailing space
 - NOAA-GFDL/MOM6@69bf4fa Updates CVMix
 - NOAA-GFDL/MOM6@5f19507 Merge pull request #48 from gustavo-marques/fix_cvmix_convection
 - NOAA-GFDL/MOM6@caf1d1e Fixes bug and renames variables
 - NOAA-GFDL/MOM6@869d32f Merge pull request #47 from alperaltuntas/introduce_cvmix_tidal
 - NOAA-GFDL/MOM6@01578c5 fix tidal_mixing_init return
 - NOAA-GFDL/MOM6@86e7074 Merge pull request #46 from alperaltuntas/introduce_cvmix_tidal
 - NOAA-GFDL/MOM6@bf322c8 add tidal mixing-specific prandtl number
 - NOAA-GFDL/MOM6@81a5ef8 Merged with latest master
 - NOAA-GFDL/MOM6@696462c MOM_tidal_mixing. cleaanup
 - NOAA-GFDL/MOM6@3e7cab8 debug calculate_cvmix_tidal
 - NOAA-GFDL/MOM6@78bb40c Merge pull request #44 from NCAR/adding_cvmix
 - NOAA-GFDL/MOM6@4dde603 Avoided a possible seg. fault in set_diffusivity_end
 - NOAA-GFDL/MOM6@36f7a06 Changed kv to a pointer since it might not always be associated
 - NOAA-GFDL/MOM6@0ce9980 By pass reading BULKMIXEDLAYER via get_param
 - NOAA-GFDL/MOM6@1218973 Raname variables Kd -> kd_lay; visc%Kv_slow - > kv
 - NOAA-GFDL/MOM6@ea813b8 add tidal diagnostics for cvmix
 - NOAA-GFDL/MOM6@648018e Rename kv_conv -> kv_conv_const; kd_conv -> kd_conv_const
 - NOAA-GFDL/MOM6@c1acec8 Add vertical background viscosity into visc%Kv_slow
 - NOAA-GFDL/MOM6@a2498a1 Changed name in register_diag_field kd_shear -> kd_shear_cvmix; kv_shear -> kv_shear_cvmix
 - NOAA-GFDL/MOM6@37ca38f Renamed kd_bkgnd_3d -> kd_bkgnd; kv_bkgnd_3d -> kv_bkgnd
 - NOAA-GFDL/MOM6@105094f Add viscosities due to convection into visc%Kv_slow
 - NOAA-GFDL/MOM6@e544290 Allocated/deallocate visc%Kv_slow
 - NOAA-GFDL/MOM6@801a86a Added variable Kv_slow in visc type
 - NOAA-GFDL/MOM6@8977888 Move tidal diagnostics to MOM_tidal_mixing module
 - NOAA-GFDL/MOM6@2430f6e correct tidal energy file dir
 - NOAA-GFDL/MOM6@a3155d6 Add tidal parameter consistency checks.
 - NOAA-GFDL/MOM6@80c33a4 Replaced Kv_turb -> Kv_shear
 - NOAA-GFDL/MOM6@644f200 Replaced Kv_turb -> Kv_shear
 - NOAA-GFDL/MOM6@6a2e864 Replaced Kd_turb -> Kd_shear and Kv_turb -> Kv_shear
 - NOAA-GFDL/MOM6@7376f49 update Kd
 - NOAA-GFDL/MOM6@69ab998 Added a unique Prandtl # for convection and background
 - NOAA-GFDL/MOM6@4cac1e1 Renamed variables (KH to kd; KM to kv) and added diagnostics
 - NOAA-GFDL/MOM6@e992292 Added calculate_cvmix_tidal interface
 - NOAA-GFDL/MOM6@2c451c8 Merge pull request #43 from alperaltuntas/dev/ncar
 - NOAA-GFDL/MOM6@d1cee89 Add timestep initializations to calculate_cvmix_tidal
 - NOAA-GFDL/MOM6@7a81871 Re-structured MOM_bkgnd_mixing
 - NOAA-GFDL/MOM6@3fcdb4c Update to new CVMix tag with tidal mixing changes
 - NOAA-GFDL/MOM6@f361002 Read in tidal energy dissipation
 - NOAA-GFDL/MOM6@4e8dd5a Added a if statement to check if Int_tide_dissipation and Bryan_Lewis are used at the same time.
 - NOAA-GFDL/MOM6@8ef5a1b Renamed Bryan&Lewis coeffs and added a 3D array for depth
 - NOAA-GFDL/MOM6@08db85c Deleted code that has been moved to MOM_bkgnd_mixing.F90
 - NOAA-GFDL/MOM6@1be0248 Added first version of MOM_bkgnd_mixing
 - NOAA-GFDL/MOM6@1116f49 Fixed a problem in cvmix_init_bkgnd_BryanLewis_low
 - NOAA-GFDL/MOM6@83089ff Updated CVMix
 - NOAA-GFDL/MOM6@a101e49 Reduced the numbers of characters in a line
 - NOAA-GFDL/MOM6@53004ec Deleted module MOM_diffConvection
 - NOAA-GFDL/MOM6@0bb899a uncomment cvmix_init_tidal
 - NOAA-GFDL/MOM6@22902de Mv add_int_tide_diffusivity to tidal_mixing module
 - NOAA-GFDL/MOM6@c34ab63 Move diags back from MOM_tidal_mixing to MOM_set_diffusivity (for now)
 - NOAA-GFDL/MOM6@76546aa Move tidal mixing initialization to MOM_tidal_mixing
 - NOAA-GFDL/MOM6@95406ff Rename MOM_cvmix_tidal module as MOM_tidal_mixing (for now)
 - NOAA-GFDL/MOM6@c2dea88 update diabatic driver for MOM_cvmix_tidal module
 - NOAA-GFDL/MOM6@bb7917a comment out call ocn_domain_mct to avoid uninitialized vars for now. more comprehensive cleanup is to come.
 - NOAA-GFDL/MOM6@941bfb6 Updated mixing coeff. due to convection
 - NOAA-GFDL/MOM6@ba2a0a4 Added function cvmix_conv_is_used and register restart fields.
 - NOAA-GFDL/MOM6@c78ac9a Add the new module MOM_cvmix_tidal
 - NOAA-GFDL/MOM6@1d850a6 Changed hbl to an optional pointer; do not apply mixing due to convection within the boundary layer
 - NOAA-GFDL/MOM6@afd8f59 Fixed a bug in the deallocate call
 - NOAA-GFDL/MOM6@a77d114 Fixed a bug in the deallocate call
 - NOAA-GFDL/MOM6@f12702c Dealocate memory via cvmix_shear_end and changed some var names to snake_case convention
 - NOAA-GFDL/MOM6@a209b7a Added a call to diabatic_driver_end
 - NOAA-GFDL/MOM6@e84f706 Fix array allocattion/dealocation
 - NOAA-GFDL/MOM6@7f6d8f1 Added call to KPP_get_BLD
 - NOAA-GFDL/MOM6@fc00e77 Added function to copy KPP surface boundary layer depth into BLD
 - NOAA-GFDL/MOM6@c99e94b Updates visc%Kd_turb and visc%Kv_turb after convection is applied
 - NOAA-GFDL/MOM6@97152b1 Adding first version of convection calls via CVMix
 - NOAA-GFDL/MOM6@dca5736 Add comments for adding additonal CVMix components and clean module
 - NOAA-GFDL/MOM6@c6327d6 Copy OBLdepth from KPP into visc%MLD and Hml
 - NOAA-GFDL/MOM6@71ff26b Changed multi-word names from camelCase to snake_case
 - NOAA-GFDL/MOM6@8095e8f Merge pull request #42 from gustavo-marques/merge-dev-master-2018-02-28
 - NOAA-GFDL/MOM6@bd80a20 Merge branch 'dev/master' into merge-dev-master-2018-02-28
 - NOAA-GFDL/MOM6@2f79ffc Merge pull request #41 from gustavo-marques/merge_dev_master_20feb2018
marshallward added a commit that referenced this issue Apr 14, 2021
- NOAA-GFDL/MOM6@fc75e0fa4 Merge pull request #1370 from Hallberg-NOAA/F_case_file_output
- NOAA-GFDL/MOM6@e8e8abab9 Merge remote-tracking branch 'hallberg/F_case_file_output' into F_case_file_output
- NOAA-GFDL/MOM6@96f1d1e89 Use allocatable types in write_ocean_geometry_files
- NOAA-GFDL/MOM6@983824a69 Merge branch 'dev/gfdl' into F_case_file_output
- NOAA-GFDL/MOM6@5fe51b18e Merge pull request #1369 from Hallberg-NOAA/SIS2_IO_upgrades
- NOAA-GFDL/MOM6@0eb47b25a +More consistent treatment of input_filename = 'F'
- NOAA-GFDL/MOM6@03b997b88 +Enhanced support for novel axes in MOM_io
- NOAA-GFDL/MOM6@7ec08cd9b Merge pull request #1365 from marshallward/corad_vec_v2
- NOAA-GFDL/MOM6@dc66dd8a7 Merge branch 'dev/gfdl' into corad_vec_v2
- NOAA-GFDL/MOM6@c5c74419d Merge pull request #1364 from jkrasting/downsampled_diag_fix
- NOAA-GFDL/MOM6@a5fb36503 Merge branch 'dev/gfdl' into downsampled_diag_fix
- NOAA-GFDL/MOM6@d485a5123 Merge pull request #1363 from Hallberg-NOAA/SIS2_infra_support
- NOAA-GFDL/MOM6@b413f25c5 Merge branch 'SIS2_infra_support' of github.com:Hallberg-NOAA/MOM6 into SIS2_infra_support
- NOAA-GFDL/MOM6@358da7cc4 Corrected comments describing CT_copy_data
- NOAA-GFDL/MOM6@ad0bc3c41 Merge branch 'dev/gfdl' into SIS2_infra_support
- NOAA-GFDL/MOM6@fae570d0a Merge branch 'main' into main_to_gfdl
- NOAA-GFDL/MOM6@5f063044c Fixed downsampling summation for more diag types
- NOAA-GFDL/MOM6@c549ae9d9 Merge pull request #1358 from NOAA-GFDL/dev-gfdl-main-candidate-2021-03-26
- NOAA-GFDL/MOM6@ad372fdc2 Merge branch 'dev/gfdl' into SIS2_infra_support
- NOAA-GFDL/MOM6@d1dc6b5ba Coriolis: Improved coradcalc vectorization
- NOAA-GFDL/MOM6@2b6d3e115 Merge pull request #1362 from marshallward/horvisc_diag_to_stack
- NOAA-GFDL/MOM6@9792b2346 Fixed downsampling for x:sum y:point z:point diags
- NOAA-GFDL/MOM6@665cd9a3b Merge branch 'dev/gfdl' into horvisc_diag_to_stack
- NOAA-GFDL/MOM6@b6c7fdb02 change default value of use_mommesh as true
- NOAA-GFDL/MOM6@6d4a48390 Merge pull request #1360 from Hallberg-NOAA/fewer_timelevels
- NOAA-GFDL/MOM6@3c1cb2efd +Add MOM_domains interfaces needed by SIS2
- NOAA-GFDL/MOM6@cfa59aab1 +Add coupler_types interfaces needed by SIS2
- NOAA-GFDL/MOM6@97f111779 Merge branch 'dev/gfdl' into fewer_timelevels
- NOAA-GFDL/MOM6@813fc7975 Merge pull request #1359 from Hallberg-NOAA/FMS2_io_writes
- NOAA-GFDL/MOM6@2ffea27be MOM_hor_visc: Variables moved to stack
- NOAA-GFDL/MOM6@4fd380747 Merge branch 'dev/gfdl' into FMS2_io_writes
- NOAA-GFDL/MOM6@c62d51f9d Remove inappropriate timelevel arguments
- NOAA-GFDL/MOM6@13f1e70f5 Merge pull request #1356 from GEOS-ESM/bugfix/sanAkel/output-b-grid-currents
- NOAA-GFDL/MOM6@6c2b944e2 Merge branch 'dev/gfdl' into bugfix/sanAkel/output-b-grid-currents
- NOAA-GFDL/MOM6@67b03e324 Merge pull request #1353 from Hallberg-NOAA/less_checksums
- NOAA-GFDL/MOM6@5669d4360 Merge branch 'dev/gfdl' into less_checksums
- NOAA-GFDL/MOM6@b044be8ee Merge branch 'dev/gfdl' into FMS2_io_writes
- NOAA-GFDL/MOM6@fe9b2a106 Merge pull request #1352 from Hallberg-NOAA/FMS2_io
- NOAA-GFDL/MOM6@f6105cb22 Merge branch 'dev/gfdl' into FMS2_io
- NOAA-GFDL/MOM6@95ad9372b Fix distributed reads of checksums using FMS2_io
- NOAA-GFDL/MOM6@81c48cbf6 Merge pull request #5 from marshallward/FMS2_io_writes
- NOAA-GFDL/MOM6@ba643bde2 Explicit domain decomposition of horizontal axes
- NOAA-GFDL/MOM6@7bdecbc62 Add missing ".nc" to FMS2 output filenames
- NOAA-GFDL/MOM6@fad7e0d4a Merge branch 'dev/gfdl' into bugfix/sanAkel/output-b-grid-currents
- NOAA-GFDL/MOM6@17afc2b5e A call to pass_vector(...) is needed to correctly do a halo exchange before getting currents in A- or B-grid staggering. Now added.
- NOAA-GFDL/MOM6@3fe07d4c6 +Move FMS2 read helper routines into MOM_io_infra
- NOAA-GFDL/MOM6@2579d0771 Merge pull request #4 from gustavo-marques/less_checksums_mct_nuopc
- NOAA-GFDL/MOM6@66ac81057 Only write checksums from root PE MCT/NUOPC caps
- NOAA-GFDL/MOM6@84d5e2176 +FMS2 reads for ints & MOM_read_data_fms2 cleanup
- NOAA-GFDL/MOM6@4843c6c4d Merge branch 'dev/gfdl' into FMS2_io
- NOAA-GFDL/MOM6@03e174e14 Removed FMS2 MOM_axis and MOM_write_field_fms2
- NOAA-GFDL/MOM6@255233ba3 Added code to write via FMS2 interfaces
- NOAA-GFDL/MOM6@0fdc5c438 Correct warnings from categorize_axis
- NOAA-GFDL/MOM6@f89ddeaa8 +Add edge_axis argument to write_metadata_axis
- NOAA-GFDL/MOM6@ee0152f26 +Separate MOM_interp_infra axistype from MOM_io
- NOAA-GFDL/MOM6@09173f7dc Only write checksums from root PE for FMS_cap
- NOAA-GFDL/MOM6@30b057116 Merge branch 'dev/gfdl' into FMS2_io
- NOAA-GFDL/MOM6@91232095d Merge branch 'dev/gfdl' into FMS2_io
- NOAA-GFDL/MOM6@aab2ad645 +Add ability to read fields via FMS2 interfaces
- NOAA-GFDL/MOM6@23a78d2f6 Clean up in MOM_restart.F90
- NOAA-GFDL/MOM6@c68fedfea +Change arguments to MOM_register_variable_axes
- NOAA-GFDL/MOM6@0ba1aa53e +Simplified read_data_fms2 and write_field_fms2
- NOAA-GFDL/MOM6@f2459ec21 Merge branch 'user/jml/add_fms2io_to_MOM_restart' of https://github.com/wrongkindofdoctor/MOM6 into FMS2_io
- NOAA-GFDL/MOM6@a07757314 Explicitly set (1x1) io_domain as a default
- NOAA-GFDL/MOM6@d4531ca37 Duplicated infra/FMS1 into infra/FMS2
- NOAA-GFDL/MOM6@f806579bc Correct module use statements in infra/FMS1
- NOAA-GFDL/MOM6@2e46ea6d7 removed errant .true. in save_restart call
- NOAA-GFDL/MOM6@809b3ac52 added local logical variables to save restart wrapper that are set using the use_fms2 and write_ic flags if present to avoid invalid memory reference error added str_len argument to register_variable_attribute calls
- NOAA-GFDL/MOM6@a74c7eaba changed FMS release to 2020.03-beta1
- NOAA-GFDL/MOM6@5c2daa5da converted save_restart and restore_state to interface that call versions of the routines with the fms-io or fms2-io interfaces added module use statments for fms2_io and MOM_io helper routines to MOM_restart added use_fms2=.true. arguments to save_restart and restore_state calls added write_ic=.true. to the save_restart call in MOM.F90
- NOAA-GFDL/MOM6@40047fa50 Merge pull request #66 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@c8695c621 Merge pull request #65 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@0cf3cb9c9 Merge pull request #64 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@de7f95a57 Merge pull request #63 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@50c353935 Merge pull request #62 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@cbdcf8a52 Create hola_tierra.yml
- NOAA-GFDL/MOM6@763b17650 Merge pull request #61 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@ff3412651 Merge pull request #60 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@cea55fec4 Merge pull request #59 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@b8eee455f Merge branch 'dev/gfdl' of github.com:NOAA-GFDL/MOM6 into dev/gfdl
- NOAA-GFDL/MOM6@46b8f0fd5 Merge pull request #58 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@ff1a27f59 Merge pull request #57 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@496617cb1 Merge pull request #56 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@e9281f40e Merge pull request #55 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@4a5613400 Merge pull request #54 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@86c2a7dfa Merge pull request #53 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@c24535733 Merge pull request #52 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@8d7be6866 Merge pull request #51 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@7adcc9037 Merge pull request #50 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@aff2a13ab Merge pull request #49 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@477d9f85d Merge pull request #48 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@cee0a2166 Merge pull request #47 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@12dccaf8a Merge pull request #46 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@7dbca83ff Merge pull request #44 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@162ca970b Merge pull request #43 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@abaf004cb Merge pull request #42 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@075ab81e5 Merge pull request #41 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@e072bc7cc Merge in latest dev/gfdl updates (#40)
- NOAA-GFDL/MOM6@cae4cfd05 Merge branch 'dev/gfdl' of github.com:wrongkindofdoctor/MOM6 into dev/gfdl
- NOAA-GFDL/MOM6@ece60c11e Merge branch 'NOAA-GFDL-dev/gfdl' into dev/gfdl
- NOAA-GFDL/MOM6@3e27e4793 Merge branch 'dev/gfdl' of git://github.com/NOAA-GFDL/MOM6 into NOAA-GFDL-dev/gfdl
- NOAA-GFDL/MOM6@59109032e Merge pull request #38 from wrongkindofdoctor/revert-37-dev/gfdl
- NOAA-GFDL/MOM6@3c15a0c11 Revert "Merge in dev/gfdl updates (#37)"
- NOAA-GFDL/MOM6@855d7069d Merge in dev/gfdl updates (#37)
- NOAA-GFDL/MOM6@2c32568b7 merge in latest dev/gfdl updates (#36)
- NOAA-GFDL/MOM6@09bcebcfe Merge pull request #35 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@124a071e4 Merge pull request #33 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@a427676bd Merge pull request #32 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@0b874f32c Merge pull request #31 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@a5386da98 Merge pull request #30 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@5b2852cde Merge pull request #28 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@22c586562 Merge pull request #27 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@f9b5a7fca Merge pull request #26 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@577208343 Merge pull request #25 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@5589d8cc3 Merge pull request #24 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@aa11e1f66 Merge pull request #23 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@b5e5c48a6 Merge pull request #22 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@911d0a240 Merge pull request #21 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@601eb679c Merge pull request #20 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@b4fd53be9 Merge pull request #19 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@f6879f425 Merge pull request #18 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@139ab1fc0 Merge pull request #17 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@a0c80dcf3 Merge pull request #16 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@42cca4f46 Merge pull request #15 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@a1c556b7f Merge pull request #14 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@f5bc54b67 Merge pull request #13 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@6ffc8976f Merge pull request #12 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@30d35a3c6 Merge pull request #11 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@1304880fb Merge pull request #10 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@522069b31 Merge pull request #9 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@1bbc8de13 Merge pull request #8 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@9aa2aaeb1 Merge pull request #7 from NOAA-GFDL/dev/gfdl
- NOAA-GFDL/MOM6@b7f50fcbf Merge remote-tracking branch 'GFDL_MOM6/dev/gfdl' into dev/gfdl merge in latest MOM updates * GFDL_MOM6/dev/gfdl: (220 commits)   Update cache dir for /lustre/f2   Update cache dir for /lustre/f2   Calculate height-related diagnostics in Z   Set coord_adapt and coord_slight parameters in H   Corrected comments in build_zlike_column   +Pass max_depth to initialize_regridding in Z   Corrected comments in build_sigma_column   Combined scaling factors in build_adapt_column   Clarified comments in Idealized_Hurricane   +Recast MOM_diag_to_Z to work in units of Z   +Recast MOM_ALE_sponge to work in units of Z   +Added m_to_Z arg to horiz_interp_and_extrap_tracer   Find energetic_PBL column height changes in Z   +Find diapyc_energy_req column height changes in Z   Use local variables to rescale in MOM_Point_Accel   Recast MOM_sum_output to work in units of Z   Simplify MOM_diagnostics code   +Rescale depth inside of MEKE_lengthScales_0d   +Add conversion argument to register_static_field   Rescale values reported by PointAccel   ...
- NOAA-GFDL/MOM6@975262dc9 Merge pull request #5 from NOAA-GFDL/dev/gfdl
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants