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

Users set solo driver forcing time records per day #793

Merged

Conversation

Hallberg-NOAA
Copy link
Member

Refactored the solo_driver version of MOM_surface_forcing to modify how the time levels to read from forcing files, with a series of 11 new runtime parameters (WIND_FILE_DAYS_PER_RECORD, etc.) giving the user to specify how many days each time record spans (for positive values) or the number of time records in the file per day (for negative values). If these parameters are set to 31, the month returned by the FMS get_date() function sets the time level. If they are set to 0 (the default) the previous behavior is obtained, in which the time level is determined from the number of records in the file. To always take the first record in the file, set these parameters to large values (greater than 1000000 will always work, but in practice smaller values do the same thing). By default all answers are bitwise identical, but there are up to 10 new runtime parameters in some MOM_parameter_doc files for cases that have WIND_CONFIG = "file" or BUOY_CONFIG = "file".

The list of new runtime parameters is WIND_FILE_DAYS_PER_RECORD, LONGWAVE_FILE_DAYS_PER_RECORD, SHORTWAVE_FILE_DAYS_PER_RECORD, EVAPORATION_FILE_DAYS_PER_RECORD, LATENTHEAT_FILE_DAYS_PER_RECORD, SENSIBLEHEAT_FILE_DAYS_PER_RECORD, RAIN_FILE_DAYS_PER_RECORD, SHORTWAVE_FILE_DAYS_PER_RECORD, RUNOFF_FILE_DAYS_PER_RECORD, SSTRESTORE_FILE_DAYS_PER_RECORD and SALINITYRESTORE_FILE_DAYS_PER_RECORD.

The problem identified in #631 is addressed by this commit, and that issue can be closed once this commit is merged onto the main branch of MOM6. This PR is a more comprehensive and general solution than the one proposed in #648 , and that PR should be closed after this one is merged into dev/gfdl.

  Refactored the solo_driver version of MOM_surface_forcing to modify how the
time levels to read from forcing files, with a series of 11 new runtime
parameters (WIND_FILE_DAYS_PER_RECORD, etc.) giving the user to specify how many
days each time record spans (for positive values) or the number of time records
in the file per day (for negative values).  If these parameters are set to 31,
the month returned by the FMS `get_date()` function sets the time level.  If
they are set to 0 (the default) the previous behavior is obtained, in which the
time level is determined from the number of records in the file.  To always take
the first record in the file, set these parameters to large values (greater than
1000000 will always work, but in practice smaller values do the same thing).  By
default all answers are bitwise identical, but there are up to 10 new runtime
parameters in some MOM_parameter_doc files for cases that have `WIND_CONFIG =
"file"` or `BUOY_CONFIG = "file"`.

  The list of new runtime parameters is `WIND_FILE_DAYS_PER_RECORD`,
`LONGWAVE_FILE_DAYS_PER_RECORD`, `SHORTWAVE_FILE_DAYS_PER_RECORD`,
`EVAPORATION_FILE_DAYS_PER_RECORD`, `LATENTHEAT_FILE_DAYS_PER_RECORD`,
`SENSIBLEHEAT_FILE_DAYS_PER_RECORD`, `RAIN_FILE_DAYS_PER_RECORD`,
`SHORTWAVE_FILE_DAYS_PER_RECORD`, `RUNOFF_FILE_DAYS_PER_RECORD`,
`SSTRESTORE_FILE_DAYS_PER_RECORD` and  `SALINITYRESTORE_FILE_DAYS_PER_RECORD`.

  The problem identified in github.com/NOAA-GFDL/issues/631 is addressed by
this commit, and that issue can be closed once this commit is merged onto the
main branch of MOM6.
@Hallberg-NOAA Hallberg-NOAA added bug Something isn't working enhancement New feature or request labels Jan 2, 2025
@raphaeldussin raphaeldussin self-assigned this Jan 6, 2025
@raphaeldussin
Copy link

this code improves over the bits it replaces, for more advance file handling one can use wind_forcing, buoy_forcing = data_override

@adcroft
Copy link
Member

adcroft commented Jan 8, 2025

Copy link
Member

@adcroft adcroft left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Per @raphaeldussin recommendation

@Hallberg-NOAA
Copy link
Member Author

This has passed pipeline testing at https://gitlab.gfdl.noaa.gov/ogrp/mom6ci/MOM6/-/pipelines/25986 with the expected warnings about new runtime parameters.

@Hallberg-NOAA Hallberg-NOAA merged commit 82d44fb into NOAA-GFDL:dev/gfdl Jan 9, 2025
10 checks passed
@Hallberg-NOAA Hallberg-NOAA deleted the solo_forcing_timelevels branch January 19, 2025 03:19
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working enhancement New feature or request
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants