-
Notifications
You must be signed in to change notification settings - Fork 252
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
Unable to read in CRTM coefficients, using inline post, while running GNU executables on Hera #2537
Comments
Inline post should run using the GNU compiler. Since the code currently does not have We should use all fortran unformatted files using native endianness, which is little endian these days on all the platforms we support, and avoid setting the conversion flag globally. I see CRTM provides both little and big endian version of this file: https://github.com/JCSDA/crtm/blob/v2.4.0_emc.3/fix/SpcCoeff/Little_Endian/imgr_g15.SpcCoeff.bin https://github.com/JCSDA/crtm/blob/v2.4.0_emc.3/fix/SpcCoeff/Big_Endian/imgr_g15.SpcCoeff.bin Can you try to use little endian version? |
Hello @DusanJovic-NOAA. I was able to successfully run the inline post test using little endian CRTM coefficient files. Unfortunately, there are two issues with using the little endian CRTM coefficient files:
Is NCO planning on moving to native endian files for Linux machines, or will they continue to use the old IBM big endian files? If they will change to little endian, then I can close this issue and wait until the convert flags are removed to move forward with this. If there are no plans to use little endian files, then the path forward isn't clear. |
I don't know whether NCO has any plans regarding moving to native endian files or not. I checked the implementation standards document (here) and I do not see any mention of required endiannes of fortran unformatted files. If in fact there aren't any such requirements, then I guess each system can choose whatever format is most convenient. In that sense, we (the ufs community) should be able to choose to use whatever we want. The only issue we need to be aware of is that all unformatted files from all components must use the same endiannes, which is currently not the case, as you found, some files used by ccpp are little-endian, while some upp files are big-endian. This is important when GNU compiler is used. In addition to using unformatted files with same endiannes within the ufs-weather-model and all of its components it would be nice to be consistent with other programs for example standalone UPP, or other preprocessor /postprocessor programs, so that workflows do not need to have two sets of files, one for the model executable, one for other programs. |
Description
While running the weather model on Hera using GNU-built executables, inline post is failing while using the
postxconfig-NT-rrfs.txt
post config file. This configuration uses simulated radiances, thus requiring to read in CRTM coefficients. The inline post is failing with the following error messages:Looking in
cmake/GNU.cmake
, I noted that there was no-fconvert=big-endian
in the Fortran flags. Adding this flag allows the inline post to successfully run, but other tests failed in the weather model:Should inline post not be run using GNU-built executables?
To Reproduce:
The SRW App only runs GNU tests on Hera, but this would likely apply to all machines that can allow for GNU builds.
git clone -b feature/hash_update [email protected]:MichaelLueken/ufs-srweather-app.git
cd ufs-srweather-app
./manage_externals/checkout_externals
./devbuild.sh -p=hera -c=gnu
module use modulefiles
module load wflow_hera
conda activate srw_app
cd tests/WE2E
./run_WE2E_tests.py -t fundamental -m hera -a <account> -c gnu
(replace with your project on Hera) and see the inline post test fail with the above error message in../../../expt_dirs/grid_RRFS_CONUScompact_25km_ics_HRRR_lbcs_RAP_suite_RRFS_v1beta/log/run_fcst_mem000_2020081000.log
The text was updated successfully, but these errors were encountered: