Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Update intel compile to Intel2022 #571

Merged
merged 71 commits into from
Sep 12, 2023
Merged
Show file tree
Hide file tree
Changes from 4 commits
Commits
Show all changes
71 commits
Select commit Hold shift + click to select a range
9efbe3b
Merge pull request #1 from NOAA-EMC/master
DavidHuber-NOAA Sep 10, 2020
556e3e3
Merge branch 'NOAA-EMC:master' into master
DavidHuber-NOAA Sep 21, 2021
437b189
Merge branch 'NOAA-EMC:develop' into master
DavidHuber-NOAA Jan 27, 2023
da439e1
fix several bugs found when uses 2022.01 intel compiler.
hu5970 May 5, 2023
9e88613
Merge remote-tracking branch 'upstream/develop' into HEAD
hu5970 May 9, 2023
1359145
Update Hera Intel compiler to intel 2022.01.
hu5970 May 9, 2023
362c767
Update intel compile for Jet and Orion for using intel 2022.1
hu5970 May 10, 2023
437d6fb
Update S4 module, remove TODO. #447
DavidHuber-NOAA May 10, 2023
3fcb166
Merge pull request #6 from DavidHuber-NOAA/intel2022_dh
hu5970 May 10, 2023
caf22c0
Merge branch 'NOAA-EMC:develop' into master
DavidHuber-NOAA May 11, 2023
f5d200d
Fix out of bounds ref and cleanup. #447
DavidHuber-NOAA May 17, 2023
8c2ead4
Fixed out of bounds and vector assignment bugs #471
DavidHuber-NOAA May 19, 2023
619ecd8
Merge pull request #7 from DavidHuber-NOAA/intel2022_dh
hu5970 May 19, 2023
6dca839
Decrease radar memory footprint. #471
DavidHuber-NOAA May 19, 2023
aa42971
Removed duplicate call to read_hdraob #471
DavidHuber-NOAA May 19, 2023
d8f09b5
Merge remote-tracking branch 'ming/intel2022' into intel2022_dh
May 25, 2023
b6d8af0
Merge remote-tracking branch 'emc/develop' into intel2022_dh
May 26, 2023
6383ae7
Fix out of bounds error, trim system calls, optimize do loop #447
May 26, 2023
59b9e26
Revert to Fortran-created directories. Move metadata screening to ncd…
DavidHuber-NOAA May 26, 2023
f5b0b23
Let one PE create directories #447
Jun 2, 2023
facd50f
Merge remote-tracking branch 'emc/develop' into intel2022_dh
Jun 2, 2023
d134822
Add ncdiag v1.1.0, update Cheyenne Intel location. #447
Jun 5, 2023
5d4cf66
Merge pull request #8 from DavidHuber-NOAA/intel2022_dh
hu5970 Jun 5, 2023
bac7531
Updated ncdiag version in ci/spack.yaml #447
Jun 5, 2023
4fb0a04
Merge remote-tracking branch 'emc/develop' into intel2022_dh
Jun 6, 2023
b601e59
Stop if allocations fail. #571
Jun 6, 2023
9434673
Merge pull request #9 from DavidHuber-NOAA/intel2022_dh
hu5970 Jun 9, 2023
f01cca6
Gaea modulefile update, fix files location update on Jet,Hera,Orion,G…
Jun 14, 2023
aace46e
Gaea modulefile update
Jun 14, 2023
f842350
Merge remote-tracking branch 'upstream/develop' into intel2022_dh
Jun 21, 2023
db70960
Merge remote-tracking branch 'ming/intel2022' into intel2022_dh
Jun 21, 2023
56a22ca
Fixed directory creation. #571
Jun 22, 2023
ea336c6
Reverted regression_var.sh.
Jun 22, 2023
e5d89c3
Update Gaea and Cheyenne modulefiles.
Jun 22, 2023
06772e5
Merge pull request #10 from DavidHuber-NOAA/intel2022_dh
hu5970 Jun 22, 2023
3bf5e01
Modulefile for Gaea and regression tests configuration
Jun 23, 2023
1fe104e
Merge branch 'intel2022_gaea' into gaea_intel2022
natalie-perlin Jun 23, 2023
ff26a62
Merge pull request #1 from natalie-perlin/gaea_intel2022
natalie-perlin Jun 23, 2023
fe42c85
Intel 2022 for Gaea,update tests scripts for Gaea, Cheyenne, Orion, Jet
Jun 26, 2023
a7a6a2e
Merge branch 'intel2022_gaea' of github.com:natalie-perlin/GSI into i…
Jun 26, 2023
3baf6c7
update Cheyenne modulefile
Jun 26, 2023
d3fe9a2
updatesto scripts to address comments
Jun 26, 2023
7bd5f95
update regression/regression_driver.sh
Jun 26, 2023
e50cf96
update regression/regression_driver.sh
Jun 26, 2023
a0e48e2
update ush/build.sh
Jun 26, 2023
4864e07
Merge remote-tracking branch 'ming/intel2022' into intel2022_gaea
Jun 27, 2023
1d8beed
fixed typ inmodulefile for gaea
Jun 27, 2023
e2398c7
ncdiag/1.1.1 for spack build
Jun 28, 2023
164126b
update ncdiag/1.1.1
Jun 28, 2023
8d6009b
gaea modulefile update
Jun 28, 2023
29a1bb6
updated test scripts for gaea
Jun 28, 2023
c077a1c
Merge pull request #11 from natalie-perlin/intel2022_gaea
hu5970 Jun 29, 2023
44feb8a
update hera.gnu modulefile to use epic hpc-stack, load ncdiag from ma…
RussTreadon-NOAA Jul 1, 2023
ffba673
Merge branch 'NOAA-EMC:develop' into intel2022
RussTreadon-NOAA Jul 1, 2023
3d47231
remove w3nco from gsi_common.lua and gsi_cheyenne.gnu.lua
RussTreadon-NOAA Jul 10, 2023
06ad860
Merge pull request #12 from RussTreadon-NOAA/intel2022
hu5970 Jul 10, 2023
d0fdffc
update gsi_wcoss2.lua to ncdiag/1.1.1 and nemsio/2.5.4, update gnu co…
RussTreadon-NOAA Jul 10, 2023
fb580f1
Remove labels to fix RT on Orion and Jet #447 (#14)
DavidHuber-NOAA Aug 1, 2023
1e819ea
Update Orion stack location for the new role-epic account (#15)
natalie-perlin Aug 1, 2023
1ccf38d
Merge branch 'NOAA-EMC:develop' into intel2022
RussTreadon-NOAA Aug 7, 2023
e9b24d6
Added a new chadmin template to detect_machine.sh #595 (#16)
DavidHuber-NOAA Aug 7, 2023
04a4336
Merge branch 'develop' into intel2022
RussTreadon-NOAA Aug 10, 2023
e4fc198
use sub-communicator for parallel netcdf io in gsi_rfv3io_mod.f90 (#447)
RussTreadon-NOAA Aug 18, 2023
91ca898
modifications for acorn (wcoss2 test system) build using intel19 spac…
RussTreadon-NOAA Aug 21, 2023
06ed4d7
add version numbers to module loads in gsi_common_wcoss2.lua (#447)
RussTreadon-NOAA Aug 21, 2023
f4524b9
Merge branch 'develop' into intel2022
RussTreadon-NOAA Sep 11, 2023
1485b20
revert gsi_wcoss2.lua to develop (#447)
RussTreadon-NOAA Sep 11, 2023
5edbe26
Merge branch 'NOAA-EMC:develop' into intel2022
RussTreadon-NOAA Sep 12, 2023
7cb76d8
update nemsio version in spack.yaml, clean up sub_wcoss2 (#447)
RussTreadon-NOAA Sep 12, 2023
047001b
remove gsi_common_wcoss2.lua since no longer used (#447)
RussTreadon-NOAA Sep 12, 2023
dc96296
generalize machine specific sub scripts to allow different modulefile…
RussTreadon-NOAA Sep 12, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 4 additions & 2 deletions modulefiles/gsi_common.lua
Original file line number Diff line number Diff line change
Expand Up @@ -6,12 +6,13 @@ local netcdf_ver=os.getenv("netcdf_ver") or "4.7.4"

local bufr_ver=os.getenv("bufr_ver") or "11.7.0"
local bacio_ver=os.getenv("bacio_ver") or "2.4.1"
local w3emc_ver=os.getenv("w3emc_ver") or "2.9.1"
local w3emc_ver=os.getenv("w3emc_ver") or "2.9.2"
local w3nco_ver=os.getenv("w3nco_ver") or "2.4.1"
Copy link
Contributor

Choose a reason for hiding this comment

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

Why is is necessary to add w3nco to the list of common modules to build with intel2022?

Copy link
Collaborator

Choose a reason for hiding this comment

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

@RussTreadon-NOAA w3nco was loaded by nemsio versions 2.5.2 and earlier, but is no longer, so it now needs to be loaded explicitly.

Copy link
Contributor

Choose a reason for hiding this comment

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

Thanks for the explanation.

Copy link
Contributor

Choose a reason for hiding this comment

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

@DavidHuber-NOAA
If you are loading nemsio, 2.5.4, it depends on w3emc. You no longer need w3nco.

Copy link
Contributor

Choose a reason for hiding this comment

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

Copy link
Collaborator

Choose a reason for hiding this comment

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

@aerorahul I removed the w3nco load. Thanks! Note there is a placeholder for the new ncdiag library here which provides a local install on Hera presently. I will update this when the new ncdiag PR is merged and the new tag is installed everywhere.

local sp_ver=os.getenv("sp_ver") or "2.3.3"
local ip_ver=os.getenv("ip_ver") or "3.3.3"
local sigio_ver=os.getenv("sigio_ver") or "2.3.2"
local sfcio_ver=os.getenv("sfcio_ver") or "1.4.1"
local nemsio_ver=os.getenv("nemsio_ver") or "2.5.2"
local nemsio_ver=os.getenv("nemsio_ver") or "2.5.4"
local wrf_io_ver=os.getenv("wrf_io_ver") or "1.2.0"
local ncio_ver=os.getenv("ncio_ver") or "1.1.2"
local crtm_ver=os.getenv("crtm_ver") or "2.4.0"
Expand All @@ -22,6 +23,7 @@ load(pathJoin("netcdf", netcdf_ver))
load(pathJoin("bufr", bufr_ver))
load(pathJoin("bacio", bacio_ver))
load(pathJoin("w3emc", w3emc_ver))
load(pathJoin("w3nco", w3nco_ver))
load(pathJoin("sp", sp_ver))
load(pathJoin("ip", ip_ver))
load(pathJoin("sigio", sigio_ver))
Expand Down
17 changes: 8 additions & 9 deletions modulefiles/gsi_hera.intel.lua
Original file line number Diff line number Diff line change
@@ -1,24 +1,23 @@
help([[
]])

prepend_path("MODULEPATH", "/scratch2/NCEPDEV/nwprod/hpc-stack/libs/hpc-stack/modulefiles/stack")
prepend_path("MODULEPATH", "/scratch1/NCEPDEV/nems/role.epic/miniconda3/modulefiles")
Copy link
Contributor

Choose a reason for hiding this comment

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

Does this prepend_path point at the official installation all UFS and EMC apps should use?

Copy link
Member

Choose a reason for hiding this comment

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

Others should also confirm but the MODULEPATHs I see in this PR jive with the ones that ufs-weather-model moved to (ufs-community/ufs-weather-model#1465) and which global-workflow and other components are also moving to. The ufs-weather-model issue I refer to has a nice listing at the top of the various machine installs.

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

The updated prepend_path and module versions all come from ufs-weather-model develop for Hera, Jet, and Orion.
I did not change setup for other machines because I cannot access them. But the ufs-weather-model develop still use intel 19 for wcoss2, which should be updated for both model and GSI.

Copy link
Contributor

Choose a reason for hiding this comment

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

Let's work with g-w and others to update as many modulefiles as possible. Tagging @KateFriedman-NOAA , natalie-perlin, and @GeorgeVandenberghe-NOAA , and [email protected]. Should anyone be removed from this list? Should anyone be added?

Copy link
Member

Choose a reason for hiding this comment

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

Looks like all of the (fully) supported R&D platforms are covered in this PR (Hera, Orion, Jet). @DavidHuber-NOAA is providing updates for S4 (low support). WCOSS2 is not considered in this PR since it's only intel 2019 still and not EPIC-maintained hpc-stacks. Will update WCOSS2 to intel 2022 at a later date (likely when we move to spack-stack but not 100% on that). Updates in this PR should not break WCOSS2 functionality.

Copy link
Contributor

Choose a reason for hiding this comment

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

OK. GSI develop must use officially approved and maintained modules. It would be good to get confirmation from EMC g-w and library staff that this PR brings in the correct modules and versions.

Copy link
Contributor

Choose a reason for hiding this comment

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

Paths look correct. A couple versions are ahead of where workflow is (and not in UFS), but we can update to match.

Copy link
Collaborator

Choose a reason for hiding this comment

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

Is this resolved, then?

Copy link
Contributor

Choose a reason for hiding this comment

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

If GSI paths are ahead of g-w, will gsi.x and enkf.x run correctly in g-w?

Copy link
Collaborator

@DavidHuber-NOAA DavidHuber-NOAA Sep 12, 2023

Choose a reason for hiding this comment

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

This will need to be resolved in the g-w. I linked this discussion into the relevant issue NOAA-EMC/global-workflow#812. I believe this conversation can be resolved.

miniconda3_ver=os.getenv("miniconda3_ver") or "4.12.0"
load(pathJoin("miniconda3", miniconda3_ver))

local hpc_ver=os.getenv("hpc_ver") or "1.1.0"
local hpc_intel_ver=os.getenv("hpc_intel_ver") or "18.0.5.274"
local hpc_impi_ver=os.getenv("hpc_impi_ver") or "2018.0.4"
prepend_path("MODULEPATH", "/scratch1/NCEPDEV/nems/role.epic/hpc-stack/libs/intel-2022.1.2/modulefiles/stack")
RussTreadon-NOAA marked this conversation as resolved.
Show resolved Hide resolved

local hpc_ver=os.getenv("hpc_ver") or "1.2.0"
local hpc_intel_ver=os.getenv("hpc_intel_ver") or "2022.1.2"
local hpc_impi_ver=os.getenv("hpc_impi_ver") or "2022.1.2"
local cmake_ver=os.getenv("cmake_ver") or "3.20.1"
local anaconda_ver=os.getenv("anaconda_ver") or "2.3.0"
local prod_util_ver=os.getenv("prod_util_ver") or "1.2.2"

load(pathJoin("hpc", hpc_ver))
load(pathJoin("hpc-intel", hpc_intel_ver))
load(pathJoin("hpc-impi", hpc_impi_ver))
load(pathJoin("cmake", cmake_ver))

prepend_path("MODULEPATH", "/contrib/anaconda/modulefiles")

load(pathJoin("anaconda", anaconda_ver))

load("gsi_common")

load(pathJoin("prod_util", prod_util_ver))
Expand Down
15 changes: 7 additions & 8 deletions modulefiles/gsi_jet.lua
Original file line number Diff line number Diff line change
@@ -1,24 +1,23 @@
help([[
]])

prepend_path("MODULEPATH", "/mnt/lfs4/HFIP/hfv3gfs/role.epic/hpc-stack/libs/intel-18.0.5.274/modulefiles/stack")
prepend_path("MODULEPATH", "/mnt/lfs4/HFIP/hfv3gfs/role.epic/miniconda3/modulefiles")
RussTreadon-NOAA marked this conversation as resolved.
Show resolved Hide resolved
miniconda3_ver=os.getenv("miniconda3_ver") or "4.12.0"
load(pathJoin("miniconda3", miniconda3_ver))

prepend_path("MODULEPATH", "/mnt/lfs4/HFIP/hfv3gfs/role.epic/hpc-stack/libs/intel-2022.1.2/modulefiles/stack")
RussTreadon-NOAA marked this conversation as resolved.
Show resolved Hide resolved

local hpc_ver=os.getenv("hpc_ver") or "1.2.0"
local hpc_intel_ver=os.getenv("hpc_intel_ver") or "18.0.5.274"
local hpc_impi_ver=os.getenv("hpc_impi_ver") or "2018.4.274"
local hpc_intel_ver=os.getenv("hpc_intel_ver") or "2022.1.2"
local hpc_impi_ver=os.getenv("hpc_impi_ver") or "2022.1.2"
local cmake_ver=os.getenv("cmake_ver") or "3.20.1"
local anaconda_ver=os.getenv("anaconda_ver") or "5.3.1"
local prod_util_ver=os.getenv("prod_util_ver") or "1.2.2"

load(pathJoin("hpc", hpc_ver))
load(pathJoin("hpc-intel", hpc_intel_ver))
load(pathJoin("hpc-impi", hpc_impi_ver))
load(pathJoin("cmake", cmake_ver))

prepend_path("MODULEPATH", "/contrib/anaconda/modulefiles")

load(pathJoin("anaconda", anaconda_ver))

load("gsi_common")

load(pathJoin("prod_util", prod_util_ver))
Expand Down
14 changes: 8 additions & 6 deletions modulefiles/gsi_orion.lua
Original file line number Diff line number Diff line change
@@ -1,20 +1,22 @@
help([[
]])

prepend_path("MODULEPATH", "/apps/contrib/NCEP/libs/hpc-stack/modulefiles/stack")
prepend_path("MODULEPATH", "/work/noaa/epic-ps/role-epic-ps/miniconda3/modulefiles")
RussTreadon-NOAA marked this conversation as resolved.
Show resolved Hide resolved
miniconda3_ver=os.getenv("miniconda3_ver") or "4.12.0"
load(pathJoin("miniconda3", miniconda3_ver))

local hpc_ver=os.getenv("hpc_ver") or "1.1.0"
local hpc_intel_ver=os.getenv("hpc_intel_ver") or "2018.4"
local hpc_impi_ver=os.getenv("hpc_impi_ver") or "2018.4"
prepend_path("MODULEPATH", "/work/noaa/epic-ps/role-epic-ps/hpc-stack/libs/intel-2022.1.2/modulefiles/stack")
RussTreadon-NOAA marked this conversation as resolved.
Show resolved Hide resolved

local hpc_ver=os.getenv("hpc_ver") or "1.2.0"
local hpc_intel_ver=os.getenv("hpc_intel_ver") or "2022.1.2"
local hpc_impi_ver=os.getenv("hpc_impi_ver") or "2022.1.2"
local cmake_ver=os.getenv("cmake_ver") or "3.22.1"
local python_ver=os.getenv("python_ver") or "3.7.5"
local prod_util_ver=os.getenv("prod_util_ver") or "1.2.2"

load(pathJoin("hpc", hpc_ver))
load(pathJoin("hpc-intel", hpc_intel_ver))
load(pathJoin("hpc-impi", hpc_impi_ver))
load(pathJoin("cmake", cmake_ver))
load(pathJoin("python", python_ver))

load("gsi_common")

Expand Down
14 changes: 7 additions & 7 deletions regression/regression_namelists.sh
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ export gsi_namelist="
oneobtest=.false.,retrieval=.false.,l_foto=.false.,
use_pbl=.false.,use_compress=.true.,nsig_ext=45,gpstop=50.,
commgpstop=45.,commgpserrinf=1.0,
use_gfs_nemsio=.false.,lrun_subdirs=.true.,
use_gfs_nemsio=.false.,lrun_subdirs=.false.,
RussTreadon-NOAA marked this conversation as resolved.
Show resolved Hide resolved
use_readin_anl_sfcmask=.true.,
crtm_coeffs_path='./crtm_coeffs/',
newpc4pred=.true.,adp_anglebc=.true.,angord=4,passive_bc=.true.,use_edges=.false.,
Expand Down Expand Up @@ -232,7 +232,7 @@ export gsi_namelist="
use_pbl=.false.,use_compress=.false.,nsig_ext=10,gpstop=30.,
crtm_coeffs_path='./crtm_coeffs/',
lsqrtb=.true.,lcongrad=.true.,ltlint=.true.,ladtest=.true.,lgrtest=.false.,
use_gfs_nemsio=.false.,lrun_subdirs=.true.,use_gfs_ncio=.true.,
use_gfs_nemsio=.false.,lrun_subdirs=.false.,use_gfs_ncio=.true.,
$SETUP
/
&GRIDOPTS
Expand Down Expand Up @@ -396,7 +396,7 @@ export gsi_namelist="
iguess=-1,
oneobtest=.false.,retrieval=.false.,l_foto=.false.,
use_pbl=.false.,use_prepb_satwnd=.false.,
nhr_assimilation=6,lrun_subdirs=.true.,
nhr_assimilation=6,lrun_subdirs=.false.,
$SETUP
/
&GRIDOPTS
Expand Down Expand Up @@ -578,7 +578,7 @@ export gsi_namelist="
oneobtest=.false.,retrieval=.false.,l_foto=.false.,
use_pbl=.false.,use_compress=.true.,nsig_ext=45,gpstop=50.,
commgpstop=45.,commgpserrinf=1.0,
use_gfs_nemsio=.false.,lrun_subdirs=.true.,
use_gfs_nemsio=.false.,lrun_subdirs=.false.,
use_readin_anl_sfcmask=.true.,
crtm_coeffs_path='./crtm_coeffs/',
newpc4pred=.true.,adp_anglebc=.true.,angord=4,passive_bc=.true.,use_edges=.false.,
Expand Down Expand Up @@ -798,7 +798,7 @@ export gsi_namelist="
iguess=-1,
oneobtest=.false.,retrieval=.false.,l_foto=.false.,
use_pbl=.false.,use_compress=.true.,nsig_ext=56,gpstop=55.,
use_gfs_nemsio=.false.,lrun_subdirs=.true.,use_readin_anl_sfcmask=.true.,
use_gfs_nemsio=.false.,lrun_subdirs=.false.,use_readin_anl_sfcmask=.true.,
crtm_coeffs_path='./crtm_coeffs/',
newpc4pred=.true.,adp_anglebc=.true.,angord=4,passive_bc=.true.,use_edges=.false.,
diag_precon=.true.,step_start=1.e-3,emiss_bc=.true.,thin4d=.true.,cwoption=3,
Expand Down Expand Up @@ -1008,7 +1008,7 @@ export gsi_namelist="
iguess=-1,
oneobtest=.false.,retrieval=.false.,
diag_rad=.false.,diag_pcp=.false.,diag_ozone=.false.,diag_aero=.false.,
nhr_assimilation=6,min_offset=180,use_compress=.false.,lrun_subdirs=.true.,
nhr_assimilation=6,min_offset=180,use_compress=.false.,lrun_subdirs=.false.,
use_similarity_2dvar=.true.,
neutral_stability_windfact_2dvar=.false.,
use_prepb_satwnd=.false.,
Expand Down Expand Up @@ -1607,7 +1607,7 @@ export gsi_namelist="
diag_precon=.true., step_start=1.e-3,
nhr_assimilation=3,l_foto=.false.,
use_pbl=.false.,use_compress=.false.,gpstop=30.,
lrun_subdirs=.true.,
lrun_subdirs=.false.,
$SETUP
/
&GRIDOPTS
Expand Down
9 changes: 7 additions & 2 deletions src/enkf/observer_gfs.f90
Original file line number Diff line number Diff line change
Expand Up @@ -66,7 +66,7 @@ subroutine setup_linhx(rlat, rlon, time, ix, delx, ixp, delxp, iy, dely, &
!$$$
use kinds, only: r_kind,i_kind,r_single
use params, only: nstatefields, nlons, nlats, nhr_state, fhr_assim
use gridinfo, only: latsgrd, lonsgrd
use gridinfo, only: latsgrd, lonsgrd, npts
use constants, only: zero,one,pi
use mpisetup
implicit none
Expand Down Expand Up @@ -95,7 +95,12 @@ subroutine setup_linhx(rlat, rlon, time, ix, delx, ixp, delxp, iy, dely, &
delx = max(zero,min(delx,one))

iyp = 1
do while (iyp <= nlons .and. lonsgrd(ix*nlons + iyp) <= rlon)
do
RussTreadon-NOAA marked this conversation as resolved.
Show resolved Hide resolved
if (iyp > nlons .or. ix*nlons + iyp > npts) then
exit
elseif(lonsgrd(ix*nlons + iyp) > rlon) then
exit
endif
iyp = iyp + 1
enddo
iy = iyp - 1
Expand Down
1 change: 1 addition & 0 deletions src/gsi/general_read_fv3atm.f90
Original file line number Diff line number Diff line change
Expand Up @@ -255,6 +255,7 @@ subroutine general_read_fv3atm_nems(grd,sp_a,filename,uvflag,vordivflag,zflag, &
call stop2(999)
endif
istatus=0
istatus1=0
call gsi_bundlegetpointer(gfs_bundle,'ps',g_ps ,ier);istatus = istatus + ier
call gsi_bundlegetpointer(gfs_bundle,'q' ,g_q ,ier);istatus = istatus + ier
call gsi_bundlegetpointer(gfs_bundle,'oz',g_oz ,ier);istatus = istatus + ier
Expand Down
50 changes: 29 additions & 21 deletions src/gsi/genstats_gps.f90
Original file line number Diff line number Diff line change
Expand Up @@ -753,6 +753,8 @@ end subroutine contents_binary_diag_

subroutine contents_netcdf_diag_
use sparsearr, only: sparr2, readarray, fullarray
use constants, only: r_missing
use screen_to_ncdiag
Copy link
Contributor

Choose a reason for hiding this comment

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

GSI coding standards require

  • All module declarations must explicitly specify which module components (variables or routines) are used within the given routine (e.g., use constants, only: zero, one, two)

To conform to this standard we need

use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata

Copy link
Collaborator

Choose a reason for hiding this comment

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

Fixed.

Copy link
Contributor

Choose a reason for hiding this comment

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

screen_to_ncdiag no longer referenced in src/gsi

integer(i_kind),dimension(miter) :: obsdiag_iuse
integer(i_kind) :: obstype, obssubtype
type(sparr2) :: dhx_dx
Expand All @@ -766,27 +768,33 @@ subroutine contents_netcdf_diag_
obssubtype = gps_allptr%rdiag(2)
call nc_diag_metadata("Observation_Type", obstype )
call nc_diag_metadata("Observation_Subtype", obssubtype )
call nc_diag_metadata("Latitude", sngl(gps_allptr%rdiag(3)) )
call nc_diag_metadata("Longitude", sngl(gps_allptr%rdiag(4)) )
call nc_diag_metadata("Incremental_Bending_Angle", sngl(gps_allptr%rdiag(5)) )
call nc_diag_metadata("Pressure", sngl(gps_allptr%rdiag(6)) )
call nc_diag_metadata("Height", sngl(gps_allptr%rdiag(7)) )
call nc_diag_metadata("Time", sngl(gps_allptr%rdiag(8)) )
call nc_diag_metadata("Model_Elevation", sngl(gps_allptr%rdiag(9)) )
call nc_diag_metadata("Setup_QC_Mark", sngl(gps_allptr%rdiag(10)) )
call nc_diag_metadata("Prep_Use_Flag", sngl(gps_allptr%rdiag(11)) )
call nc_diag_metadata("Analysis_Use_Flag", sngl(gps_allptr%rdiag(12)) )

call nc_diag_metadata("Nonlinear_QC_Rel_Wgt", sngl(gps_allptr%rdiag(13)) )
call nc_diag_metadata("Errinv_Input", sngl(gps_allptr%rdiag(14)) )
call nc_diag_metadata("Errinv_Adjust", sngl(gps_allptr%rdiag(15)) )
call nc_diag_metadata("Errinv_Final", sngl(gps_allptr%rdiag(16)) )
call nc_diag_metadata("Observation", sngl(gps_allptr%rdiag(17)) )
call nc_diag_metadata("Obs_Minus_Forecast_adjusted", sngl(gps_allptr%rdiag(17))*sngl(gps_allptr%rdiag(5)) )
call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(gps_allptr%rdiag(17))*sngl(gps_allptr%rdiag(5)) )
call nc_diag_metadata("GPS_Type", sngl(gps_allptr%rdiag(20)) )
call nc_diag_metadata("Temperature_at_Obs_Location", sngl(gps_allptr%rdiag(18)) )
call nc_diag_metadata("Specific_Humidity_at_Obs_Location", sngl(gps_allptr%rdiag(21)) )
call screen_to_single_nc_diag_metadata("Latitude",(gps_allptr%rdiag(3)) )
call screen_to_single_nc_diag_metadata("Longitude",(gps_allptr%rdiag(4)) )
call screen_to_single_nc_diag_metadata("Incremental_Bending_Angle",(gps_allptr%rdiag(5)) )
call screen_to_single_nc_diag_metadata("Pressure",(gps_allptr%rdiag(6)) )
call screen_to_single_nc_diag_metadata("Height",(gps_allptr%rdiag(7)) )
call screen_to_single_nc_diag_metadata("Time",(gps_allptr%rdiag(8)) )
call screen_to_single_nc_diag_metadata("Model_Elevation",(gps_allptr%rdiag(9)) )
call screen_to_single_nc_diag_metadata("Setup_QC_Mark",(gps_allptr%rdiag(10)) )
call screen_to_single_nc_diag_metadata("Prep_Use_Flag",(gps_allptr%rdiag(11)) )
call screen_to_single_nc_diag_metadata("Analysis_Use_Flag",(gps_allptr%rdiag(12)) )

call screen_to_single_nc_diag_metadata("Nonlinear_QC_Rel_Wgt",(gps_allptr%rdiag(13)) )
call screen_to_single_nc_diag_metadata("Errinv_Input",(gps_allptr%rdiag(14)) )
call screen_to_single_nc_diag_metadata("Errinv_Adjust",(gps_allptr%rdiag(15)) )
call screen_to_single_nc_diag_metadata("Errinv_Final",(gps_allptr%rdiag(16)) )
call screen_to_single_nc_diag_metadata("Observation",(gps_allptr%rdiag(17)) )
!TODO Verify that 'adjusted' is supposed to be the same as unadjusted
RussTreadon-NOAA marked this conversation as resolved.
Show resolved Hide resolved
if(isnan(gps_allptr%rdiag(17)) .or. isnan(gps_allptr%rdiag(5))) then
RussTreadon-NOAA marked this conversation as resolved.
Show resolved Hide resolved
call nc_diag_metadata("Obs_Minus_Forecast_adjusted", sngl(real(r_missing)))
call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(real(r_missing)))
else
call nc_diag_metadata("Obs_Minus_Forecast_adjusted", sngl(gps_allptr%rdiag(17))*sngl(gps_allptr%rdiag(5)) )
call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(gps_allptr%rdiag(17))*sngl(gps_allptr%rdiag(5)) )
endif
call screen_to_single_nc_diag_metadata("GPS_Type",(gps_allptr%rdiag(20)) )
call screen_to_single_nc_diag_metadata("Temperature_at_Obs_Location",(gps_allptr%rdiag(18)) )
call screen_to_single_nc_diag_metadata("Specific_Humidity_at_Obs_Location",(gps_allptr%rdiag(21)) )

if (save_jacobian) then
call readarray(dhx_dx, gps_allptr%rdiag(ioff+1:nreal))
Expand Down
1 change: 1 addition & 0 deletions src/gsi/gsi_files.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -522,6 +522,7 @@ rsearch.F90
rtlnmc_version3.f90
rtma_comp_fact10.f90
satthin.F90
screen_to_ncdiag.f90
RussTreadon-NOAA marked this conversation as resolved.
Show resolved Hide resolved
set_crtm_aerosolmod.f90
set_crtm_cloudmod.f90
setupaod.f90
Expand Down
45 changes: 32 additions & 13 deletions src/gsi/guess_grids.F90
Original file line number Diff line number Diff line change
Expand Up @@ -977,18 +977,30 @@ subroutine create_gesfinfo
nfldaer_all=nfldaer
nfldaer_now=0
extrap_intime=.true.
allocate(hrdifsfc(nfldsfc),ifilesfc(nfldsfc), &
hrdifnst(nfldnst),ifilenst(nfldnst), &
hrdifsig(nfldsig),ifilesig(nfldsig), &
hrdifaer(nfldaer),ifileaer(nfldaer), &
hrdifsfc_all(nfldsfc_all), &
hrdifnst_all(nfldnst_all), &
hrdifsig_all(nfldsig_all), &
hrdifaer_all(nfldaer_all), &
stat=istatus)
if(nfldsig>0) allocate(hrdifsig(nfldsig),ifilesig(nfldsig), &
hrdifsig_all(nfldsig_all), &
stat=istatus)
if (istatus/=0) &
RussTreadon-NOAA marked this conversation as resolved.
Show resolved Hide resolved
write(6,*)'CREATE_GESFINFO(hrdifsig,..): allocate error, istatus=',&
istatus
if(nfldsfc>0) allocate(hrdifsfc(nfldsfc),ifilesfc(nfldsfc), &
hrdifsfc_all(nfldsfc_all), &
stat=istatus)
if (istatus/=0) &
write(6,*)'CREATE_GESFINFO(hrdifsfc,..): allocate error, istatus=',&
istatus
if(nfldnst>0) allocate(hrdifnst(nfldnst),ifilenst(nfldnst), &
hrdifnst_all(nfldnst_all), &
stat=istatus)
if (istatus/=0) &
write(6,*)'CREATE_GESFINFO(hrdifnst,..): allocate error, istatus=',&
istatus
if(nfldnst>0) allocate(hrdifaer(nfldaer),ifileaer(nfldaer), &
hrdifaer_all(nfldaer_all), &
stat=istatus)
if (istatus/=0) &
write(6,*)'CREATE_GESFINFO(hrdifaer,..): allocate error, istatus=',&
istatus
#endif /* HAVE_ESMF */

return
Expand Down Expand Up @@ -1030,11 +1042,18 @@ subroutine destroy_gesfinfo
gesfinfo_created_=.false.

#ifndef HAVE_ESMF
deallocate(hrdifsfc,ifilesfc,hrdifnst,hrdifaer,ifilenst,hrdifsig,ifilesig,ifileaer,&
hrdifsfc_all,hrdifnst_all,hrdifsig_all,hrdifaer_all,stat=istatus)
if(nfldsig>0) deallocate(hrdifsig,ifilesig,hrdifsig_all,stat=istatus)
if (istatus/=0) &
write(6,*)'DESTROY_GESFINFO: deallocate error, istatus=',&
istatus
write(6,*)'DESTROY_GESFINFO: deallocate error, istatus=',istatus
if(nfldsfc>0) deallocate(hrdifsfc,ifilesfc,hrdifsfc_all,stat=istatus)
if (istatus/=0) &
write(6,*)'DESTROY_GESFINFO: deallocate error, istatus=',istatus
if(nfldnst>0) deallocate(hrdifnst,ifilenst,hrdifnst_all,stat=istatus)
if (istatus/=0) &
write(6,*)'DESTROY_GESFINFO: deallocate error, istatus=',istatus
if(nfldnst>0) deallocate(hrdifaer,ifileaer,hrdifaer_all,stat=istatus)
if (istatus/=0) &
write(6,*)'DESTROY_GESFINFO: deallocate error, istatus=',istatus

nfldsfc_all=0
nfldnst_all=0
Expand Down
2 changes: 1 addition & 1 deletion src/gsi/read_files.f90
Original file line number Diff line number Diff line change
Expand Up @@ -585,7 +585,7 @@ subroutine read_files(mype)
if (nst_gsi > 0 ) call mpi_bcast(time_nst,2*nfldnst,mpi_rtype,npem1,mpi_comm_world,ierror)

! for external aerosol files
if(.not.allocated(time_aer)) allocate(time_aer(nfldaer,2))
if(lread_ext_aerosol .and. (.not.allocated(time_aer))) allocate(time_aer(nfldaer,2))
if (lread_ext_aerosol) call mpi_bcast(time_aer,2*nfldaer,mpi_rtype,npem1,mpi_comm_world,ierror)

call mpi_bcast(iamana,3,mpi_rtype,npem1,mpi_comm_world,ierror)
Expand Down
Loading