forked from CICE-Consortium/CICE
-
Notifications
You must be signed in to change notification settings - Fork 13
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
Update CICE for latest Consortium/main #56
Merged
DeniseWorthen
merged 58 commits into
NOAA-EMC:emc/develop
from
DeniseWorthen:feature/updcice
Jan 23, 2023
Merged
Update CICE for latest Consortium/main #56
DeniseWorthen
merged 58 commits into
NOAA-EMC:emc/develop
from
DeniseWorthen:feature/updcice
Jan 23, 2023
Conversation
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
* Rename several variables to make compatible with C-grid names, strairxU, strairyU, strtltxU, strtltyU, strintxU, strintyU, taubxU, taubyU, strocnxU, strocnyU, fmU, TbU, waterxU, wateryU, forcexU, forceyU, aiU Move iceumask, icenmask, iceemask from ice_flux to ice_grid Make dyn_prep2, stepu, stepuv_CD, stepv_C, implicit_solver, and anderson_soler argument names a little more generic/specific Inline boxslotcyl velocity calculation * remove boxslotcyl_data_vel * update documentation * Additional updates to change to upper case for some variable names Fix indentations as noted
* Add optargs "optional arguments" unit test. This tests the ability to pass optional arguments down the calling tree robustly whether they are present or not. * Add test to count optional arguments at 2nd level
…ortium#731) When running a test suite that includes 'bfbcomp' tests, the test script ('cice.test') queries the file 'suite.jobs' in the suite directory to get the job ID of the test against which to compare for bit-for-bit-ness. If re-running the suite, 'suite.jobs' is not removed, so that the new job IDs are appended to the existing file. This leads to syntax errors when 'cice.test' looks for the job ID to compare against since the 'grep' call returns several matches. Remove 'suite.jobs' at the start of the 'suite.submit' script generated by 'cice.setup' to avoid that.
* Deprecate CESM ponds * Namelist changes for deprecating cesmponds * Update documentation
) * initial 0-layer thermo deprecation * capitalization matters for cpps * set_nml.boxadv needs thermo turned on * deprecate old ridging participation and redistribution functions * Revert "deprecate old ridging participation and redistribution functions" This reverts commit 95c289a.
Bring in deprecated 0-layer and cesmponds changes in Icepack.
…tium#742) * Update cice.t-test.py to use cartopy instead of basemap. * Bug fix to add gridlines to SH plots * commented out contour section of plots. Default is pcolor. If contour is selected it will instead make a pcolor plot * cice.t-test.py: addded individual colorbar to each plot. environment.yml: removed basemap, added cartopy * Remove shrink option from difference plots * Add blockall distribution_wght to set_nml.qc to address plotting issues in qc test Co-authored-by: daveh150 <david.hebert@nrlssc.navy.mil>
…tium#745) * cice.setup: allow command line to override suite options Options chosen on the 'cice.setup' command line (using the '-s' flag) are added to the options defined for each test in the test suite definition file, when running a test suite. This is implemented by appending the options from the test suite (in variable 'sets_tmp') to the options from the command line ('sets_base') in the variable 'sets', which is ultimately (via the variable 'setsx') looped through to apply each option. Since 'sets_tmp' is appended to 'sets_base', options on the command line can't override options from the test suite file, which means one can't e.g. run a test suite with 'kdyn=3' and expect all tests to use this option if any option specified in the test suite set 'kdyn' to some other value. To allow options from the command line to override options from the test suite, reverse the order in which 'sets_tmp' and 'sets_base' are used to define 'sets'. This is in line with the common behaviour of the command line taking precedence. Adjust the documentation accordingly, fixing a typo along the way. * cice.setup: name test suite cases less ambiguously In the previous commit, we allowed options from the command line to override options from the test suite definition file. However, test case directories are still named using a sorted list of all active options, both from command line and the suite definition file (variable 'setsarray'). This is nonoptimal since it is not clear from looking at the test directory name which options have precedence in case of conflict. Change the naming logic so that options from the command line are last in the test directory name, in a "last-one-wins" fashion. To do that, let 'setsarray' be defined from the test suite options ('sets_tmp') and add a second loop for the command line options ('sets_base'). Note that we do not check if the same option is mentioned both in the test suite and the command line, in order not to complicate the code further. This also allows greatly simplifying the logic used to adjust 'bfbcomp' test names to include command line options. This part of the code is checking if the options for the test aginst which to compare contain duplicates and 'none', which is unnecessary since these options come directly from the test suite definition file.
* Update Icepack Update Version * Set visc_method='avg_strength' for gridCD to avoid some aborts Fix a few bugs in the test suite lists
…ium#749) At the end of subroutine ice_grid::gridbox_corners, the arrays 'lont_bounds' and 'lonu_bounds', which contain the longitude of the corners of each grid cell on the T and U grids, are converted to to the [0, 360] range. In the case of rectangular grids ('grid_type = rectangular'), at the point where 'gridbox_corners' is called in 'init_grid2', 'lont_bounds' is not initialized, causing the code to abort if compiling with NaN initialization. This is due to the fact that 'gridbox_verts', which initializes 'lont_bounds' and 'latt_bounds', is not called in 'rectgrid', whereas it is called in 'popgrid[_nc]'. Do call 'gridbox_verts' in 'rectgrid', so that 'lont_bounds' and 'latt_bounds' are correctly initalized in that case also. Note that these calls are also missing in 'latlongrid' and 'cpomgrid', but since these two subroutines are not used in standalone configuration, let's not bother for now.
* Update/improve debug_blocks output, see CICE-Consortium#718. * Add ICE_MEMUSE cice.settings flag for batch memory use Add set_env.memsmall, memmed, memlarge options To use, will require changes to the env machine files. Most machines will probably not use it. See CICE-Consortium#674. * Add setup_machparams.csh to compute batch/launch machine parameters Update cice.batch.csh and cice.launch.csh to use setup_machparams.csh See CICE-Consortium#650 * Update subroutine diagnostic_abort which calls print_state Update ice_transport_remap and ice_transport_driver to call diagnostic_abort during some errors. See also CICE-Consortium#622 * Update miniconda install information See CICE-Consortium#547 * Code cleanup based on compile with -Wall Code cleanup based on -std f2003 and f2008 checks Add -stand f08 to cheyenne_intel debug flags Add -std f2008 to cheyenne_gnu debug flags Code consistent with Fortran 2003 except for use of contiguous in 1d evp code. * Remove all trailing blank space with script * Update the cheyenne env so qc testing works Add configuration/scripts/tests/qctest.yml file Update documentation * Update Icepack * Clean up some output * fix comments * update print_state output
* machines: eccc: unify baseline directory * machines: eccc: fix modules initialization Make sure to source the Csh initialization script for environment modules ourselves, as it is not done in all environments. While at it, for convenience add I_MPI_LIBRARY_KIND=debug to the commented lines.
The variable ice_calendar::nstreams, which corresponds to the number of output history streams to use for the run, is initialized in ice_history::init_hist depending on the number of non-'x' elements in 'histfreq' in the namelist. However, the code does use 'nstreams' before ice_history::init_hist is called, in ice_calendar::calendar when called from ice_calendar::init_calendar. Both 'init_calendar' and 'init_hist' are called from CICE_InitMod::cice_init, in that order, such that the loop that initializes 'write_history' in 'calendar' uses 'nstreams' uninitialized. 'calendar' ends up being called at least once more during 'cice_init', from ice_calendar::advance_timestep, at which point 'nstreams' is correctly defined and 'write_history' is thus correctly initialized, before its first use in 'accum_hist'. To avoid using 'nstreams' uninitialized in the first call to 'calendar' from 'init_calendar', initialize it to zero in 'init_calendar' before calling 'calendar'. This issue was discovered by compiling using the '-init=huge' flag of the Intel compiler.
CICE-Consortium#746) * Added dxgrow, dygrow to facilitate variable spaced grid. Modified rectgrid to generate grid from center outward using growth factor * Adding vargrid namelist options. * Refactored rectgrid to compute dx/dy first. Then ULON/ULAT. Added scale_dxdy flag to check of want grid spacing scaled. Renamed dxgrow/dygrow to dxscale/dyscale. * Added method to check for odd nx_global/ny_global when applying grid spacing scale factors * Update comments before computing dx/dy * Update comments when checking for even/odd * made grid_lonref, grid_latref namelist varaibles. Removed vargrid_suite.ts. Updated the box nml to specify the default grid_lonref and grid_latref for future reference. * Change grid_lonref/grid_latref to lonrefrect,latrefrect. Reduce default vargrid tests to 3 per B,C,CD grid. * Make new subroutine rectgrid_scale_dxdy to implemnet grid scaling. Remove explicit latrefrec/lonrefrect from set_nml. Make dxscale,dyscale,latrefrec,lonrefrec double precition in ice_in * Add set_nml.scale1 to test vargrid with dxscale/dyscale = 1.d0 * Remove lonrefrec/latrefrec from boxnodyn * Add lonrefrect, latrafrect to documentation * Inserted new scaled grid varibles in alphabetical order in documentation
…CE-Consortium#754) * Update Pull Request Template, add question about updating Icepack
* Refactored evp sub cycling loop * corrected indent and case for dyn_haloUptdate
…um#758) In 3fedc78 (Allow for read of tlat, tlon, anglet with popgrid (CICE-Consortium#463), 2020-06-24), ice_grid::init_grid2 was changed so that ice_grid::Tlatlon, which computes the TLAT and TLON arrays from ULAT and ULON, is only called if the private module variable 'l_readCenter' is false. The idea is that if the grid file contains a variable 'anglet', then it is assumed that it also contains variables 'tlon' and 'tlat', and so these fields are read directly instead of being computed. This logic, however, was only implemented in ice_grid::popgrid_nc, which sets 'l_readCenter' depending on the presence or absence of 'anglet' in the grid file. This means that if 'popgrid_nc' is not called (for example with "grid_format='bin'", in which case init_grid2 calls 'popgrid' and not 'popgrid_nc'), then 'l_readCenter' is used uninitialized in init_grid2, and so it's possible that 'Tlatlon' is not called, if 'l_readCenter' happens to be initialized to true. This in turns leads to 'TLAT' and 'TLON' being uninitialized, and the code failing when accessing these arrays if compiling with NaN initialization. Fix this by initializing 'l_readCenter' at the beginning of init_grid2, such that it is initialized for all choices of 'grid_format' and 'grid_type'. Remove the initialization in 'popgrid_nc'.
* move deformation out of loop for B grid only * Moved C and CD grid deformations * correct location of bgrid deformation
* Update dEdd implementation - Update Icepack with several fixes (changes answers for tr_aero) - Update bgc aerosol table to higher precision - Add modal aerosol tests - Update test suites * Update Icepack including dEdd fixes
) * Update grid averaging for tmass, aice, uvelT, vvelT - Update tmass and aice T2U mapping, switch from "F" to "S", F was backwards compatible but not correct (changes answers) - Update ocean forcing T2U averaging in ocn_data_ncar_init, change "F" to "A". - Update uvelT, vvelT averaging in step_therm1, change from 4 point average to U2TA (changes answers for highfreq=.true.) - Remove history grids not needed (i.e. ustr3Dz) * Refactor uvelT, vvelT implementation
Mention that CICE must be cloned with '--recurse-submodules' for Icepack to also be cloned, formatting the 'git clone' command as a code block, and fix the link to the Git Workflow Guide.
* Refactor strocnxT, strocnyT implementation - add aiU to ice_state - migrate computation of strocnxT and strocnyT to ice_step, needed for thermodynamics, better code reuse. - add strocnxT_sf, strocnyT_sf as coupling field, could be computed differently than the thermodynanics version. The _sf field computation should be in scale fluxes, but because scale_fluxes is called on a block and the _sf fields require a halo update among other things, the computation can't be done in scale_fluxes. - Update the coupling layers to use the _sf version of the fields. - CICE-Consortium#761 suggests the values of strocnxT, strocnyT should not be scaled for use in thermodynamics. This commit does not make that change yet, but allows for that change to be made easily. - These changes are bit-for-bit for a full test suite on cheyenne with 3 compilers. * Update computation of strocnxT, strocnyT passed into icepack_step_therm1 - No longer divided by aice - strocnxT_sf, strocnyT_sf are still computed in the same way as before * Rename strocn[x,y]T_sf to strocn[x,y]T_iavg Revert strocn[x,y]T passed into thermodynamics to be the version divided by aice, specifically strocn[x,y]T_iavg. This is identical to earlier implementations.
When the 'default_season' namelist setting was added in 01494c7 (Nml settings (CICE-Consortium#208), 2018-10-19) to replace 'l_winter' and 'l_spring', a call to 'broadcast_scalar' was forgotten, such that the 'default_season' value from the namelist is only used on the first MPI process; all other processes get the hardcoded default value 'winter' defined in 'ice_init::input_data', resulting in different initialization across the grid for several variables if anything other than 'winter' is used in the namelist. Fix that by broadcasting 'default_season' to all MPI procs.
- refactor options boxsym and boxislands to boxopen, boxclosed, and boxforce - update box test names as needed - update calculation of test suite failures in cice.results.csh - add documentation to user guide for rectangular grids
- Compute and used cdn_ocn on U, E, and N cell locations as needed for dynamics. - Add halo updates in dynamics before calling grid_average. This doesn't change answers, but is the safe thing to do in general. Performance does not seem to be affected.
…sk (CICE-Consortium#773) * Change icetmask to logical consistent with iceumask, icenmask, iceemask - Add icetmask as logical array to ice_grid.F90, was integer array - Update use of icetmask in code for consistency with new type - Add ice_HaloUpdate2DL1 to support halo updates for logical fields in both mpi and serial ice_boundary.F90 - Modify some capital T,U,N,E in ice_dyn_shared.F90 to t,u,n,e for better consistency in code * Update cicecore/cicedynB/infrastructure/comm/mpi/ice_boundary.F90 * Update comment in code * Revert changes to T,U,N,E in ice_dyn_shared.F90, working toward additional changes * Move ice[T,U,N,E}mask from ice_grid to ice_dyn_shared * rename icell[t,u,n,e] to icell[T,U,N,E], rename indx[t,u,n,e] to indx[T,U,N,E] * remove ice[t,u,n,e]grid from ice_grid
…CE-Consortium#774) * doc: fix typo in index (bfbflag) * doc: correct default value of 'maxits_nonlin' The "Table of namelist options" in the user guide lists 'maxits_nonlin' as having a default value of 1000, whereas its actual default is 4, both in the namelist and in 'ice_init.F90'. This has been the case since the original implementation of the implicit solver in f7fd063 (dynamics: add implicit VP solver (CICE-Consortium#491), 2020-09-22). Fix the documentation. * doc: VP solver is validated with OpenMP When the implicit VP solver was added in f7fd063 (dynamics: add implicit VP solver (CICE-Consortium#491), 2020-09-22), it had not yet been tested with OpenMP enabled. The OpenMP implementation was carefully reviewed and then fixed in d1e972a (Update OMP (CICE-Consortium#680), 2022-02-18), which lead to all runs of the 'decomp' suite completing and all restart tests passing. The 'bfbcomp' tests are still failing, but this is due to the code not using the CICE global sum implementation correctly, which will be fixed in the next commits. Update the documentation accordingly. * ice_dyn_vp: activate OpenMP in 'dyn_prep2' loop When the OpenMP implementation was reviewed and fixed in d1e972a (Update OMP (CICE-Consortium#680), 2022-02-18), the 'PRIVATE' clause of the OpenMP directive for the loop where 'dyn_prep2' is called in 'implicit_solver' was corrected in line with what was done in 'ice_dyn_evp', but OpenMP was left unactivated for this loop (the 'TCXOMP' was not changed to a real 'OMP' directive). Activate OpenMP for this loop. All runs and restart tests of the 'decomp_suite' still pass with this change. * machines: eccc : add ICE_MACHINE_MAXRUNLENGTH to ppp[56] * machines: eccc: use PBS-enabled OpenMPI for 'ppp6_gnu' The system installation of OpenMPI at /usr/mpi/gcc/openmpi-4.1.2a1/ is not compiled with support for PBS. This leads to failures as the MPI runtime does not have the same view of the number of available processors as the job scheduler. Use our own build of OpenMPI, compiled with PBS support, for the 'ppp6_gnu' environment, which uses OpenMPI. * machines: eccc: set I_MPI_FABRICS=ofi Intel MPI 2021.5.1, which comes with oneAPI 2022.1.2, seems to have an intermittent bug where a call to 'MPI_Waitall' fails with: Abort(17) on node 0 (rank 0 in comm 0): Fatal error in PMPI_Waitall: See the MPI_ERROR field in MPI_Status for the error code and no core dump is produced. This affects at least these cases of the 'decomp' suite: - *_*_restart_gx3_16x2x1x1x800_droundrobin - *_*_restart_gx3_16x2x2x2x200_droundrobin This was reported to Intel and they suggested setting the variable 'I_MPI_FABRICS' to 'ofi' (the default being 'shm:ofi' [1]). This disables shared memory transport and indeeds fixes the failures. Set this variable for all ECCC machine files using Intel MPI. [1] https://www.intel.com/content/www/us/en/develop/documentation/mpi-developer-reference-linux/top/environment-variable-reference/environment-variables-for-fabrics-control/communication-fabrics-control.html * machines: eccc: set I_MPI_CBWR for BASEGEN/BASECOM runs Intel MPI, in contrast to OpenMPI (as far as I was able to test, and see [1], [2]), does not (by default) guarantee that repeated runs of the same code on the same machine with the same number of MPI ranks yield the same results when collective operations (e.g. 'MPI_ALLREDUCE') are used. Since the VP solver uses MPI_ALLREDUCE in its algorithm, this leads to repeated runs of the code giving different answers, and baseline comparing runs with code built from the same commit failing. When generating a baseline or comparing against an existing baseline, set the environment variable 'I_MPI_CBWR' to 1 for ECCC machine files using Intel MPI [3], so that (processor) topology-aware collective algorithms are not used and results are reproducible. Note that we do not need to set this variable on robert or underhill, on which jobs have exclusive node access and thus job placement (on processors) is guaranteed to be reproducible. [1] https://stackoverflow.com/a/45916859/ [2] https://scicomp.stackexchange.com/a/2386/ [3] https://www.intel.com/content/www/us/en/develop/documentation/mpi-developer-reference-linux/top/environment-variable-reference/i-mpi-adjust-family-environment-variables.html#i-mpi-adjust-family-environment-variables_GUID-A5119508-5588-4CF5-9979-8D60831D1411 * ice_dyn_vp: fgmres: exit early if right-hand-side vector is zero If starting a run with with "ice_ic='none'" (no ice), the linearized problem for the ice velocity A x = b will have b = 0, since all terms in the right hand side vector will be zero: - strint[xy] is zero because the velocity is zero - tau[xy] is zero because the ocean velocity is also zero - [uv]vel_init is zero - strair[xy] is zero because the concentration is zero - strtlt[xy] is zero because the ocean velocity is zero We thus have a linear system A x = b with b=0, so we must have x=0. In the FGMRES linear solver, this special case is not taken into account, and so we end up with an all-zero initial residual since workspace_[xy] is also zero because of the all-zero initial guess 'sol[xy]', which corresponds to the initial ice velocity. This then leads to a division by zero when normalizing the first Arnoldi vector. Fix this special case by computing the norm of the right-hand-side vector before starting the iterations, and exiting early if it is zero. This is in line with the GMRES implementation in SciPy [1]. [1] https://github.com/scipy/scipy/blob/651a9b717deb68adde9416072c1e1d5aa14a58a1/scipy/sparse/linalg/_isolve/iterative.py#L620-L628 Close: phil-blain#42 * ice_dyn_vp: add global_norm, global_dot_product functions The VP solver uses a linear solver, FGMRES, as part of the non-linear iteration. The FGMRES algorithm involves computing the norm of a distributed vector field, thus performing global sums. These norms are computed by first summing the squared X and Y components of a vector field in subroutine 'calc_L2norm_squared', summing these over the local blocks, and then doing a global (MPI) sum using 'global_sum'. This approach does not lead to reproducible results when the MPI distribution, or the number of local blocks, is changed, for reasons explained in the "Reproducible sums" section of the Developer Guide (mostly, floating point addition is not associative). This was partly pointed out in [1] but I failed to realize it at the time. Introduce a new function, 'global_dot_product', to encapsulate the computation of the dot product of two grid vectors, each split into two arrays (for the X and Y components). Compute the reduction locally as is done in 'calc_L2norm_squared', but throw away the result and use the existing 'global_sum' function when 'bfbflag' is active, passing it the temporary array used to compute the element-by-element product. This approach avoids a performance regression from the added work done in 'global_sum', such that non-bfbflag runs are as fast as before. Note that since 'global_sum' loops on the whole array (and not just ice points as 'global_dot_product'), make sure to zero-initialize the 'prod' local array. Also add a 'global_norm' function implemented using 'global_dot_product'. Both functions will be used in subsequent commits to ensure bit-for-bit reproducibility. * ice_dyn_vp: use global_{norm,dot_product} for bit-for-bit output reproducibility Make the results of the VP solver reproducible if desired by refactoring the code to use the subroutines 'global_norm' and 'global_dot_product' added in the previous commit. The same pattern appears in the FGMRES solver (subroutine 'fgmres'), the preconditioner 'pgmres' which uses the same algorithm, and the Classical and Modified Gram-Schmidt algorithms in 'orthogonalize'. These modifications do not change the number of global sums in the fgmres, pgmres and the MGS algorithm. For the CGS algorithm, there is (in theory) a slight performance impact as 'global_dot_product' is called inside the loop, whereas previously we called 'global_allreduce_sum' after the loop to compute all 'initer' sums at the same time. To keep that optimization, we would have to implement a new interface 'global_allreduce_sum' which would take an array of shape (nx_block,ny_block,max_blocks,k) and sum over their first three dimensions before performing the global reduction over the k dimension. We choose to not go that route for now mostly because anyway the CGS algorithm is (by default) only used for the PGMRES preconditioner, and so the cost should be relatively low as 'initer' corresponds to 'dim_pgmres' in the namelist, which should be kept low for efficiency (default 5). These changes lead to bit-for-bit reproducibility (the decomp_suite passes) when using 'precond=ident' and 'precond=diag' along with 'bfbflag=reprosum'. 'precond=pgmres' is still not bit-for-bit because some halo updates are skipped for efficiency. This will be addressed in a following commit. [1] CICE-Consortium#491 (comment) * ice_dyn_vp: do not skip halo updates in 'pgmres' under 'bfbflag' The 'pgmres' subroutine implements a separate GMRES solver and is used as a preconditioner for the FGMRES linear solver. Since it is only a preconditioner, it was decided to skip the halo updates after computing the matrix-vector product (in 'matvec'), for efficiency. This leads to non-reproducibility since the content of the non-updated halos depend on the block / MPI distribution. Add the required halo updates, but only perform them when we are explicitely asking for bit-for-bit global sums, i.e. when 'bfbflag' is set to something else than 'not'. Adjust the interfaces of 'pgmres' and 'precondition' (from which 'pgmres' is called) to accept 'halo_info_mask', since it is needed for masked updates. Closes CICE-Consortium#518 * ice_dyn_vp: use global_{norm,dot_product} for bit-for-bit log reproducibility In the previous commits we ensured bit-for-bit reproducibility of the outputs when using the VP solver. Some global norms computed during the nonlinear iteration still use the same non-reproducible pattern of summing over blocks locally before performing the reduction. However, these norms are used only to monitor the convergence in the log file, as well as to exit the iteration when the required convergence level is reached ('nlres_norm'). Only 'nlres_norm' could (in theory) influence the output, but it is unlikely that a difference due to floating point errors would influence the 'if (nlres_norm < tol_nl)' condition used to exist the nonlinear iteration. Change these remaining cases to also use 'global_norm', leading to bit-for-bit log reproducibility. * ice_dyn_vp: remove unused subroutine and cleanup interfaces The previous commit removed the last caller of 'calc_L2norm_squared'. Remove the subroutine. Also, do not compute 'sum_squared' in 'residual_vec', since the variable 'L2norm' which receives this value is also unused in 'anderson_solver' since the previous commit. Remove that variable, and adjust the interface of 'residual_vec' accordingly. * ice_global_reductions: remove 'global_allreduce_sum' In a previous commit, we removed the sole caller of 'global_allreduce_sum' (in ice_dyn_vp::orthogonalize). We do not anticipate that function to be ued elsewhere in the code, so remove it from ice_global_reductions. Update the 'sumchk' unit test accordingly. * doc: mention VP solver is only reproducible using 'bfbflag' The previous commits made sure that the model outputs as well as the log file output are bit-for-bit reproducible when using the VP solver by refactoring the code to use the existing 'global_sum' subroutine. Add a note in the documentation mentioning that 'bfbflag' is required to get bit-for-bit reproducible results under different decompositions / MPI counts when using the VP solver. Also, adjust the doc about 'bfbflag=lsum8' being the same as 'bfbflag=off' since this is not the case for the VP solver: in the first case we use the scalar version of 'global_sum', in the second case we use the array version. * ice_dyn_vp: improve default parameters for VP solver During QC testing of the previous commit, the 5 years QC test with the updated VP solver failed twice with "bad departure points" after a few years of simulation. Simply bumping the number of nonlinear iterations (maxits_nonlin) from 4 to 5 makes these failures disappear and allow the simulations to run to completion, suggesting the solution is not converged enough with 4 iterations. We also noticed that in these failing cases, the relative tolerance for the linear solver (reltol_fmgres = 1E-2) is too small to be reached in less than 50 iterations (maxits_fgmres), and that's the case at each nonlinear iteration. Other papers mention a relative tolerance of 1E-1 for the linear solver, and using this value also allows both cases to run to completion (even without changing maxits_nonlin). Let's set the default tolerance for the linear solver to 1E-1, and let's be conservative and bump the number of nonlinear iterations to 10. This should give us a more converged solution and add robustness to the default settings.
* CESM updates * Rearrange some wave code * Add updates for UFS
…onsortium#778) * allocate c and cd var in evp, reduce number of if grid_ice. * Homogenized call init_dyn in CICE_initMod, rmoved first_call from loop in eap * bug fixes, removal of *.loc, moved more fields to be allocatable * Allign indents * read and write when iceumask, icenmask and iceemask are not allocated
* Rename cicedynB to cicedyn, update test suites - Rename cicedynB directory to cicedyn (See CICE-Consortium#660) - Add softlink for cicedynB - Update path in cice.build - Update documentation - Fix sig1, sig2, sigP grid on history file (See CICE-Consortium#789) - Fix Fortran warning messages for long lines - Fix test suite order in cice.setup - Update test suites to reduce bfbcomp failures due to time outs - Add tests to first_suite to help - Add dyneap and dynpicard decomp tests, add set_nml.dyneap - Add TAB check in github actions in all .F90 and .c files github actions will fail if source files have TABs * Remove tabs * Update documentation * Update documentation
* Trap solve_zsal = true at initialization - remove zsal tests - rearrange a few test suites * Update documentation for zsalinty * update test suite * Update Icepack to latest
* Update Icepack to #5999551 Update advection description in document Update f_bound setting in ice_history.F90
* Bring Consortium main into CESM * Comment out OMP initialization * Update wave-ice coupling in NUOPC/CMEPS driver * Update saltflux option to be constant and use ice_ref_salinity * Fix a couple inconsistencies with CICE Consortium master * Fix some issues * Fix some merge issues * Fix some merge issues * Fix ACC directive * Bug fixes with eap initialization * Fix evp initialization * Add warning when ktherm=1 and saltflux_option not constant * Comment out Tair initialization * Add CESMCOUPLED around OMP initialization * CESM File unit handling * Change icepack hash for PR * Some cleanup things * Move nu_diag_set to CESMCOUPLED region * Put Tair initialization in a CESMCOUPLED * New saltflux tests * Update icepack for saltflux option * Update icepack
* Update stress12T calculation for C-grid stress12T was zero. Compute stress12T in subroutine stressC_T after computing estimate of shearT by averaging shearU. minor updates to some indentation and variable names. * Update calc of stress12T and shearT for C-grid for performance, changes answers
Update Icepack to latest release version Remove trailing blank space
CICE-Consortium#801) * Adding method to check namelist in any order. Use subroutine in ice_namelist_mod.F90 to search for namelist in ice_in. * Moved goto_nml subroutine to ice_fileunits.F90. Removed ice_namelist_mod.F90 * Cleanup indentations with tmpstr2 use * Cleanup spacing and intentation * For namelist check, remove extra continuation after making ice_abort string. Co-authored-by: Tony Craig <apcraig@users.noreply.github.com>
* Fix OMP setup * Update meshgrid
allow nudiag_set to be available outside of cesm; may prefer to fix in coupling interface
37 tasks
BrianCurtis-NOAA
approved these changes
Jan 10, 2023
NeilBarton-NOAA
approved these changes
Jan 17, 2023
DeniseWorthen
added a commit
to DeniseWorthen/CICE
that referenced
this pull request
Sep 1, 2023
…ICE-Consortium#856) * merge latest master (NOAA-EMC#4) * Isotopes for CICE (CICE-Consortium#423) Co-authored-by: apcraig <anthony.p.craig@gmail.com> Co-authored-by: David Bailey <dbailey@ucar.edu> Co-authored-by: Elizabeth Hunke <eclare@lanl.gov> * updated orbital calculations needed for cesm * fixed problems in updated orbital calculations needed for cesm * update CICE6 to support coupling with UFS * put in changes so that both ufsatm and cesm requirements for potential temperature and density are satisfied * Convergence on ustar for CICE. (CICE-Consortium#452) (NOAA-EMC#5) * Add atmiter_conv to CICE * Add documentation * trigger build the docs Co-authored-by: David A. Bailey <dbailey@ucar.edu> * update icepack submodule * Revert "update icepack submodule" This reverts commit e70d1ab. * update comp_ice.backend with temporary ice_timers fix * Fix threading problem in init_bgc * Fix additional OMP problems * changes for coldstart running * Move the forapps directory * remove cesmcoupled ifdefs * Fix logging issues for NUOPC * removal of many cpp-ifdefs * fix compile errors * fixes to get cesm working * fixed white space issue * Add restart_coszen namelist option * update icepack submodule * change Orion to orion in backend remove duplicate print lines from ice_transport_driver * add -link_mpi=dbg to debug flags (NOAA-EMC#8) * cice6 compile (NOAA-EMC#6) * enable debug build. fix to remove errors * fix an error in comp_ice.backend.libcice * change Orion to orion for machine identification * changes for consistency w/ current emc-cice5 (NOAA-EMC#13) Update to emc/develop fork to current CICE consortium Co-authored-by: David A. Bailey <dbailey@ucar.edu> Co-authored-by: Tony Craig <apcraig@users.noreply.github.com> Co-authored-by: Elizabeth Hunke <eclare@lanl.gov> Co-authored-by: Mariana Vertenstein <mvertens@ucar.edu> Co-authored-by: apcraig <anthony.p.craig@gmail.com> Co-authored-by: Philippe Blain <levraiphilippeblain@gmail.com> * Fixcommit (NOAA-EMC#14) Align commit history between emc/develop and cice-consortium/master * Update CICE6 for integration to S2S * add wcoss_dell_p3 compiler macro * update to icepack w/ debug fix * replace SITE with MACHINE_ID * update compile scripts * Support TACC stampede (NOAA-EMC#19) * update icepack * add ice_dyn_vp module to CICE_InitMod * update gitmodules, update icepack * Update CICE to consortium master (NOAA-EMC#23) updates include: * deprecate upwind advection (CICE-Consortium#508) * add implicit VP solver (CICE-Consortium#491) * update icepack * switch icepack branches * update to icepack master but set abort flag in ITD routine to false * update icepack * Update CICE to latest Consortium master (NOAA-EMC#26) update CICE and Icepack * changes the criteria for aborting ice for thermo-conservation errors * updates the time manager * fixes two bugs in ice_therm_mushy * updates Icepack to Consortium master w/ flip of abort flag for troublesome IC cases * add cice changes for zlvs (NOAA-EMC#29) * update icepack and pointer * update icepack and revert gitmodules * Fix history features - Fix bug in history time axis when sec_init is not zero. - Fix issue with time_beg and time_end uninitialized values. - Add support for averaging with histfreq='1' by allowing histfreq_n to be any value in that case. Extend and clean up construct_filename for history files. More could be done, but wanted to preserve backwards compatibility. - Add new calendar_sec2hms to converts daily seconds to hh:mm:ss. Update the calchk calendar unit tester to check this method - Remove abort test in bcstchk, this was just causing problems in regression testing - Remove known problems documentation about problems writing when istep=1. This issue does not exist anymore with the updated time manager. - Add new tests with hist_avg = false. Add set_nml.histinst. * revert set_nml.histall * fix implementation error * update model log output in ice_init * Fix QC issues - Add netcdf ststus checks and aborts in ice_read_write.F90 - Check for end of file when reading records in ice_read_write.F90 for ice_read_nc methods - Update set_nml.qc to better specify the test, turn off leap years since we're cycling 2005 data - Add check in c ice.t-test.py to make sure there is at least 1825 files, 5 years of data - Add QC run to base_suite.ts to verify qc runs to completion and possibility to use those results directly for QC validation - Clean up error messages and some indentation in ice_read_write.F90 * Update testing - Add prod suite including 10 year gx1prod and qc test - Update unit test compare scripts * update documentation * reset calchk to 100000 years * update evp1d test * update icepack * update icepack * add memory profiling (NOAA-EMC#36) * add profile_memory calls to CICE cap * update icepack * fix rhoa when lowest_temp is 0.0 * provide default value for rhoa when imported temp_height_lowest (Tair) is 0.0 * resolves seg fault when frac_grid=false and do_ca=true * update icepack submodule * Update CICE for latest Consortium master (NOAA-EMC#38) * Implement advanced snow physics in icepack and CICE * Fix time-stamping of CICE history files * Fix CICE history file precision * Use CICE-Consortium/Icepack master (NOAA-EMC#40) * switch to icepack master at consortium * recreate cap update branch (NOAA-EMC#42) * add debug_model feature * add required variables and calls for tr_snow * remove 2 extraneous lines * remove two log print lines that were removed prior to merge of driver updates to consortium * duplicate gitmodule style for icepack * Update CICE to latest Consortium/main (NOAA-EMC#45) * Update CICE to Consortium/main (NOAA-EMC#48) Update OpenMP directives as needed including validation via new omp_suite. Fixed OpenMP in dynamics. Refactored eap puny/pi lookups to improve scalar performance Update Tsfc implementation to make sure land blocks don't set Tsfc to freezing temp Update for sea bed stress calculations * fix comment, fix env for orion and hera * replace save_init with step_prep in CICE_RunMod * fixes for cgrid repro * remove added haloupdates * baselines pass with these extra halo updates removed * change F->S for ocean velocities and tilts * fix debug failure when grid_ice=C * compiling in debug mode using -init=snan,arrays requires initialization of variables * respond to review comments * remove inserted whitespace for uvelE,N and vvelE,N * Add wave-cice coupling; update to Consortium main (NOAA-EMC#51) * add wave-ice fields * initialize aicen_init, which turns up as NaN in calc of floediam export * add call to icepack_init_wave to initialize wavefreq and dwavefreq * update to latest consortium main (PR 752) * add initializationsin ice_state * initialize vsnon/vsnon_init and vicen/vicen_init * Update CICE (NOAA-EMC#54) * update to include recent PRs to Consortium/main * fix for nudiag_set allow nudiag_set to be available outside of cesm; may prefer to fix in coupling interface * Update CICE for latest Consortium/main (NOAA-EMC#56) * add run time info * change real(8) to real(dbl)kind) * fix syntax * fix write unit * use cice_wrapper for ufs timer functionality * add elapsed model time for logtime * tidy up the wrapper * fix case for 'time since' at the first advance * add timer and forecast log * write timer values to timer log, not nu_diag * write log.ice.fXXX * only one time is needed * modify message written for log.ice.fXXX * change info in fXXX log file * Update CICE from Consortium/main (NOAA-EMC#62) * Fix CESMCOUPLED compile issue in icepack. (CICE-Consortium#823) * Update global reduction implementation to improve performance, fix VP bug (CICE-Consortium#824) * Update VP global sum to exclude local implementation with tripole grids * Add functionality to change hist_avg for each stream (CICE-Consortium#827) * Update Icepack to #6703bc533c968 May 22, 2023 (CICE-Consortium#829) * Fix for mesh check in CESM driver (CICE-Consortium#830) * Namelist option for time axis position. (CICE-Consortium#839) * reset timer after Advance to retrieve "wait time" * add logical control for enabling runtime info * remove zsal items from cap * fix typo --------- Co-authored-by: apcraig <anthony.p.craig@gmail.com> Co-authored-by: David Bailey <dbailey@ucar.edu> Co-authored-by: Elizabeth Hunke <eclare@lanl.gov> Co-authored-by: Mariana Vertenstein <mvertens@ucar.edu> Co-authored-by: Minsuk Ji <57227195+MinsukJi-NOAA@users.noreply.github.com> Co-authored-by: Tony Craig <apcraig@users.noreply.github.com> Co-authored-by: Philippe Blain <levraiphilippeblain@gmail.com> Co-authored-by: Jun.Wang <Jun.Wang@noaa.gov>
DeniseWorthen
added a commit
to DeniseWorthen/CICE
that referenced
this pull request
Sep 18, 2023
commit 2ed3c05 Author: Denise Worthen <denise.worthen@noaa.gov> Date: Thu Sep 7 15:00:21 2023 -0400 Update CICE from Consortium/main, add run-time and history-write logging (NOAA-EMC#65) commit d41c61d Author: Denise Worthen <denise.worthen@noaa.gov> Date: Wed Aug 2 17:09:26 2023 -0400 Update CICE from Consortium/main (NOAA-EMC#62) * Fix CESMCOUPLED compile issue in icepack. (CICE-Consortium#823) * Update global reduction implementation to improve performance, fix VP bug (CICE-Consortium#824) * Update VP global sum to exclude local implementation with tripole grids * Add functionality to change hist_avg for each stream (CICE-Consortium#827) * Update Icepack to #6703bc533c968 May 22, 2023 (CICE-Consortium#829) * Fix for mesh check in CESM driver (CICE-Consortium#830) * Namelist option for time axis position. (CICE-Consortium#839) commit 5840cd1 Merge: 6671e32 7df80ba Author: Denise Worthen <denise.worthen@noaa.gov> Date: Wed Mar 22 07:43:35 2023 -0400 Merge remote-tracking branch 'Consortium/main' into feature/updcice commit 6671e32 Merge: ee68d3f d73bb8b Author: Denise Worthen <denise.worthen@noaa.gov> Date: Tue Mar 7 12:56:52 2023 -0500 Merge remote-tracking branch 'Consortium/main' into feature/updcice commit ee68d3f Merge: dd25b0f e628a9a Author: Denise Worthen <denise.worthen@noaa.gov> Date: Tue Mar 7 12:56:33 2023 -0500 Merge branch 'emc/develop' into feature/updcice commit e628a9a Author: Denise Worthen <denise.worthen@noaa.gov> Date: Mon Jan 23 07:58:06 2023 -0500 Update CICE for latest Consortium/main (NOAA-EMC#56) commit dd25b0f Merge: ed472ab 506614d Author: Denise Worthen <denise.worthen@noaa.gov> Date: Sat Jan 14 12:00:15 2023 -0500 Merge branch 'test' into feature/updcice commit 506614d Merge: 7757945 0bf0fdc Author: Denise Worthen <denise.worthen@noaa.gov> Date: Sat Jan 14 11:58:19 2023 -0500 Merge remote-tracking branch 'CICE-Consortium/main' into test commit ed472ab Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Mon Jan 9 12:53:05 2023 +0000 fix for nudiag_set allow nudiag_set to be available outside of cesm; may prefer to fix in coupling interface commit ce2298e Merge: ad8d577 0bf0fdc Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Wed Jan 4 14:50:34 2023 -0500 Merge remote-tracking branch 'Consortium/main' into feature/updcice commit ad8d577 Merge: 90a8b62 b16d7fd Author: Denise Worthen <denise.worthen@noaa.gov> Date: Tue Dec 6 14:22:06 2022 -0500 Merge remote-tracking branch 'Consortium/main' into feature/updcice commit 90a8b62 Merge: fe16051 7757945 Author: Denise Worthen <denise.worthen@noaa.gov> Date: Tue Dec 6 13:37:51 2022 -0500 Merge branch 'NOAA-EMC:emc/develop' into feature/updcice commit 7757945 Author: Denise Worthen <denise.worthen@noaa.gov> Date: Fri Nov 25 08:58:08 2022 -0500 Update CICE (NOAA-EMC#54) * update to include recent PRs to Consortium/main commit fe16051 Merge: b11bfb4 9808b51 Author: Denise Worthen <denise.worthen@noaa.gov> Date: Wed Nov 16 07:59:58 2022 -0500 Merge remote-tracking branch 'Consortium/main' into feature/updcice commit b11bfb4 Merge: b893ee9 251ca48 Author: Denise Worthen <denise.worthen@noaa.gov> Date: Tue Nov 8 09:07:10 2022 -0500 Merge remote-tracking branch 'Consortium/main' into feature/updcice commit b893ee9 Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Wed Nov 2 15:45:10 2022 -0600 add initializationsin ice_state * initialize vsnon/vsnon_init and vicen/vicen_init commit 2e68b9e Merge: d6d081a 3820cde Author: Denise Worthen <denise.worthen@noaa.gov> Date: Wed Nov 2 12:14:34 2022 -0400 Merge remote-tracking branch 'Consortium/main' into feature/updcice commit d6d081a Merge: 1f70caf 968a0ed Author: Denise Worthen <denise.worthen@noaa.gov> Date: Wed Nov 2 12:13:52 2022 -0400 Merge branch 'emc/develop' into feature/updcice commit 968a0ed Author: Denise Worthen <denise.worthen@noaa.gov> Date: Tue Aug 30 12:51:07 2022 -0400 Add wave-cice coupling; update to Consortium main (NOAA-EMC#51) * add wave-ice fields * initialize aicen_init, which turns up as NaN in calc of floediam export * add call to icepack_init_wave to initialize wavefreq and dwavefreq * update to latest consortium main (PR 752) commit 1f70caf Merge: 73cc18c fea412a Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Sat Aug 20 10:52:22 2022 -0400 Merge remote-tracking branch 'Consortium/main' into feature/updcice commit 73cc18c Merge: cc0f89c 471c010 Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Thu Jun 23 17:42:49 2022 -0400 Merge remote-tracking branch 'Consortium/main' into feature/addCgridfixes commit cc0f89c Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Wed Jun 22 14:13:25 2022 -0600 remove inserted whitespace for uvelE,N and vvelE,N commit 9e2dd69 Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Wed Jun 22 13:07:56 2022 -0600 respond to review comments commit 26498db Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Mon Jun 20 15:27:46 2022 -0600 fix debug failure when grid_ice=C * compiling in debug mode using -init=snan,arrays requires initialization of variables commit 2d5487a Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Mon Jun 13 11:56:40 2022 -0600 change F->S for ocean velocities and tilts commit a38df37 Merge: ab95d2d 7705e13 Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Mon Jun 13 09:34:45 2022 -0400 Merge remote-tracking branch 'Consortium/main' into feature/addCgridfixes commit ab95d2d Merge: cbc6046 c334aee Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Thu Jun 2 15:48:31 2022 -0400 Merge remote-tracking branch 'Consortium/main' into feature/addCgridfixes commit cbc6046 Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Mon May 23 19:07:39 2022 -0600 remove added haloupdates * baselines pass with these extra halo updates removed commit ae50efe Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Sun May 22 16:30:00 2022 -0600 fixes for cgrid repro commit dd158e2 Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Sat May 14 13:59:26 2022 +0000 replace save_init with step_prep in CICE_RunMod commit 247dc1d Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Sat May 14 09:01:12 2022 -0400 fix comment, fix env for orion and hera commit 4b28dfe Merge: c660075 078aab4 Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Sat May 14 08:58:48 2022 -0400 Merge remote-tracking branch 'Consortium/main' into feature/addCgrid commit c660075 Author: Denise Worthen <denise.worthen@noaa.gov> Date: Tue May 10 15:28:44 2022 -0400 Update CICE to Consortium/main (NOAA-EMC#48) Update OpenMP directives as needed including validation via new omp_suite. Fixed OpenMP in dynamics. Refactored eap puny/pi lookups to improve scalar performance Update Tsfc implementation to make sure land blocks don't set Tsfc to freezing temp Update for sea bed stress calculations commit 27dfd1b Author: Denise Worthen <denise.worthen@noaa.gov> Date: Thu Feb 24 11:19:10 2022 -0500 Update CICE to latest Consortium/main (NOAA-EMC#45) commit 8ff0fb2 Author: denise.worthen <denise.worthen@noaa.gov> Date: Tue Nov 30 05:11:57 2021 -0500 duplicate gitmodule style for icepack commit abbebab Author: denise.worthen <denise.worthen@noaa.gov> Date: Tue Nov 30 05:10:24 2021 -0500 remove 2 extraneous lines * remove two log print lines that were removed prior to merge of driver updates to consortium commit 7a0b65e Merge: 55bf9f4 8d4a3c6 Author: denise.worthen <denise.worthen@noaa.gov> Date: Mon Nov 29 19:06:29 2021 -0500 Merge branch 'emc/develop' into feature/updcice commit 55bf9f4 Merge: d83c67b 2b85126 Author: denise.worthen <denise.worthen@noaa.gov> Date: Mon Nov 29 18:50:34 2021 -0500 Merge remote-tracking branch 'Consortium/main' into feature/updcice commit 8d4a3c6 Author: Denise Worthen <denise.worthen@noaa.gov> Date: Mon Nov 22 09:06:56 2021 -0500 recreate cap update branch (NOAA-EMC#42) * add debug_model feature * add required variables and calls for tr_snow commit d83c67b Merge: 8a88024 d95bd51 Author: Denise Worthen <denise.worthen@noaa.gov> Date: Tue Oct 12 14:16:31 2021 -0400 Merge branch 'NOAA-EMC:emc/develop' into feature/updcice commit d95bd51 Author: Denise Worthen <denise.worthen@noaa.gov> Date: Fri Oct 1 09:42:49 2021 -0400 Use CICE-Consortium/Icepack master (NOAA-EMC#40) * switch to icepack master at consortium commit 8a88024 Merge: d0a45a2 2540695 Author: Denise Worthen <denise.worthen@noaa.gov> Date: Mon Sep 20 09:28:26 2021 -0400 Merge branch 'NOAA-EMC:emc/develop' into feature/updcice commit 2540695 Author: Denise Worthen <denise.worthen@noaa.gov> Date: Thu Sep 16 08:28:30 2021 -0400 Update CICE for latest Consortium master (NOAA-EMC#38) * Implement advanced snow physics in icepack and CICE * Fix time-stamping of CICE history files * Fix CICE history file precision commit d0a45a2 Author: denise.worthen <denise.worthen@noaa.gov> Date: Thu Sep 16 07:44:22 2021 -0400 update icepack submodule commit 5cb78cd Author: denise.worthen <denise.worthen@noaa.gov> Date: Wed Sep 15 09:15:42 2021 -0400 fix rhoa when lowest_temp is 0.0 * provide default value for rhoa when imported temp_height_lowest (Tair) is 0.0 * resolves seg fault when frac_grid=false and do_ca=true commit cd021b5 Merge: 7d2139c 6e89728 Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Wed Sep 1 19:39:06 2021 -0400 Merge remote-tracking branch 'Consortium/master' into feature/updcice commit 7d2139c Merge: a1b3375 cb7d616 Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Tue Aug 31 14:08:06 2021 -0400 Merge remote-tracking branch 'Consortium/master' into feature/updcice commit a1b3375 Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Tue Aug 31 14:07:50 2021 -0400 update icepack commit 397b4bd Merge: aade124 7f089d0 Author: Denise Worthen <denise.worthen@noaa.gov> Date: Thu Aug 26 17:20:25 2021 -0400 Merge branch 'NOAA-EMC:emc/develop' into feature/updcice commit 7f089d0 Author: Denise Worthen <denise.worthen@noaa.gov> Date: Mon Aug 23 08:19:25 2021 -0400 add memory profiling (NOAA-EMC#36) * add profile_memory calls to CICE cap commit aade124 Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Fri Aug 20 08:14:44 2021 -0400 update icepack commit aeb473a Merge: 71f4fe6 26d917a Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Fri Aug 20 08:03:58 2021 -0400 Merge remote-tracking branch 'Consortium/master' into feature/updcice commit 71f4fe6 Merge: 4373d3d 3fd897e Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Sun Aug 15 11:04:41 2021 -0400 Merge remote-tracking branch 'TCraig/tmB' into feature/updcice commit 4373d3d Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Sun Aug 15 11:04:01 2021 -0400 update icepack commit 3fd897e Merge: 83068c7 2a692af Author: apcraig <anthony.p.craig@gmail.com> Date: Fri Aug 13 16:24:01 2021 -0600 Merge branch 'master' of https://github.com/cice-consortium/cice into tmB commit 83068c7 Author: apcraig <anthony.p.craig@gmail.com> Date: Fri Aug 13 09:24:49 2021 -0600 update evp1d test commit e31ce7e Author: apcraig <anthony.p.craig@gmail.com> Date: Fri Aug 13 09:00:01 2021 -0600 reset calchk to 100000 years commit eaa3c3a Author: apcraig <anthony.p.craig@gmail.com> Date: Thu Aug 12 23:53:55 2021 -0600 update documentation commit c5794b4 Author: apcraig <anthony.p.craig@gmail.com> Date: Thu Aug 12 23:49:05 2021 -0600 Update testing - Add prod suite including 10 year gx1prod and qc test - Update unit test compare scripts commit 7b5c2b4 Author: apcraig <anthony.p.craig@gmail.com> Date: Thu Aug 12 16:57:18 2021 -0600 Fix QC issues - Add netcdf ststus checks and aborts in ice_read_write.F90 - Check for end of file when reading records in ice_read_write.F90 for ice_read_nc methods - Update set_nml.qc to better specify the test, turn off leap years since we're cycling 2005 data - Add check in c ice.t-test.py to make sure there is at least 1825 files, 5 years of data - Add QC run to base_suite.ts to verify qc runs to completion and possibility to use those results directly for QC validation - Clean up error messages and some indentation in ice_read_write.F90 commit 96d5851 Author: apcraig <anthony.p.craig@gmail.com> Date: Wed Aug 11 13:26:01 2021 -0600 update model log output in ice_init commit b3364a6 Author: apcraig <anthony.p.craig@gmail.com> Date: Tue Aug 10 22:21:33 2021 -0600 fix implementation error commit 15763d8 Author: apcraig <anthony.p.craig@gmail.com> Date: Tue Aug 10 17:14:25 2021 -0600 revert set_nml.histall commit 441f693 Author: apcraig <anthony.p.craig@gmail.com> Date: Tue Aug 10 17:04:56 2021 -0600 Fix history features - Fix bug in history time axis when sec_init is not zero. - Fix issue with time_beg and time_end uninitialized values. - Add support for averaging with histfreq='1' by allowing histfreq_n to be any value in that case. Extend and clean up construct_filename for history files. More could be done, but wanted to preserve backwards compatibility. - Add new calendar_sec2hms to converts daily seconds to hh:mm:ss. Update the calchk calendar unit tester to check this method - Remove abort test in bcstchk, this was just causing problems in regression testing - Remove known problems documentation about problems writing when istep=1. This issue does not exist anymore with the updated time manager. - Add new tests with hist_avg = false. Add set_nml.histinst. commit 55586f7 Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Tue Jul 20 11:21:12 2021 -0400 update icepack and revert gitmodules commit 1721728 Merge: 9057817 85531cf Author: denise.worthen <denise.worthen@noaa.gov> Date: Fri Jul 2 09:49:24 2021 -0400 Merge remote-tracking branch 'Consortium/master' into feature/updcice commit 9057817 Merge: f3b2652 995f3af Author: denise.worthen <denise.worthen@noaa.gov> Date: Thu Jun 24 08:34:26 2021 -0400 Merge remote-tracking branch 'Consortium/master' into feature/updcice commit f3b2652 Author: denise.worthen <denise.worthen@noaa.gov> Date: Thu Jun 24 08:32:44 2021 -0400 update icepack and pointer commit 0c39047 Merge: 9a76541 d1f2d15 Author: denise.worthen <denise.worthen@noaa.gov> Date: Thu Jun 24 08:30:26 2021 -0400 Merge branch 'emc/develop' into feature/updcice commit d1f2d15 Merge: 74e7b58 9d88d92 Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Fri Jun 11 09:13:53 2021 -0400 Merge remote-tracking branch 'upstream/emc/develop' into emc/develop commit 9d88d92 Author: Denise Worthen <denise.worthen@noaa.gov> Date: Thu Jun 10 18:08:12 2021 -0400 add cice changes for zlvs (NOAA-EMC#29) commit 74e7b58 Merge: b52e91c 519d339 Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Sat Jun 5 17:35:52 2021 -0400 Merge remote-tracking branch 'upstream/emc/develop' into emc/develop commit 519d339 Author: Denise Worthen <denise.worthen@noaa.gov> Date: Fri Jun 4 16:41:08 2021 -0400 Update CICE to latest Consortium master (NOAA-EMC#26) update CICE and Icepack * changes the criteria for aborting ice for thermo-conservation errors * updates the time manager * fixes two bugs in ice_therm_mushy * updates Icepack to Consortium master w/ flip of abort flag for troublesome IC cases commit 9a76541 Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Fri Jun 4 16:01:59 2021 -0400 update icepack commit d8fb6d9 Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Wed Jun 2 16:57:19 2021 -0400 switch icepack branches * update to icepack master but set abort flag in ITD routine to false commit 51db2f9 Merge: b52e91c bd512d4 Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Tue Jun 1 09:17:15 2021 -0400 Merge remote-tracking branch 'Consortium/master' into feature/updcice commit b52e91c Merge: 840e931 2eca569 Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Mon Apr 5 08:40:40 2021 -0400 Merge remote-tracking branch 'upstream/emc/develop' into emc/develop commit 2eca569 Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Mon Apr 5 08:29:35 2021 -0400 update icepack commit 66546ae Merge: 1e4d393 5a0a559 Author: denise.worthen <denise.worthen@noaa.gov> Date: Sun Mar 14 09:27:54 2021 -0400 Merge remote-tracking branch 'Consortium/master' into feature/updcice commit 1e4d393 Merge: 2a0f332 f773ef3 Author: denise.worthen <denise.worthen@noaa.gov> Date: Sun Mar 14 09:19:52 2021 -0400 Merge remote-tracking branch 'upstream/emc/develop' into feature/updcice commit 840e931 Merge: 23cdee7 f773ef3 Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Tue Nov 10 10:44:16 2020 -0500 Merge remote-tracking branch 'upstream/emc/develop' into emc/develop commit f773ef3 Author: Denise Worthen <denise.worthen@noaa.gov> Date: Tue Nov 10 10:37:11 2020 -0500 Update CICE to consortium master (NOAA-EMC#23) updates include: * deprecate upwind advection (CICE-Consortium#508) * add implicit VP solver (CICE-Consortium#491) commit 2a0f332 Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Tue Nov 10 10:29:03 2020 -0500 update gitmodules, update icepack commit 41afe74 Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Fri Oct 30 17:47:51 2020 +0000 add ice_dyn_vp module to CICE_InitMod commit 2515f77 Merge: 1e4f42b 12fdb47 Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Fri Oct 30 11:14:19 2020 -0400 Merge remote-tracking branch 'consortium/master' into feature/updcice commit 1e4f42b Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Fri Oct 30 11:13:17 2020 -0400 update icepack commit 23cdee7 Merge: 8129aab ac617cd Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Thu Oct 8 07:17:42 2020 -0400 Merge remote-tracking branch 'upstream/emc/develop' into emc/develop commit ac617cd Author: Minsuk Ji <57227195+MinsukJi-NOAA@users.noreply.github.com> Date: Thu Oct 8 07:13:14 2020 -0400 Support TACC stampede (NOAA-EMC#19) commit 8129aab Merge: 6d30789 c0a2e2d Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Mon Aug 31 13:29:35 2020 -0400 Merge remote-tracking branch 'consortium/master' into emc/develop commit 6d30789 Merge: 5dcfca8 285985c Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Mon Aug 31 16:59:48 2020 +0000 Merge remote-tracking branch 'upstream/emc/develop' into emc/develop commit 285985c Author: Denise Worthen <denise.worthen@noaa.gov> Date: Mon Aug 31 12:53:02 2020 -0400 Update CICE6 for integration to S2S * add wcoss_dell_p3 compiler macro * update to icepack w/ debug fix * replace SITE with MACHINE_ID * update compile scripts commit 5dcfca8 Merge: 5ecde75 4d7ba5b Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Thu Aug 13 13:06:16 2020 -0400 Merge remote-tracking branch 'upstream/emc/develop' into emc/develop commit 4d7ba5b Merge: d81a834 eb77517 Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Thu Aug 13 12:57:55 2020 -0400 Merge remote-tracking branch 'upstream/master' into emc/develop commit d81a834 Author: Denise Worthen <denise.worthen@noaa.gov> Date: Thu Aug 13 09:40:18 2020 -0400 Fixcommit (NOAA-EMC#14) Align commit history between emc/develop and cice-consortium/master commit 5ecde75 Merge: 88cc2fd bdf1a1f Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Wed Aug 12 16:24:04 2020 -0400 Merge remote-tracking branch 'upstream/emc/develop' into emc/develop commit bdf1a1f Author: Denise Worthen <denise.worthen@noaa.gov> Date: Wed Aug 12 15:55:21 2020 -0400 changes for consistency w/ current emc-cice5 (NOAA-EMC#13) Update to emc/develop fork to current CICE consortium Co-authored-by: David A. Bailey <dbailey@ucar.edu> Co-authored-by: Tony Craig <apcraig@users.noreply.github.com> Co-authored-by: Elizabeth Hunke <eclare@lanl.gov> Co-authored-by: Mariana Vertenstein <mvertens@ucar.edu> Co-authored-by: apcraig <anthony.p.craig@gmail.com> Co-authored-by: Philippe Blain <levraiphilippeblain@gmail.com> commit 88cc2fd Merge: c084de4 003aae0 Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Wed Aug 5 18:35:50 2020 -0400 Merge remote-tracking branch 'upstream/master' into emc/develop commit c084de4 Merge: 86b8dab b055c7f Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Fri Jul 17 17:24:15 2020 -0400 Merge remote-tracking branch 'upstream/master' into emc/develop commit 86b8dab Merge: 9bdb9ad 8f37bfc Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Fri Jul 17 13:15:25 2020 +0000 Merge remote-tracking branch 'upstream/emc/develop' into HEAD commit 8f37bfc Author: Minsuk Ji <57227195+MinsukJi-NOAA@users.noreply.github.com> Date: Fri Jul 17 09:05:06 2020 -0400 cice6 compile (NOAA-EMC#6) * enable debug build. fix to remove errors * fix an error in comp_ice.backend.libcice * change Orion to orion for machine identification commit 9bdb9ad Merge: 916c6af c22c6d5 Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Wed Jul 15 13:15:02 2020 -0400 Merge remote-tracking branch 'CICE-Consortium/master' into emc/develop commit 916c6af Author: Denise Worthen <denise.worthen@noaa.gov> Date: Tue Jul 14 08:18:33 2020 -0400 add -link_mpi=dbg to debug flags (NOAA-EMC#8) commit 8ff4ee0 Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Tue Jul 7 15:46:57 2020 -0400 change Orion to orion in backend remove duplicate print lines from ice_transport_driver commit 4e8cc79 Merge: f92bef3 93f0e86 Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Tue Jul 7 15:32:13 2020 -0400 Merge remote-tracking branch 'upstream/nuopc' into emc/develop commit f92bef3 Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Tue Jul 7 15:20:45 2020 -0400 update icepack submodule commit 93f0e86 Merge: 8ebdda9 6b4a277 Author: David A. Bailey <dbailey@ucar.edu> Date: Tue Jul 7 13:19:36 2020 -0600 Merge pull request NOAA-EMC#5 from ESCOMP/coszen Add restart_coszen namelist option commit 6b4a277 Merge: 27dd3b7 8ebdda9 Author: David A. Bailey <dbailey@ucar.edu> Date: Tue Jul 7 13:19:22 2020 -0600 Merge branch 'nuopc' into coszen commit 50bf856 Merge: 3bb3694 fcf8989 Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Tue Jul 7 15:03:30 2020 -0400 Merge remote-tracking branch 'upstream/master' commit 27dd3b7 Author: David Bailey <dbailey@ucar.edu> Date: Tue Jul 7 12:40:33 2020 -0600 Add restart_coszen namelist option commit 8ebdda9 Merge: e4c989c 30a81cc Author: David A. Bailey <dbailey@ucar.edu> Date: Tue Jul 7 12:39:20 2020 -0600 Merge pull request NOAA-EMC#4 from mvertens/nuopc cleanup changes to nuopc branch commit 30a81cc Author: Mariana Vertenstein <mvertens@ucar.edu> Date: Tue Jul 7 12:17:21 2020 -0600 fixed white space issue commit e4c989c Merge: 178693a fcf8989 Author: David Bailey <dbailey@ucar.edu> Date: Mon Jul 6 10:24:24 2020 -0600 Merge branch 'master' of https://github.com/CICE-Consortium/CICE into nuopc commit aea1aa8 Merge: 178693a 41855fd Author: Mariana Vertenstein <mvertens@ucar.edu> Date: Sat Jul 4 15:04:13 2020 -0600 update to latest nuopc changes commit 41855fd Author: Mariana Vertenstein <mvertens@ucar.edu> Date: Sat Jul 4 14:29:12 2020 -0600 fixes to get cesm working commit 3a1b88b Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Sat Jul 4 13:25:48 2020 -0600 fix compile errors commit b4afd2e Author: Mariana Vertenstein <mvertens@ucar.edu> Date: Sat Jul 4 11:59:19 2020 -0600 removal of many cpp-ifdefs commit 178693a Merge: 902e883 c762336 Author: David Bailey <dbailey@ucar.edu> Date: Thu Jul 2 15:28:07 2020 -0600 Merge branch 'nuopc' of https://github.com/ESCOMP/CICE into nuopc commit 902e883 Author: David Bailey <dbailey@ucar.edu> Date: Thu Jul 2 15:27:55 2020 -0600 Fix logging issues for NUOPC commit 6bccf71 Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Thu Jul 2 13:19:25 2020 -0600 remove cesmcoupled ifdefs commit c762336 Author: David Bailey <dbailey@ucar.edu> Date: Thu Jul 2 11:36:49 2020 -0600 Move the forapps directory commit 46fcfba Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Thu Jul 2 05:24:54 2020 -0600 changes for coldstart running commit 73e7774 Author: David Bailey <dbailey@ucar.edu> Date: Wed Jul 1 14:41:27 2020 -0600 Fix additional OMP problems commit ad03424 Author: David Bailey <dbailey@ucar.edu> Date: Wed Jul 1 12:52:00 2020 -0600 Fix threading problem in init_bgc commit 239c7de Merge: b4da8a6 415df0e Author: David Bailey <dbailey@ucar.edu> Date: Wed Jul 1 12:50:38 2020 -0600 Merge branch 'nuopc' of https://github.com/ESCOMP/CICE into nuopc commit b4da8a6 Merge: 6affdcf 55ca18b Author: David Bailey <dbailey@ucar.edu> Date: Wed Jul 1 12:50:14 2020 -0600 Merge branch 'master' of https://github.com/CICE-Consortium/CICE into nuopc commit 415df0e Merge: b5a6058 6affdcf Author: David Bailey <dbailey@ucar.edu> Date: Wed Jul 1 10:08:07 2020 -0600 Merge branch 'nuopc' of https://github.com/ESCOMP/CICE into nuopc commit b5a6058 Merge: 7848fdf 55ca18b Author: David Bailey <dbailey@ucar.edu> Date: Wed Jul 1 10:07:31 2020 -0600 Merge branch 'master' of https://github.com/CICE-Consortium/CICE into nuopc commit 6affdcf Merge: 7848fdf c6c20bf Author: David Bailey <dbailey@ucar.edu> Date: Mon Jun 29 15:31:28 2020 -0600 Merge branch 'master' of https://github.com/CICE-Consortium/CICE into nuopc commit 089f60f Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Thu Jun 25 15:18:56 2020 +0000 update comp_ice.backend with temporary ice_timers fix commit 6982ee4 Merge: 308a1d4 7848fdf Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Thu Jun 25 14:03:59 2020 +0000 Merge remote-tracking branch 'upstream/nuopc' into HEAD commit 7848fdf Merge: 7e43703 f532dd9 Author: David Bailey <dbailey@ucar.edu> Date: Wed Jun 24 15:46:15 2020 -0600 Merge branch 'master' of https://github.com/CICE-Consortium/CICE into nuopc commit 308a1d4 Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Mon Jun 22 15:05:32 2020 -0600 Revert "update icepack submodule" This reverts commit e70d1ab. commit e70d1ab Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Mon Jun 22 14:58:13 2020 -0600 update icepack submodule commit f41f1e9 Merge: 7ac0e3d 7e43703 Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Mon Jun 22 20:52:39 2020 +0000 Merge remote-tracking branch 'upstream/nuopc' into HEAD commit 3bb3694 Author: Denise Worthen <denise.worthen@noaa.gov> Date: Fri Jun 5 13:32:44 2020 -0400 Convergence on ustar for CICE. (CICE-Consortium#452) (NOAA-EMC#5) * Add atmiter_conv to CICE * Add documentation * trigger build the docs Co-authored-by: David A. Bailey <dbailey@ucar.edu> commit 397e588 Merge: d46d691 2054d09 Author: denise.worthen <Denise.Worthen@noaa.gov> Date: Tue Jun 2 12:31:56 2020 -0400 Merge remote-tracking branch 'upstream/master' commit 7e43703 Merge: 80c9e6e 53715ea Author: David A. Bailey <dbailey@ucar.edu> Date: Tue May 26 09:15:51 2020 -0600 Merge pull request NOAA-EMC#3 from mvertens/mvertens/nuopc changes to satisfy ufsatm and cesm requirements for pot temp and density from atm commit 53715ea Author: Mariana Vertenstein <mvertens@ucar.edu> Date: Sun May 24 18:06:06 2020 -0600 put in changes so that both ufsatm and cesm requirements for potential temperature and density are satisfied commit 80c9e6e Merge: 8f0b5ee bce31c2 Author: David Bailey <dbailey@ucar.edu> Date: Tue May 19 09:09:00 2020 -0600 Merge branch 'master' of https://github.com/CICE-Consortium/CICE into nuopc commit 7ac0e3d Merge: 10e7c20 8f0b5ee Author: Denise Worthen <denise.worthen@noaa.gov> Date: Tue May 12 10:02:58 2020 -0400 Merge pull request #1 from ESCOMP/nuopc commit 8f0b5ee Merge: 10e7c20 ce8e5a9 Author: David A. Bailey <dbailey@ucar.edu> Date: Sun May 10 08:24:19 2020 -0600 Merge pull request #2 from apcraig/ufs01 Update CICE for coupling with UFS commit ce8e5a9 Author: apcraig <anthony.p.craig@gmail.com> Date: Sat May 9 21:29:22 2020 -0600 update CICE6 to support coupling with UFS commit 10e7c20 Author: Mariana Vertenstein <mvertens@ucar.edu> Date: Wed Apr 29 16:36:09 2020 -0600 fixed problems in updated orbital calculations needed for cesm commit 183218a Author: Mariana Vertenstein <mvertens@ucar.edu> Date: Thu Apr 23 17:43:35 2020 -0600 updated orbital calculations needed for cesm commit d46d691 Author: Denise Worthen <denise.worthen@noaa.gov> Date: Wed Apr 22 14:48:08 2020 -0400 merge latest master (NOAA-EMC#4) * Isotopes for CICE (CICE-Consortium#423) Co-authored-by: apcraig <anthony.p.craig@gmail.com> Co-authored-by: David Bailey <dbailey@ucar.edu> Co-authored-by: Elizabeth Hunke <eclare@lanl.gov> commit 71d2ded Merge: 99470ed 9ac1863 Author: Denise Worthen <denise.worthen@noaa.gov> Date: Thu Apr 2 15:13:02 2020 -0400 Merge pull request NOAA-EMC#3 from CICE-Consortium/master commit 99470ed Merge: 0338d04 7e2a1d9 Author: Denise Worthen <denise.worthen@noaa.gov> Date: Sat Mar 7 10:03:29 2020 -0500 Merge pull request #2 from CICE-Consortium/master commit 0338d04 Merge: b5134ad 7e11a34 Author: Denise Worthen <denise.worthen@noaa.gov> Date: Tue Feb 25 08:43:10 2020 -0500 Merge pull request #1 from CICE-Consortium/master Merge branch 'emc/develop' into feature/main6.4.2
DeniseWorthen
added a commit
to DeniseWorthen/CICE
that referenced
this pull request
Sep 22, 2023
DeniseWorthen
added a commit
to DeniseWorthen/CICE
that referenced
this pull request
Apr 7, 2024
commit f36559256eb08272cdfe0706c45e0824e00fb37b Author: Denise Worthen <denise.worthen@noaa.gov> Date: Sun Apr 7 09:50:39 2024 -0400 fix bad merge * this fixes a block of code w/in a CESMCOUPLED ifdef block commit cbac04dad1f79eb51900dab8bf6aaa7cddbe82a1 Merge: 5a56c38 7d4e5de Author: Denise Worthen <denise.worthen@noaa.gov> Date: Wed Apr 3 16:05:31 2024 -0400 Merge branch 'emc/develop' into feature/pio_options commit 5a56c38a0d73bf16ddf2024a23f3f3fe4432007a Author: Denise Worthen <denise.worthen@noaa.gov> Date: Wed Apr 3 15:44:33 2024 -0400 update with last emc/develop change commit aca835755aa82ead50040ea7e43ec63619667054 Author: Tony Craig <apcraig@users.noreply.github.com> Date: Thu Feb 22 08:55:44 2024 -0800 Update IO formats and add new IO namelist controls (#928) This provides new features for CICE IO both thru netCDF and PIO. New namelist are added to control history and restart format, hdf5 compression and chunking, the PIO rearranger, and PIO IO task control. Separate controls are provided for history and restart files. The namelist changes are for _history_format, restart_format history_rearranger, restart_rearranger history_iotasks, history_root, history_stride, restart_iotasks, restart_root, and restart_stride history_chunksize, history_deflate, restart_chunksize, restart_deflate._ In particular, - Update restart_format and history_format options to 'cdf1', 'cdf2', 'cdf5', 'hdf5', 'pnetcdf1', 'pnetcdf2', 'pnetcdf5', 'default'. The old options, 'default', 'pio_netcdf', and 'pio_pnetcdf' are still supported and backwards compatible with lcdf64, but are deprecated and no longer documented. The old options and old namelist lcdf64 are covered by the new options. Support of the old options should be removed in the future. Note that some problems were discovered when opening files with hdf5 format but reading non-hdf5 files with a spack built PIO/netCDF. As a result, the format specified for the restart read is always 'cdf1' which provides flexibility and robustness across software installs, although it may result in serial reads of hdf5 files when a parallel read could be done. - Deprecate lcdf64 namelist. This namelist is no longer needed and is covered by the new restart_format and history_format options. The namelist still exists and is backwards compatible with the old 'default', 'pio_netcdf', and 'pio_pnetcdf' format options, but is no longer documented. This should be removed in the future. - Add new namelist to control PIO pe/task setup (iotasks, root, stride) for history and restart. These settings control the PIO IO tasks. The root, stride, and iotasks are consistent with the MPI communicator. root=0 is the first MPI task. These control PIO IO performance and are usually a function of things like the IO and node hardware. See PIO for more information. CICE computes PIO iotask, root, and stride defaults for cases where -99 is passed in for some or all of these namelist. Those defaults are somewhat constrained by a bug in PIO, https://github.com/NCAR/ParallelIO/issues/1986. The current implementation avoids the bug by limiting the iotasks for some MPI task counts. This is noted in ice_pio.F90. - Add new namelist to control PIO rearranger (rearranger) for history and restart. Supports 'box', 'subset', and 'default'. These control how PIO rearrangment is carried out. default is equivalent to box and the box generally performs better. See PIO for more information. - Add new namelist to support hdf5 compression and chunking (deflate, chunksize) for history and restart. The deflate controls file compression and is an integer between 0 and 9 where 0 means no compression and 9 is maximum compression. Generally, the higher the number, the slower the IO and the smaller the file, but the optimal setting depends on the contents of the file. Chunksize provides a performance control for the hdf5 parallel writes. It is a 2d array and is associated with the size of the piece of the array written by hdf5. hdf5 can be read and written in parallel, but that depends on how netCDF and PIO are built. Note that prior version of PIO, including PIO1, do not support the hdf5 compression and chunking thru the PIO interface. - Add new namelist settings (set_nml files) and update the io_suite to cover the new IO options. Remove old namelist settings associated with the deprecated format options and the lcdf64 namelist. These deprecated feature are no longer tested. - Update documentation to add new namelist and IO features. - Update the nuopc/cmeps driver code to support the new features. - Update the default ice_in to add the new namelist. - Update the derecho netcdf module to a version that supports hdf5. - Clean up some code formatting (indentation) --------- Co-authored-by: Anton Steketee <anton.steketee@anu.edu.au> commit 9e9e5b3fabd88c429c4632baa8235187129e2dd7 Author: Philippe Blain <philippe.blain@canada.ca> Date: Mon Feb 19 14:08:37 2024 -0500 ug_testing.rst: also mention checking the base suite results (#934) In the "End-To-End Testing Procedure" section of the user guide, we instruct users to run a base suite and a test suite, but only mention checking the results of the test suite. Also mention checking the results of the base suite first, to make sure everything passes before checking the test suite. Suggested-by: Jean-Francois Lemieux <jean-francois.lemieux@canada.ca> commit 095e62a9342df74261b90fcb7a20d2ecdae2c5bc Author: Tony Craig <apcraig@users.noreply.github.com> Date: Mon Feb 12 14:49:02 2024 -0800 Update PULL_REQUEST_TEMPLATE to request detailed information (#931) Update PULL_REQUEST_TEMPLATE to request detailed information about changes associated with the PR. This will be useful for the commit log when squash merging the PR. --------- Co-authored-by: Philippe Blain <levraiphilippeblain@gmail.com> commit 1a00e5e4e967c8429a7753ac3597f9c1476cf6b7 Author: David A. Bailey <dbailey@ucar.edu> Date: Mon Feb 5 16:22:11 2024 -0700 Fix for ice_mesh_mod with grid variables removed (#929) commit 7a4b95e6deec0ec72c1da35a23ae1eb3ffe3d077 Author: Tony Craig <apcraig@users.noreply.github.com> Date: Mon Jan 22 11:12:13 2024 -0800 Update pio and netcdf error checks (#927) Update pio and netcdf error checks --------- Co-authored-by: anton-climate <anton.steketee@anu.edu.au> Co-authored-by: Anton Steketee <79179784+anton-seaice@users.noreply.github.com> commit 6449f40c41aa1a5c00096696202d7bd7ebd2a69a Author: JFLemieux73 <31927797+JFLemieux73@users.noreply.github.com> Date: Thu Jan 11 19:17:20 2024 +0000 Add vorticity as a diagnostic output (#924) * Added new variable vort for vorticity output * Added calc of diag vorticity for evp, vp and eap for B, C and CD grids * updated doc and ice_in file for new vorticity variable * Changed output frequency of vorticity from m to x * Added f_vort to set_nml.histall and set_nml.histdbg * Specified location of divu, shear and vort in ice_history.F90 --------- Co-authored-by: Tony Craig <apcraig@users.noreply.github.com> commit a20bfddf7a1260dbb61241e0838c678d2eecf972 Author: David A. Bailey <dbailey@ucar.edu> Date: Thu Jan 11 11:07:36 2024 -0700 scamn bugfix for nuopc driver (#926) Co-authored-by: John Truesdale <jet@ucar.edu> commit 1314e17b4213c6ce9424eab80763edf4b2ae867f Author: TRasmussen <33480590+TillRasmussen@users.noreply.github.com> Date: Thu Jan 11 18:25:52 2024 +0100 First round of housekeeping on ice_grid (#921) * removal of unused variables. * moved xav to transport. Could remove commented code. Could remove xav and yav as they are zero * Move derived parameters and only allocate if needed * bugfixes for cxp, cyp... * fix index and remove commented code in ice_grid * new version of transport_remap. xav, yav array where needed. xxav, yyav parameter * Removed comments rom ice_transport_remap and arrays for nonuniform grids commit 37f9a98b1b6529bc957fb888bd00348ab61c8b32 Author: Tony Craig <apcraig@users.noreply.github.com> Date: Thu Dec 21 07:15:02 2023 -0800 Fix single channel debug failure, Update github actions testing (#922) * update ghactions testing * refactor min/max global reductions, code away from huge which was giving MPI some problems. commit b14cedfaed8b81500fc5422cfc44b6d80e5893ef Author: David A. Bailey <dbailey@ucar.edu> Date: Tue Nov 28 15:10:16 2023 -0700 ice_history: allow per-stream suffix for history filenames (#912) * Add capability for h extension * Update documentation for hist_str * Change hist_str to hist_suffix * Change in default namelist * Update doc/source/cice_index.rst Co-authored-by: Philippe Blain <levraiphilippeblain@gmail.com> * One more hist_str --------- Co-authored-by: Philippe Blain <levraiphilippeblain@gmail.com> commit 21fab166fd2b8e903df366dbc1c518dabd08c23f Author: Tony Craig <apcraig@users.noreply.github.com> Date: Tue Nov 28 10:04:36 2023 -0800 Update Icepack to #f6ff8f7c4d4cb6f (#913) * Update Icepack to #f6ff8f7c4d4cb6f Split the developer guide infrastructure section from the dynamics documentation Add a coding standard section to the documentation Add a couple sentences about the state of the parameter nghost to the documentation Update opticep to use the latest main code for the unit test * update documentation commit 509e2c33e95e3a2370dc406fb2fe4d06192420a6 Author: Philippe Blain <philippe.blain@canada.ca> Date: Thu Nov 23 13:09:04 2023 -0500 ice_history: refactor CMIP history variables (#906) * ice_flux: zero-initialize divu and shear in init_history_dyn 'divu' and 'shear' are accessed in 'accum_hist' when writing the initial condition before they are initialized at the start of {eap, evp, implicit_solver}. This leads to runtime error when compiling with NaN initialization. Zero-initialize 'divu' and 'shear' in init_history_dyn, where the related variable 'strength' is already zero-initialized. * ice_history_shared: disallow 'x' in history frequency variables f_*' In the current code, nothing prevents users from leaving 'x' along with active frequencies in the individual namelist history frequency variables, for example: f_aice = 'xmd' This configuration does not work correctly, however. The corresponding history fields are correctly defined in ice_history_shared::define_hist_field, but since the calls to ice_history_shared::accum_hist_field in ice_history::accum_hist are only done after checking that the first element of each frequency variable is not 'x', the corresponding variables in the history files are all zero. Prevent that behaviour by actually disallowing 'x' in history frequency variables if any other frequencies are active. To implement that, add a check in the loop in define_hist_field, which loops through vhistfreq, (corresponding to f_aice, etc. in ice_history). Since this subroutine initializes 'id(:)' to zero and then writes a (non-zero) index in 'id' for any active frequency, it suffices to check that all previous indices are non-zero. * ice_history: remove uneeded conditions around CMIP history variables In ice_history::accum_hist, after the calls to accum_hist, we loop on the different output streams, and on the history variables in the avail_hist_fields array, to mask out land points and convert units for each output variable. Since 3c99e106 (Update CICE with CMIP changes. (#191), 2018-09-27), we also use this loop to do a special treatment for some CMIP variables (namely, averaging them only for time steps where ice is present, and masking points where ice is absent). This adjustment is done if the corresponding output frequency variable (f_sithick, etc.) does not have 'x' as its first element, and if the corresponding index in avail_hist_field for that variable/frequency (n_sithick(ns)) is not zero. Both conditions are in fact uneeded since they are always true. The first condition is always true because if the variable is found in the avail_hist_field array, which is ensured by the condition on line 3645, then necessarily its corresponding namelist output frequency won't have 'x' as its first character (since this is enforced in ice_history_shared::define_hist_field). The second condition is always true because if the variable is found in the avail_hist_field array, then necessarily its index in that array, n_<var>(ns), is non-zero (see ice_history_shared::define_hist_field). Remove these uneeded conditions. This commit is best viewed with git show --color-moved --color-moved-ws=allow-indentation-change * ice_history: use loop index directly for CMIP variables In ice_history::accum_hist, there is a special treatment for some CMIP variables where they are averaged only for time steps where ice is present, and points where there is no ice are masked. This is done on the loop on output streams (with loop index n). This special averaging is done by accessing a2D and a3Dc using the variable n_<var>(ns), which corresponds to the index in the avail_hist_field array where this history variable/frequency is defined. By construction, this index correponds to the loop index 'n', for both the 2D and the 3D loops. Simplify the code by using 'n' directly. * ice_history_shared: add two logical components to ice_hist_field At the end of ice_history::accum_hist, we do a special processing for some CMIP variables: we average them only for time steps where ice is present, and also mask ice-free points. The code to do that is repeated for each variable to which it applies. In order to reduce code duplication, let's introduce two new logical components to our 'ice_hist_field' type, defaulting them to .false., and make them optional arguments in ice_history_shared::define_hist_field. This allows us to avoid defining them for each output variable. We'll set them for CMIP variables in a following commit. * ice_history: set avg_ice_present, mask_ice_free_points for relevant CMIP variables In the previous commit, we added two components to type ice_hist_field (avg_ice_present and mask_ice_free_points), relating to some special treatment for CMIP variables (whether to average only for time steps where the ice is present and to mask ice-free points). Set these to .true. in the call to 'define_hist_field' for the relevant 2D variables [1], and set only 'avg_ice_present' to .true. for the 3D variables siitdthick and siitdsnthick, corresponding to the code under the "Mask out land points and convert units" loop in ice_history::accum_hist. [1] sithick siage sisnthick sitemptop sitempsnic sitempbot siu siv sidmasstranx sistrxdtop sistrydtop sistrxubot sistryubot sicompstren sispeed sidir sialb sihc siflswdtop siflswutop siflswdbot sifllwdtop sifllwutop siflsenstop siflsensupbot sifllatstop siflcondtop siflcondbot sipr sifb siflsaltbot siflfwbot siflfwdrain sidragtop sirdgthick siforcetiltx siforcetilty siforcecoriolx siforcecorioly siforceintstrx siforceintstry * ice_history: use avg_ice_present, mask_ice_free_points to reduce duplication Some CMIP variables are processed differently in ice_history::accum_hist: they are averaged only for time steps when ice is present, and points where ice is absent are masked. This processing is repeated for each of these variables in the 2D and 3Dc loops. To reduce code duplication, use the new components avg_ice_present and mask_ice_free_points of ice_hist_field to perform this processing only for variables that were defined accordingly. The relevant variables already have those components defined as of the previous commit. Note that we still need a separate loop for the variable 'sialb' (sea ice albedo) to mask points below the horizon. commit 1cf109b7c350f119e8e3cd8bd918fa31e61d829c Author: David A. Bailey <dbailey@ucar.edu> Date: Mon Nov 20 14:03:59 2023 -0700 Change to dealloc_grid in CICE_InitMod.F90 (#911) commit d14bb694f2f8df4e74361a9df999e82eaa44fc8b Author: Mads Hvid Ribergaard <38077893+mhrib@users.noreply.github.com> Date: Fri Nov 17 16:39:01 2023 +0100 Add missing logical "timer_stats" (#910) Co-authored-by: Mads Hvid Ribergaard <mhri@3vsrvp2.usr.dmi.dk> commit 8573ba8ab196c1e357a101462b16bd92128461b1 Author: TRasmussen <33480590+TillRasmussen@users.noreply.github.com> Date: Thu Nov 16 22:12:07 2023 +0100 New 1d evp solver (#895) * New 1d evp solver * Small changes incl timer names and inclued private/publice in ice_dyn_core1d * fixed bug on gnu debug * moved halo update to evp1d, added deallocation, fixed bug * fixed deallocation dyn_evp1d * bugfix deallocate * Remove gather strintx and strinty * removed 4 test with evp1d and c/cd grid * Update of evp1d implementation - Rename halo_HTE_HTN to global_ext_halo and move into ice_grid.F90 - Generalize global_ext_halo to work with any nghost size (was hardcoded for nghost=1) - Remove argument from dyn_evp1d_init, change to "use" of global grid variables - rename pgl_global_ext to save_ghte_ghtn - Update allocation of G_HTE, G_HTN - Add dealloc_grid to deallocate G_HTE and G_HTN at end of initialization - Add calls to dealloc_grid to all CICE_InitMod.F90 subroutines - Make dimension of evp1d arguments implicit size more consistently - Clean up indentation and formatting a bit * Clean up trailing blanks * resolved name conflicts * 1d grid var name change --------- Co-authored-by: apcraig <anthony.p.craig@gmail.com> commit 5d09123865b5e8b47ba9d3c389b23743d84908c1 Author: Mads Hvid Ribergaard <38077893+mhrib@users.noreply.github.com> Date: Fri Nov 10 01:17:24 2023 +0100 Rename sum to asum, as "sum" is also a generic fortran function (#905) Co-authored-by: Mads Hvid Ribergaard <mhri@3vsrvp2.usr.dmi.dk> commit 4450a3e8c64bc07d1173eb3e341cd8dea91d5068 Author: Tony Craig <apcraig@users.noreply.github.com> Date: Fri Oct 27 22:22:43 2023 -0700 Update Icepack to latest version, does not affect CICE (#903) commit ea241fa81a53b614f54cf5c2dad93bda20b72a78 Author: Tony Craig <apcraig@users.noreply.github.com> Date: Fri Oct 27 16:27:15 2023 -0700 Update version, remove trailing blanks (#901) commit 32f233d9728b4e453c0f02fb79a188517a8d5ed4 Author: Tony Craig <apcraig@users.noreply.github.com> Date: Fri Oct 27 16:27:01 2023 -0700 Update Icepack, add snicar and snicartest tests (#902) commit 0484dcd1410920f26375b7c280500a5bd16173e9 Author: Tony Craig <apcraig@users.noreply.github.com> Date: Fri Oct 27 09:24:52 2023 -0700 Split N/E grid computation out of Tlonlat, create NElonlat subroutine. (#899) * Split N/E grid computation out of Tlonlat, create NElonlat subroutine. See https://github.com/CICE-Consortium/CICE/issues/897 When TLON, TLAT, ANGLET are on the CICE grid, Tlonlat is NOT called. This meant N and E grid info was never computed. This would fail during history writing with invalid values in N and E grid arrays. And it would also cause problem if the C-grid were run with this type of CICE grid. There are no test grids that have TLON, TLAT, ANGLET on them, so this error was not found in standard test suites. This was detected by users. * Add gx3 grid/kmt files with TLON, TLAT, ANGLET netcdf grid test. The grid and kmt files were produced from a gx3 history file. Results are not bit-for-bit with the standard gx3 runs, but seem to be roundoff different initially (as expected). commit 0b5ca0911edaf6081ba891f4287af14ceb201c9f Author: Tony Craig <apcraig@users.noreply.github.com> Date: Thu Oct 26 19:33:19 2023 -0700 Revert "Add 5-band dEdd shortwave tests (#896)" (#900) This reverts commit b4abca479cd548c3e600a6c645447d5ba9464422. commit 2e13606558f7ce71633274bc38630caa23de3392 Author: Philippe Blain <philippe.blain@canada.ca> Date: Thu Oct 26 13:24:37 2023 -0400 doc: update histfreq_base and hist_avg descriptions (#898) * doc: ug_implementation.rst: do not use curly quotes The namelist excerpt in section 'History' of the Implementation part of the user guide uses curly quotes (’) instead of regular straight quotes ('). This is probably a remnant of the LaTeX version of the doc. These quotes can't be used in Fortran and so copy pasting from the doc to the namelist causes runtime failures. Use straigth quotes instead. * doc: ug_implementation.rst: align histfreq_n with histfreq Align frequencies with their respective streams, which makes the example clearer. * doc: ug_implementation.rst: avoid "now" and "still" The documentation talks about the current version of the code, so it is unnecessary to use words like "now" and "still" to talk about the model features. Remove them. * doc: ug_implementation.rst: mention histfreq_base and hist_avg are per-stream In 35ec167d (Add functionality to change hist_avg for each stream (#827), 2023-05-17), hist_avg was made into an array, allowing each stream to individually be set to instantaneous or averaged mode. The first paragraph of the "History" section of the user guide was updated, but another paragraph a little below was not. In 933b148c (Extend restart output controls, provide multiple frequency options (#850), 2023-08-24), histfreq_base was also made into an array, but the "History" section of the user guide was not updated. Adjust the wording of the doc to reflect the fact that both hist_avg and histfreq_base are per-stream. Also adjust the namelist excerpt to make histfreq_base an array, and align hist_avg with it. * doc: ug_implementation.rst: refer to 'timemanager' after mentioning histfreq_base In 34dc6670 (Namelist option for time axis position. (#839), 2023-07-06), the namelist option hist_time_axis was added, and the "History" section of the user guide updated to mention it. The added sentence, however, separates the mention of 'histfreq_base' and the reference to the "Time manager" section, which explains the different allowed values for that variable. Move the reference up so both are next to each other. commit b4abca479cd548c3e600a6c645447d5ba9464422 Author: Tony Craig <apcraig@users.noreply.github.com> Date: Thu Oct 26 08:54:40 2023 -0700 Add 5-band dEdd shortwave tests (#896) commit 624c28b19b443c031ea862e3e5d2c16387777ddc Author: Philippe Blain <philippe.blain@canada.ca> Date: Thu Oct 26 11:52:26 2023 -0400 ice_dyn_evp: pass 'grid_location' for LKD seabed stress on C grid (#893) When the C grid support was added in 078aab48 (Merge cgridDEV branch including C grid implementation and other fixes (#715), 2022-05-10), subroutine ice_dyn_shared::seabed_stress_factor_LKD gained a 'grid_location' optional argument to indicate where to compute intermediate quantities and the seabed stress itself (originally added in 0f9f48b9 (ice_dyn_shared: add optional 'grid_location' argument to seabed_stress_factor_LKD, 2021-11-17)). This argument was however forgotten in ice_dyn_evp::evp when this subroutine was adapted for the C grid in 48c07c66 (ice_dyn_evp: compute seabed stress factor at CD-grid locations, 2021-11-17), such that currently the seabed stress is not computed at the correct grid location for the C and CD grids. Fix that by correctly passing the 'grid_location' argument. Note that the dummy argument is incorrectly declared as 'intent(inout)' in the subroutine, so change that to 'intent(in)' so we can pass in character constants. Closes: https://github.com/CICE-Consortium/CICE/issues/891 commit d3698fb46fc23a81b1df8dba676a5a74d7e96a39 Author: daveh150 <david.hebert@nrlssc.navy.mil> Date: Wed Oct 25 16:34:35 2023 -0500 Add atm_data_version to allow JRA55 forcing filenames to have a unique version string (#876) * Add jra55date to allow JRA55 forcing to have creation date in file name * Changed jra55_date to atm_data_date. Added atm_data_date to docs. * Change jra55_date to atm_data_date. Update JRA55_files to include atm_data_date in file. Update case scripts/namelist. * change atm_data_date to atm_data_version. Update set_nml.tx1 default to corrected forcing version * Update doc to have atm_data_version in proper alphabetical order * Re-add set_nml.jra55. Deleted accitentally * Fix type-o in atm_data_dir documentation * Add atm_data_version to set_nml.jra55 * fix spacing after changing atm_data_date to atm_data_version * Change atm_data_date to atm_data_version * Comment out JRA55 file debugging * Update dg_forcing docs to describe atm_data_version string * Uncomment JRA55 filename check. Added check for debug_forcing before writing output * Correct doc format/links in dg_forcing.rst commit 8916b9ff2c58a3a095235bb5b4ce7e8a68f76e87 Author: Tony Craig <apcraig@users.noreply.github.com> Date: Wed Oct 18 14:08:21 2023 -0700 Update update_ocn_f implementation, Add cpl_frazil namelist (#889) * Update update_ocn_f implementation Add cpl_frazil namelist Add update_ocn_f and cpl_frazil to icepack_init_parameters call, set these values inside Icepack at initialization. Remove update_ocn_f argument from icepack_step_therm2 call Update runtime_diags and accum_hist to account for new Icepack and cpl_frazil implementation. These may need an addition update later. * Update documentation commit 6ba070f7e7027f9fd2cc32f2dbe10c9854511d93 Author: Tony Craig <apcraig@users.noreply.github.com> Date: Wed Oct 18 12:35:08 2023 -0700 Update Documentation to clarify Namelist Inputs (#888) * Update Documentation to clarify Namelist Inputs * Update documentation commit a9d6dc75f47a2898f1800ad4ddd96c4992e3bed0 Author: Tony Craig <apcraig@users.noreply.github.com> Date: Wed Oct 18 10:47:01 2023 -0700 Update input data area for Derecho, switch to campaign (#890) commit 5ddb74dfb8724ff90aa7e806d5bfcfb4a0990762 Author: Tony Craig <apcraig@users.noreply.github.com> Date: Wed Oct 18 10:46:40 2023 -0700 Remove cicedynB link (#887) Update documentation commit 96b43fb458fe00696d9532e547a3c5bff113f9f9 Author: Tony Craig <apcraig@users.noreply.github.com> Date: Wed Oct 18 10:46:25 2023 -0700 Update Icepack CPP USE_SNICARHC to NO_SNICARHC and update logic (#886) Update Icepack to version #0c548120ce44382 Oct 16, 2023 includes NO_SNICARHC commit 48a92ef6dd6bf7884ec8a16b2c082345accae385 Author: Tony Craig <apcraig@users.noreply.github.com> Date: Fri Oct 13 14:22:03 2023 -0700 Remove use of the deprecated "_old" tfrz_options in set_nml files. This (#883) changes answers for some test cases, as expected. Update tfrz_option implementation to not allow _old options. commit 276563041ea6a2b6b4c70cbfa5173fb85db7b47f Author: Tony Craig <apcraig@users.noreply.github.com> Date: Thu Oct 12 12:41:17 2023 -0700 Add perlmutter gnu, intel, cray port (#882) commit deb247bcec381615d01006bfa15dddf3a4f068fd Author: Tony Craig <apcraig@users.noreply.github.com> Date: Thu Oct 5 12:50:32 2023 -0700 Update CICE for E3SM Icepack modifications (#879) * Update CICE to run with eclare108213/Icepack branch snicar (#100) * Update CICE to run with eclare108213/Icepack branch snicar - including https://github.com/eclare108213/Icepack/pull/13, Sept 11, 2022 - Passes full CICE test suite on cheyenne with 3 compilers except alt04 changes answers for all compilers and all tests. CICE #fea412a55f was baseline. - Icepack submodule still points to standard version on main, need to be swapped manually to appropriate development version. * Remove faero_optics * update ciceexe string to account for USE_SNICARHC CPP * Update documentation * Update test suite to add modal testing * Point Icepack submodule to cice-consortium/E3SM-icepack-initial-integration Update to snicar branch merge, #8aef3f785ce * Add E3SM namelists for CICE. (#101) * New e3sm and e3smbgc namelist options * Update E3SM test options * Add a simple e3sm test suite * atmbndy is not actually different * Additional changes * add Tliquidus_max namelist parameter to CICE * Add Tf argument to icepack interfaces * Add constant option for tfrz_option * Fix some diagnostic prints and add to additional drivers * Update messages and change option in alt01 * Update implementation for latest version of Icepack - Update tfrz_option, add _old options for backwards bit-for-bit - Fix unittests - Add hi_min to namelist and tests * Update Icepack * Update to E3SM-Project/Icepack/cice-consortium/E3SM-icepack-initial-integration including Icepack1.3.3 release, Dec 15, 2022. * Update Icepack to E3SM-Project/Icepack #87db73ba6d93747a9, current head of cice-consortium/E3SM-icepack-initial-integration Feb 3, 2023 * Update boxchan1e and boxchan1n tests to tfrz_option = 'mushy_old' to recover Consortium main results Update Icepack to the latest hash on E3SM-Project Icepack cice-consortium/E3SM-icepack-initial-integration, #96f2fc707fc743d7 Prior commit was a merge from CICE Consortium Main, #d466031001cf447bcd64220c842dcd2707f61e9, Sept 29, 2023 * remove icepack * update icepack --------- Co-authored-by: David A. Bailey <dbailey@ucar.edu> Co-authored-by: Elizabeth Hunke <eclare@lanl.gov> commit d466031001cf447bcd64220c842dcd2707f61e90 Author: Tony Craig <apcraig@users.noreply.github.com> Date: Fri Sep 29 12:08:53 2023 -0700 Add single grid channel capability and test for C-grid (#875) * Added code for transport in one grid cell wide channels * Update remap advection to support transport in single gridcell channels Add single grid east and north channel configurations and tests * Update documentation * Remove temporary code comments --------- Co-authored-by: Jean-Francois Lemieux <jean-francois.lemieux@canada.ca> commit 55342ca7cb4a1be511ade6249e349cb8a8095881 Author: Dougie Squire <42455466+dougiesquire@users.noreply.github.com> Date: Tue Sep 26 03:49:09 2023 +1000 Fix mesh mask check in nuopc/cmeps cap (#873) commit a5bb4f9a0c180e325e2a5480832f588dbfdd25ec Author: Denise Worthen <denise.worthen@noaa.gov> Date: Fri Sep 15 16:01:00 2023 -0400 switch to cesm-style field names (#869) commit 01ed4db7c4e5857768a37e8b1fd7472ab5121827 Author: JFLemieux73 <31927797+JFLemieux73@users.noreply.github.com> Date: Fri Sep 15 19:59:55 2023 +0000 More accurate calculation of areafact in remapping (#849) * Modified doc to specify that l_fixed_area is T for C-grid * Initial modifs to calc areafact based on linear interpolation of left and rigth values * put back l_fixed_area = .true. for C-grid * added temporary comments for PR review * Modified areafac calc for case 1 and case 2 * Corrected minor compilation issues * Corrected conditions for case 1 to make sure areas add up * Small modif in l_fixed_area section to ensure only one condition is true * Modified conditions in locate triangle to be consistent with previous changes for case 1 * Use other edge areafac_c for TL, BL, TR and BR triangles * Some comments removed * Fixed out of bounds areafac_ce and now use earea and narea * Replaced ib,ie,jb,je in locate_triangle using ilo,ihi,jlo,jhi * Modified areafac for TL1, BL2, TR1 and BR2 for area flux consistency * Cosmetic changes * Added comment to explain latest change * Modification of bugcheck condition for l_fixed_area=T * update areafac_c, areafac_ce in halo in dynamics --------- Co-authored-by: apcraig <anthony.p.craig@gmail.com> commit 06282a538e03599aed27bc3c5506ccc31a590069 Author: Tony Craig <apcraig@users.noreply.github.com> Date: Fri Sep 8 11:26:45 2023 -0700 Update version to 6.4.2 (#864) Update License and Copyright Update Icepack for version/copyright commit 714bab97540e5b75c0f2b6c11cd061277cdb322d Author: Tony Craig <apcraig@users.noreply.github.com> Date: Thu Sep 7 14:20:29 2023 -0700 Update Cheyenne and Derecho ports (#863) * Update cheyenne and derecho ports cheyenne_intel updated to intel/19/1/1, mpt/2.25 cheyenne_gnu updated to gnu/8.3.0, mpt/2.25 cheyenne_pgi updated to pgi/19.9, mpt/2.22 derecho_intel minor updates derecho_intelclassic added derecho_inteloneapi added (not working) derecho_gnu added derecho_cray added derecho_nvhpc added cheyenne_pgi changed answers derecho_inteloneapi is not working, compiler issues fixes automated qc testing on cheyenne * Update permissions on env.chicoma_intel commit cbbac74cd9073dce8eb44fa23cabb573913aa44f Author: David A. Bailey <dbailey@ucar.edu> Date: Tue Sep 5 14:22:59 2023 -0600 Only print messages in CAP on master task (#861) commit 32dc48eae101749b437bd777c18830e3c397b17a Author: Tony Craig <apcraig@users.noreply.github.com> Date: Thu Aug 31 13:05:54 2023 -0700 Update Icepack to #23b6c1272b50d42ca, Aug 30, 2023 (#857) Includes thin ice enthalpy fix, not bit-for-bit. commit e8a69abde90b99fc6528d469b8698506a99f6e2a Author: Denise Worthen <denise.worthen@noaa.gov> Date: Mon Aug 28 16:00:41 2023 -0400 Add logging features to nuopc/cmeps cap; deprecates zsalinity in cap (#856) * merge latest master (#4) * Isotopes for CICE (#423) Co-authored-by: apcraig <anthony.p.craig@gmail.com> Co-authored-by: David Bailey <dbailey@ucar.edu> Co-authored-by: Elizabeth Hunke <eclare@lanl.gov> * updated orbital calculations needed for cesm * fixed problems in updated orbital calculations needed for cesm * update CICE6 to support coupling with UFS * put in changes so that both ufsatm and cesm requirements for potential temperature and density are satisfied * Convergence on ustar for CICE. (#452) (#5) * Add atmiter_conv to CICE * Add documentation * trigger build the docs Co-authored-by: David A. Bailey <dbailey@ucar.edu> * update icepack submodule * Revert "update icepack submodule" This reverts commit e70d1abcbeb4351195a2b81c6ce3f623c936426c. * update comp_ice.backend with temporary ice_timers fix * Fix threading problem in init_bgc * Fix additional OMP problems * changes for coldstart running * Move the forapps directory * remove cesmcoupled ifdefs * Fix logging issues for NUOPC * removal of many cpp-ifdefs * fix compile errors * fixes to get cesm working * fixed white space issue * Add restart_coszen namelist option * update icepack submodule * change Orion to orion in backend remove duplicate print lines from ice_transport_driver * add -link_mpi=dbg to debug flags (#8) * cice6 compile (#6) * enable debug build. fix to remove errors * fix an error in comp_ice.backend.libcice * change Orion to orion for machine identification * changes for consistency w/ current emc-cice5 (#13) Update to emc/develop fork to current CICE consortium Co-authored-by: David A. Bailey <dbailey@ucar.edu> Co-authored-by: Tony Craig <apcraig@users.noreply.github.com> Co-authored-by: Elizabeth Hunke <eclare@lanl.gov> Co-authored-by: Mariana Vertenstein <mvertens@ucar.edu> Co-authored-by: apcraig <anthony.p.craig@gmail.com> Co-authored-by: Philippe Blain <levraiphilippeblain@gmail.com> * Fixcommit (#14) Align commit history between emc/develop and cice-consortium/master * Update CICE6 for integration to S2S * add wcoss_dell_p3 compiler macro * update to icepack w/ debug fix * replace SITE with MACHINE_ID * update compile scripts * Support TACC stampede (#19) * update icepack * add ice_dyn_vp module to CICE_InitMod * update gitmodules, update icepack * Update CICE to consortium master (#23) updates include: * deprecate upwind advection (CICE-Consortium#508) * add implicit VP solver (CICE-Consortium#491) * update icepack * switch icepack branches * update to icepack master but set abort flag in ITD routine to false * update icepack * Update CICE to latest Consortium master (#26) update CICE and Icepack * changes the criteria for aborting ice for thermo-conservation errors * updates the time manager * fixes two bugs in ice_therm_mushy * updates Icepack to Consortium master w/ flip of abort flag for troublesome IC cases * add cice changes for zlvs (#29) * update icepack and pointer * update icepack and revert gitmodules * Fix history features - Fix bug in history time axis when sec_init is not zero. - Fix issue with time_beg and time_end uninitialized values. - Add support for averaging with histfreq='1' by allowing histfreq_n to be any value in that case. Extend and clean up construct_filename for history files. More could be done, but wanted to preserve backwards compatibility. - Add new calendar_sec2hms to converts daily seconds to hh:mm:ss. Update the calchk calendar unit tester to check this method - Remove abort test in bcstchk, this was just causing problems in regression testing - Remove known problems documentation about problems writing when istep=1. This issue does not exist anymore with the updated time manager. - Add new tests with hist_avg = false. Add set_nml.histinst. * revert set_nml.histall * fix implementation error * update model log output in ice_init * Fix QC issues - Add netcdf ststus checks and aborts in ice_read_write.F90 - Check for end of file when reading records in ice_read_write.F90 for ice_read_nc methods - Update set_nml.qc to better specify the test, turn off leap years since we're cycling 2005 data - Add check in c ice.t-test.py to make sure there is at least 1825 files, 5 years of data - Add QC run to base_suite.ts to verify qc runs to completion and possibility to use those results directly for QC validation - Clean up error messages and some indentation in ice_read_write.F90 * Update testing - Add prod suite including 10 year gx1prod and qc test - Update unit test compare scripts * update documentation * reset calchk to 100000 years * update evp1d test * update icepack * update icepack * add memory profiling (#36) * add profile_memory calls to CICE cap * update icepack * fix rhoa when lowest_temp is 0.0 * provide default value for rhoa when imported temp_height_lowest (Tair) is 0.0 * resolves seg fault when frac_grid=false and do_ca=true * update icepack submodule * Update CICE for latest Consortium master (#38) * Implement advanced snow physics in icepack and CICE * Fix time-stamping of CICE history files * Fix CICE history file precision * Use CICE-Consortium/Icepack master (#40) * switch to icepack master at consortium * recreate cap update branch (#42) * add debug_model feature * add required variables and calls for tr_snow * remove 2 extraneous lines * remove two log print lines that were removed prior to merge of driver updates to consortium * duplicate gitmodule style for icepack * Update CICE to latest Consortium/main (#45) * Update CICE to Consortium/main (#48) Update OpenMP directives as needed including validation via new omp_suite. Fixed OpenMP in dynamics. Refactored eap puny/pi lookups to improve scalar performance Update Tsfc implementation to make sure land blocks don't set Tsfc to freezing temp Update for sea bed stress calculations * fix comment, fix env for orion and hera * replace save_init with step_prep in CICE_RunMod * fixes for cgrid repro * remove added haloupdates * baselines pass with these extra halo updates removed * change F->S for ocean velocities and tilts * fix debug failure when grid_ice=C * compiling in debug mode using -init=snan,arrays requires initialization of variables * respond to review comments * remove inserted whitespace for uvelE,N and vvelE,N * Add wave-cice coupling; update to Consortium main (#51) * add wave-ice fields * initialize aicen_init, which turns up as NaN in calc of floediam export * add call to icepack_init_wave to initialize wavefreq and dwavefreq * update to latest consortium main (PR 752) * add initializationsin ice_state * initialize vsnon/vsnon_init and vicen/vicen_init * Update CICE (#54) * update to include recent PRs to Consortium/main * fix for nudiag_set allow nudiag_set to be available outside of cesm; may prefer to fix in coupling interface * Update CICE for latest Consortium/main (#56) * add run time info * change real(8) to real(dbl)kind) * fix syntax * fix write unit * use cice_wrapper for ufs timer functionality * add elapsed model time for logtime * tidy up the wrapper * fix case for 'time since' at the first advance * add timer and forecast log * write timer values to timer log, not nu_diag * write log.ice.fXXX * only one time is needed * modify message written for log.ice.fXXX * change info in fXXX log file * Update CICE from Consortium/main (#62) * Fix CESMCOUPLED compile issue in icepack. (#823) * Update global reduction implementation to improve performance, fix VP bug (#824) * Update VP global sum to exclude local implementation with tripole grids * Add functionality to change hist_avg for each stream (#827) * Update Icepack to #6703bc533c968 May 22, 2023 (#829) * Fix for mesh check in CESM driver (#830) * Namelist option for time axis position. (#839) * reset timer after Advance to retrieve "wait time" * add logical control for enabling runtime info * remove zsal items from cap * fix typo --------- Co-authored-by: apcraig <anthony.p.craig@gmail.com> Co-authored-by: David Bailey <dbailey@ucar.edu> Co-authored-by: Elizabeth Hunke <eclare@lanl.gov> Co-authored-by: Mariana Vertenstein <mvertens@ucar.edu> Co-authored-by: Minsuk Ji <57227195+MinsukJi-NOAA@users.noreply.github.com> Co-authored-by: Tony Craig <apcraig@users.noreply.github.com> Co-authored-by: Philippe Blain <levraiphilippeblain@gmail.com> Co-authored-by: Jun.Wang <Jun.Wang@noaa.gov> commit 933b148cb141a16d74615092af62c3e8d36777a2 Author: Tony Craig <apcraig@users.noreply.github.com> Date: Thu Aug 24 10:23:56 2023 -0700 Extend restart output controls, provide multiple frequency options (#850) * Extend restart output controls, provide multiple streams for possible output frequencies. Convert dumpfreq, dumpfreq_n, dumpfreq_base to arrays. Modify histfreq_base to make it an array as well. Now each history stream can have it's own base time (init or zero). Update documentation. * Clean up implementation and documentation * Update PR to check github actions commit 357103a2df0428089d54bdacf9eab621a5e1f710 Author: Tony Craig <apcraig@users.noreply.github.com> Date: Tue Aug 22 11:27:28 2023 -0700 Deprecate zsalinity (#851) * Deprecate zsalinity, mostly with ifdef and comments first for testing * Deprecate zsalinity, remove code * Add warning message for deprecated zsalinity * Update Icepack to #f5e093f5148554674 (deprecate zsalinity) commit 8322416793ae2b76c2bafa9c7b9b108c289ede9d Author: Elizabeth Hunke <eclare@lanl.gov> Date: Fri Aug 18 17:34:24 2023 -0600 Updates to advanced snow physics implementation (#852) * Replace tr_snow flag with snwredist, snwgrain in some places (tr_snow is still used more generally). Fix intent(out) compile issue in ice_read_write.F90. Replace badger with chicoma machine files. * update icepack to 86cae16d1b7c4c4f8 --------- Co-authored-by: apcraig <anthony.p.craig@gmail.com> commit 7e8dc5b2aeffe98a6a7fd91dbb8e93ced1e3369c Author: Tony Craig <apcraig@users.noreply.github.com> Date: Thu Aug 10 13:06:41 2023 -0700 Update conda_macos to fix problems with Github Actions testing (#853) * test ghactions * update master to main in github actions commit 4cb296c4003014fe57d6d00f86868a78a532fc95 Author: JFLemieux73 <31927797+JFLemieux73@users.noreply.github.com> Date: Tue Jul 25 16:11:33 2023 +0000 Modification of edge mask computation when l_fixed_area=T in horizontal remapping (#833) * Use same method whether l_fixed_area=T or F to compute masks for edge fluxes * Corrected typo in comment * Cosmetic (indentation) change in ice_transport_remap.F90 * Set l_fixed_area value depending of grid type * Modifs to the doc for l_fixed_area * Use umask for uvel,vvel initialization for boxslotcyl and change grid avg type from S to A in init_state * Temporary changes before next PR: l_fixed_area=F for B and C grid * Temporary changes before next PR: remove paragraph in the doc * Small modifs: l_fixed_area and grid_ice are defined in module ice_transport_remap commit 9f42a620e9e642c637d8f04441bacb5835ebf0b7 Author: Tony Craig <apcraig@users.noreply.github.com> Date: Thu Jul 20 14:59:42 2023 -0700 Update Icepack to Consortium main #4728746, July 18 2023 (#846) - fix optional arguments issues - fix hsn_new(1) bug Update optargs unit test, add new test cases Add opticep unit test, to test CICE calls to Icepack without optional arguments. Add new comparison option to comparelog.csh to compare a unit test with a standard CICE test. Update unittest_suite Update documentation about optional arguments and unit tests commit f9d3002c86e11ca18b06382fc2d0676c9a945223 Author: Tony Craig <apcraig@users.noreply.github.com> Date: Thu Jul 13 16:01:26 2023 -0700 Add support for JRA55do (#843) * updating paths for local nrlssc builds * Add jra55do forcing option * Updated env.nrlssc_gnu for new local directory structure * Added JRA55do to file names. Added comments for each variable name at top of JRA55do_???_files subroutine * Make JRA55 forcing to use common subroutines. Search atm_data_type for specific cases * remove extraneous 'i' variable in JRA55_files * Changed JRA55 filename JRA55_grid instead of grid at end of filename * Add jra55do tests to base_suite and quick_suite. This is done via set_nml options. * Update forcing implementation to provide a little more flexibility for JRA55, JRA55do, and ncar bulk atm forcing files. * Update documentation * update Onyx port * Update forcing documentation Initial port to derecho_intel * clean up blank spaces --------- Co-authored-by: daveh150 <david.hebert@nrlssc.navy.mil> commit 766ff8d9606ae08bdd34ac2b36b6b068464c7e71 Author: Tony Craig <apcraig@users.noreply.github.com> Date: Tue Jul 11 07:53:22 2023 -0700 Update Icepack to #d024340f19676b July 6, 2023 (#841) Remove deprecated COREII LYq forcing Remove deprecated print_points_state Update links in rst documentation to point to main, not master commit 34dc66707f6b691b1689bf36689591af3e8df270 Author: David A. Bailey <dbailey@ucar.edu> Date: Thu Jul 6 21:46:58 2023 -0600 Namelist option for time axis position. (#839) * Add option to change location in interval of time axis * Only use hist_time_axis when hist_avg is true * Add more comments and information in the documentation * Add a check on hist_time_axis as well as a global attribute * Abort if hist_time_axis is not set correctly. commit 7eb4dd7e7e2796c5718061d06b86ff602b9d29cc Author: Tony Craig <apcraig@users.noreply.github.com> Date: Tue Jun 20 09:40:55 2023 -0700 Update .readthedocs.yaml, add pdf (#837) * update readthedocs.yaml, turn on pdf * update readthedocs.yaml, turn on pdf * update readthedocs.yaml, turn on pdf * update readthedocs.yaml, turn on pdf commit 8e2aab217ece5fae933a1f2ad6e0d6ab81ecad8a Author: David A. Bailey <dbailey@ucar.edu> Date: Tue Jun 20 08:54:25 2023 -0600 Fix for mesh check in CESM driver (#830) * Fix for mesh check in CESM driver * Slightly different way to evaluate longitude difference * Slightly different way to evaluate longitude difference * Put the abs inside the mod * Add abort calls back in commit b98b8ae899fb2a1af816105e05470b829f8b3294 Author: Tony Craig <apcraig@users.noreply.github.com> Date: Wed May 24 09:56:10 2023 -0700 Update Icepack to #6703bc533c968 May 22, 2023 (#829) Remove trailing blanks via automated tool in some Fortran files commit 35ec167dc6beee685a6e9485b8a1db3604d566bd Author: David A. Bailey <dbailey@ucar.edu> Date: Wed May 17 14:56:26 2023 -0600 Add functionality to change hist_avg for each stream (#827) * Add functionality to change hist_avg for each stream * Fix some documentation * Try to fix sphinx problem * Fix hist_avg documentation * Add some metadata changes to time and time_bounds commit 5b0418a9f6d181d668ddebdc2c540566529e4125 Author: Tony Craig <apcraig@users.noreply.github.com> Date: Wed Apr 5 13:29:21 2023 -0700 Update global reduction implementation to improve performance, fix VP bug (#824) * Update global reduction implementation to improve performance, fix VP bug This was mainly done for situations like VP that need a fast global sum. The VP global sum is still slightly faster than the one computed in the infrastructure, so kept that implementation. Found a bug in the workspace_y calculation in VP that was fixed. Also found that the haloupdate call as part of the precondition step generally improves VP performance, so removed option to NOT call the haloupdate there. Separately, fixed a bug in the tripoleT global sum implementation, added a tripoleT global sum unit test, and resynced ice_exit.F90, ice_reprosum.F90, and ice_global_reductions.F90 between serial and mpi versions. - Refactor global sums to improve performance, move if checks outside do loops - Fix bug in tripoleT global sums, tripole seam masking - Update VP solver, use local global sum more often - Update VP solver, fix bug in workspace_y calculation - Update VP solver, always call haloupdate during precondition - Refactor ice_exit.F90 and sync serial and mpi versions - Sync ice_reprosum.F90 between serial and mpi versions - Update sumchk unit test to handle grids better - Add tripoleT sumchk test * Update VP global sum to exclude local implementation with tripole grids commit 942449751275ebd884abb5752d03d7ea64b72664 Author: David A. Bailey <dbailey@ucar.edu> Date: Thu Mar 23 16:46:05 2023 -0600 Fix CESMCOUPLED compile issue in icepack. (#823) * Fix CESMCOUPLED compile problem in icepack
DeniseWorthen
added a commit
to DeniseWorthen/CICE
that referenced
this pull request
May 10, 2024
DeniseWorthen
added a commit
to DeniseWorthen/CICE
that referenced
this pull request
May 10, 2024
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
See ufs-community/ufs-weather-model#1562 for details of testing.