From da439e1749a2de6124c74cc0bdae10e562f375d3 Mon Sep 17 00:00:00 2001 From: "Ming.Hu" Date: Fri, 5 May 2023 15:11:47 +0000 Subject: [PATCH 01/44] fix several bugs found when uses 2022.01 intel compiler. --- src/enkf/observer_gfs.f90 | 9 +- src/gsi/general_read_fv3atm.f90 | 1 + src/gsi/general_read_gfsatm.f90 | 1 + src/gsi/genstats_gps.f90 | 50 +++++---- src/gsi/gsi_files.cmake | 1 + src/gsi/guess_grids.F90 | 45 ++++++--- src/gsi/read_files.f90 | 2 +- src/gsi/read_prepbufr.f90 | 119 ++++++++++++---------- src/gsi/screen_to_ncdiag.f90 | 30 ++++++ src/gsi/setupaod.f90 | 19 ++-- src/gsi/setupdbz.f90 | 40 +++++--- src/gsi/setupdw.f90 | 38 ++++--- src/gsi/setuplight.f90 | 34 ++++--- src/gsi/setuplwcp.f90 | 42 +++++--- src/gsi/setupoz.f90 | 65 +++++++----- src/gsi/setupps.f90 | 63 ++++++++---- src/gsi/setuppw.f90 | 40 +++++--- src/gsi/setupq.f90 | 96 ++++++++++-------- src/gsi/setuprad.f90 | 173 +++++++++++++++++--------------- src/gsi/setuprw.f90 | 38 ++++--- src/gsi/setupspd.f90 | 40 +++++--- src/gsi/setupsst.f90 | 45 +++++---- src/gsi/setupswcp.f90 | 42 +++++--- src/gsi/setupt.f90 | 90 ++++++++++------- src/gsi/setuptcp.f90 | 42 +++++--- src/gsi/setupw.f90 | 76 +++++++++----- 26 files changed, 766 insertions(+), 475 deletions(-) create mode 100644 src/gsi/screen_to_ncdiag.f90 diff --git a/src/enkf/observer_gfs.f90 b/src/enkf/observer_gfs.f90 index 983b25f959..1f2774f6f1 100644 --- a/src/enkf/observer_gfs.f90 +++ b/src/enkf/observer_gfs.f90 @@ -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 @@ -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 + 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 diff --git a/src/gsi/general_read_fv3atm.f90 b/src/gsi/general_read_fv3atm.f90 index 3d2646fbbb..847d1c4bd3 100644 --- a/src/gsi/general_read_fv3atm.f90 +++ b/src/gsi/general_read_fv3atm.f90 @@ -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 diff --git a/src/gsi/general_read_gfsatm.f90 b/src/gsi/general_read_gfsatm.f90 index 0216b95fb6..a5d5fb77f4 100755 --- a/src/gsi/general_read_gfsatm.f90 +++ b/src/gsi/general_read_gfsatm.f90 @@ -2821,6 +2821,7 @@ subroutine general_read_gfsatm_allhydro_nc(grd,sp_a,filename,uvflag,vordivflag,z 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 diff --git a/src/gsi/genstats_gps.f90 b/src/gsi/genstats_gps.f90 index ce90d06f50..d20587e49d 100644 --- a/src/gsi/genstats_gps.f90 +++ b/src/gsi/genstats_gps.f90 @@ -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 integer(i_kind),dimension(miter) :: obsdiag_iuse integer(i_kind) :: obstype, obssubtype type(sparr2) :: dhx_dx @@ -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 + if(isnan(gps_allptr%rdiag(17)) .or. isnan(gps_allptr%rdiag(5))) then + 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)) diff --git a/src/gsi/gsi_files.cmake b/src/gsi/gsi_files.cmake index 1658c83bf4..a82f986245 100644 --- a/src/gsi/gsi_files.cmake +++ b/src/gsi/gsi_files.cmake @@ -523,6 +523,7 @@ rsearch.F90 rtlnmc_version3.f90 rtma_comp_fact10.f90 satthin.F90 +screen_to_ncdiag.f90 set_crtm_aerosolmod.f90 set_crtm_cloudmod.f90 setupaod.f90 diff --git a/src/gsi/guess_grids.F90 b/src/gsi/guess_grids.F90 index e19ce93638..b8cb188d01 100644 --- a/src/gsi/guess_grids.F90 +++ b/src/gsi/guess_grids.F90 @@ -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) & + 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 @@ -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 diff --git a/src/gsi/read_files.f90 b/src/gsi/read_files.f90 index 5d29efbace..dadcbff3e5 100644 --- a/src/gsi/read_files.f90 +++ b/src/gsi/read_files.f90 @@ -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) diff --git a/src/gsi/read_prepbufr.f90 b/src/gsi/read_prepbufr.f90 index f992ace329..32ec3e8836 100644 --- a/src/gsi/read_prepbufr.f90 +++ b/src/gsi/read_prepbufr.f90 @@ -689,20 +689,26 @@ subroutine read_prepbufr(nread,ndata,nodata,infile,obstype,lunout,twindin,sis,& ! identify drifting buoys - TYP=180/280 T29=562 and last three digits of SID between 500 and 999 ! (see https://www.wmo.int/pages/prog/amp/mmop/wmo-number-rules.html) Set kx to 199/299 - if (id_drifter .and. (kx==180 .or. kx==280) .and. nint(hdr(3))==562) then - rstation_id=hdr(4) - read(c_station_id,*,iostat=ios) iwmo - if (ios == 0 .and. iwmo > 0) then - if(mod(iwmo,1000) >=500) then - kx = kx + 19 + ! Prevent integer overflow by nint + if(hdr(3) < huge_i_kind) then + if (id_drifter .and. (kx==180 .or. kx==280) .and. idnint(hdr(3))==562) then + rstation_id=hdr(4) + read(c_station_id,*,iostat=ios) iwmo + if (ios == 0 .and. iwmo > 0) then + if(mod(iwmo,1000) >=500) then + kx = kx + 19 + end if end if end if end if - if (id_ship .and. (kx==180) .and. (nint(hdr(3))==522 .or. nint(hdr(3))==523)) then - rstation_id=hdr(4) - kx = kx + 18 - end if + !Prevent integer overflow by nint + if(hdr(3) < huge_i_kind) then + if (id_ship .and. (kx==180) .and. (idnint(hdr(3))==522 .or. idnint(hdr(3))==523)) then + rstation_id=hdr(4) + kx = kx + 18 + end if + endif if(twodvar_regional)then ! If running in 2d-var (surface analysis) mode, check to see if observation @@ -968,20 +974,26 @@ subroutine read_prepbufr(nread,ndata,nodata,infile,obstype,lunout,twindin,sis,& ! ! identify drifting buoys - TYP=180/280 T29=562 and last three digits of SID between 500 and 999 ! (see https://www.wmo.int/pages/prog/amp/mmop/wmo-number-rules.html) Set kx to 199/299 - if (id_drifter .and. (kx==180 .or. kx==280) .and. nint(hdr(8))==562 ) then - rstation_id=hdr(1) - read(c_station_id,*,iostat=ios) iwmo - if (ios == 0 .and. iwmo > 0) then - if(mod(iwmo,1000) >=500) then - kx = kx + 19 + !Prevent integer overflow by nint + if(hdr(8) < huge_i_kind) then + if (id_drifter .and. (kx==180 .or. kx==280) .and. idnint(hdr(8))==562 ) then + rstation_id=hdr(1) + read(c_station_id,*,iostat=ios) iwmo + if (ios == 0 .and. iwmo > 0) then + if(mod(iwmo,1000) >=500) then + kx = kx + 19 + end if end if end if - end if + endif - if (id_ship .and. (kx==180) .and. (nint(hdr(8))==522 .or. nint(hdr(8))==523) ) then - rstation_id=hdr(1) - kx = kx + 18 - end if + !Prevent integer overflow by nint + if(hdr(8) < huge_i_kind) then + if (id_ship .and. (kx==180) .and. (idnint(hdr(8))==522 .or. idnint(hdr(8))==523) ) then + rstation_id=hdr(1) + kx = kx + 18 + end if + endif ! ! check VAD subtype. 1--old, 2--new, other--old @@ -1178,7 +1190,7 @@ subroutine read_prepbufr(nread,ndata,nodata,infile,obstype,lunout,twindin,sis,& enddo do k=1,levs ppb=obsdat(1,k) - cat=nint(min(obsdat(10,k),qcmark_huge)) + cat=idnint(min(obsdat(10,k),qcmark_huge)) if ( cat /=0 ) cycle ppb=max(zero,min(ppb,r2000)) if(ppb>=etabl_ps(itypex,1,1)) k1_ps=1 @@ -1607,11 +1619,11 @@ subroutine read_prepbufr(nread,ndata,nodata,infile,obstype,lunout,twindin,sis,& plevs(k)=one_tenth*obsdat(1,k) ! convert mb to cb if (kx == 290) plevs(k)=101.0_r_kind ! Assume 1010 mb = 101.0 cb if (goesctpobs) plevs(k)=goescld(1,k)/1000.0_r_kind ! cloud top pressure in cb - pqm(k)=nint(qcmark(1,k)) - qqm(k)=nint(qcmark(2,k)) - tqm(k)=nint(qcmark(3,k)) - wqm(k)=nint(qcmark(5,k)) - pmq(k)=nint(qcmark(8,k)) + pqm(k)=idnint(qcmark(1,k)) + qqm(k)=idnint(qcmark(2,k)) + tqm(k)=idnint(qcmark(3,k)) + wqm(k)=idnint(qcmark(5,k)) + pmq(k)=idnint(qcmark(8,k)) end do ! If temperature ob, extract information regarding virtual @@ -1636,14 +1648,14 @@ subroutine read_prepbufr(nread,ndata,nodata,infile,obstype,lunout,twindin,sis,& if (tpc(k,j)==glcd) then !found GLERL ob - use that and jump out of events stack obsdat(3,k)=tobaux(1,k,j) qcmark(3,k)=min(tobaux(2,k,j),qcmark_huge) - tqm(k)=nint(qcmark(3,k)) + tqm(k)=idnint(qcmark(3,k)) exit endif endif if (tpc(k,j)==vtcd) then obsdat(3,k)=tobaux(1,k,j+1) qcmark(3,k)=min(tobaux(2,k,j+1),qcmark_huge) - tqm(k)=nint(qcmark(3,k)) + tqm(k)=idnint(qcmark(3,k)) end if if (tpc(k,j)>=bmiss) exit ! end of stack end do @@ -1725,11 +1737,11 @@ subroutine read_prepbufr(nread,ndata,nodata,infile,obstype,lunout,twindin,sis,& if(obsdat(2,k) > r0_01_bmiss)cycle loop_k_levs qm=qqm(k) else if(pwob) then - pwq=nint(qcmark(7,k)) + pwq=idnint(qcmark(7,k)) qm=pwq else if(sstob) then sstq=100 - if (k==1) sstq=nint(min(sstdat(4,k),qcmark_huge)) + if (k==1) sstq=idnint(min(sstdat(4,k),qcmark_huge)) qm=sstq else if(gustob) then gustqm=0 @@ -1785,10 +1797,10 @@ subroutine read_prepbufr(nread,ndata,nodata,infile,obstype,lunout,twindin,sis,& end if if (psob) then - cat=nint(min(obsdat(10,k),qcmark_huge)) + cat=idnint(min(obsdat(10,k),qcmark_huge)) if ( cat /=0 ) cycle loop_k_levs if ( obsdat(1,k)< r500) qm=100 - zqm=nint(qcmark(4,k)) + zqm=idnint(qcmark(4,k)) if (zqm>=lim_zqm .and. zqm/=15 .and. zqm/=9) qm=9 endif @@ -1798,7 +1810,7 @@ subroutine read_prepbufr(nread,ndata,nodata,infile,obstype,lunout,twindin,sis,& ! extract aircraft profile information if (aircraft_t_bc .and. acft_profl_file) then - if (nint(obsdat(10,k))==7) cycle LOOP_K_LEVS + if (idnint(obsdat(10,k))==7) cycle LOOP_K_LEVS if(abs(hdr3(2,k))>r90 .or. abs(hdr3(1,k))>r360) cycle LOOP_K_LEVS if(hdr3(1,k)== r360)hdr3(1,k)=hdr3(1,k)-r360 if(hdr3(1,k) < zero)hdr3(1,k)=hdr3(1,k)+r360 @@ -2133,12 +2145,15 @@ subroutine read_prepbufr(nread,ndata,nodata,infile,obstype,lunout,twindin,sis,& oelev=r10+selev endif if (kx == 280 )then - it29=nint(hdr(8)) - if(it29 == 522 .or. it29 == 523 .or. it29 == 531)then + !Prevent integer overflow by nint + if(hdr(8) < huge_i_kind) then + it29=idnint(hdr(8)) + if(it29 == 522 .or. it29 == 523 .or. it29 == 531)then ! oelev=r20+selev - oelev=r20 + oelev=r20 + end if end if - end if + endif if (kx == 282) oelev=r20+selev if (kx == 285 .or. kx == 289 .or. kx == 290) then @@ -3239,7 +3254,7 @@ subroutine sonde_ext(obsdat,tpc,qcmark,obserr,drfdat,levsio,kx,vtcd) enddo do k=1,levs - cat(k)=nint(obsdat(10,k)) + cat(k)=idnint(obsdat(10,k)) enddo @@ -3256,10 +3271,10 @@ subroutine sonde_ext(obsdat,tpc,qcmark,obserr,drfdat,levsio,kx,vtcd) if(kx==120)then - pqm(1)=nint(min(qcmark(1,1),10000.0)) - qqm(1)=nint(min(qcmark(2,1),10000.0)) - tqm(1)=nint(min(qcmark(3,1),10000.0)) - zqm(1)=nint(min(qcmark(4,1),10000.0)) + pqm(1)=idnint(min(qcmark(1,1),10000.0)) + qqm(1)=idnint(min(qcmark(2,1),10000.0)) + tqm(1)=idnint(min(qcmark(3,1),10000.0)) + zqm(1)=idnint(min(qcmark(4,1),10000.0)) call grdcrd(dpres,levs,prsltmp(1),nsig,-1) do k=1,levs tvflg(k)=one ! initialize as sensible @@ -3271,10 +3286,10 @@ subroutine sonde_ext(obsdat,tpc,qcmark,obserr,drfdat,levsio,kx,vtcd) do i=2,levs im=i-1 - pqm(i)=nint(min(qcmark(1,i),10000.0)) - qqm(i)=nint(min(qcmark(2,i),10000.0)) - tqm(i)=nint(min(qcmark(3,i),10000.0)) - zqm(i)=nint(min(qcmark(4,i),10000.0)) + pqm(i)=idnint(min(qcmark(1,i),10000.0)) + qqm(i)=idnint(min(qcmark(2,i),10000.0)) + tqm(i)=idnint(min(qcmark(3,i),10000.0)) + zqm(i)=idnint(min(qcmark(4,i),10000.0)) if ( (cat(i)==2 .or. cat(im)==2 .or. cat(i)==5 .or. cat(im)==5) .and. & pqm(i)<4 .and. pqm(im)<4 )then ku=dpres(i)-1 @@ -3330,14 +3345,14 @@ subroutine sonde_ext(obsdat,tpc,qcmark,obserr,drfdat,levsio,kx,vtcd) enddo !levs !!!!!!!!! w (not used) !!!!!!!!!!!!!!!!!!!!!!!!!!! elseif(kx==220)then - pqm(1)=nint(min(qcmark(1,1),10000.0)) - wqm(1)=nint(min(qcmark(5,1),10000.0)) + pqm(1)=idnint(min(qcmark(1,1),10000.0)) + wqm(1)=idnint(min(qcmark(5,1),10000.0)) call grdcrd(dpres,levs,prsltmp(1),nsig,-1) do i=2,levs im=i-1 - wqm(i)=nint(min(qcmark(5,i),10000.0)) - zqm(i)=nint(min(qcmark(4,i),10000.0)) - pqm(i)=nint(min(qcmark(1,i),10000.0)) + wqm(i)=idnint(min(qcmark(5,i),10000.0)) + zqm(i)=idnint(min(qcmark(4,i),10000.0)) + pqm(i)=idnint(min(qcmark(1,i),10000.0)) if( wqm(i)<4 .and. wqm(im)<4 .and. pqm(i)<4 .and. pqm(im)<4 .and.& (cat(i)==2 .or. cat(im)==2 .or. cat(i)==5 .or. cat(im)==5) )then ku=dpres(i)-1 diff --git a/src/gsi/screen_to_ncdiag.f90 b/src/gsi/screen_to_ncdiag.f90 new file mode 100644 index 0000000000..ae5e037e40 --- /dev/null +++ b/src/gsi/screen_to_ncdiag.f90 @@ -0,0 +1,30 @@ +module screen_to_ncdiag + implicit none + private + public:: screen_to_single_nc_diag_metadata + + !Provides a subroutine to screen quantities for NaNs before converting doubles + !to singles and sending them to nc_diag_metadata. This prevents floating + !invalids. + + contains + + subroutine screen_to_single_nc_diag_metadata(vname, var) + use constants, only: r_missing + use kinds, only: r_double, r_kind + use nc_diag_write_mod, only: nc_diag_metadata + + !Screens double variables to be sent to nc_diag_metadata by checking for NaNs first + !to prevent floating invalids (which are reported as 0) + character(len=*), intent(in) :: vname + real (r_double), intent(in) :: var + + if(isnan(var)) then + call nc_diag_metadata(vname, sngl(real(r_missing))) + else + call nc_diag_metadata(vname, sngl(var)) + endif + + endsubroutine screen_to_single_nc_diag_metadata + +endmodule screen_to_ncdiag diff --git a/src/gsi/setupaod.f90 b/src/gsi/setupaod.f90 index a1e4656e76..5a67b1e034 100644 --- a/src/gsi/setupaod.f90 +++ b/src/gsi/setupaod.f90 @@ -827,6 +827,7 @@ subroutine contents_netcdf_diag_ ! subroutine to write contents to netcdf diag files ! original: pagowski ! modified: 2019-03-21 - martin - cleaned up to fit GSI coding norms + use screen_to_ncdiag implicit none character(7),parameter :: obsclass = ' aod' character(128) :: fieldname @@ -841,16 +842,16 @@ subroutine contents_netcdf_diag_ if ( iuse_aero(l) < 0 ) cycle call nc_diag_metadata("Channel_Index", i) call nc_diag_metadata("Observation_Class", obsclass) - call nc_diag_metadata("Latitude", sngl(cenlat)) ! observation latitude (degrees) - call nc_diag_metadata("Longitude", sngl(cenlon)) ! observation longitude (degrees) - call nc_diag_metadata("Obs_Time", sngl(dtime))!-time_offset)) ! observation time (hours relative to analysis time) - call nc_diag_metadata("Sol_Zenith_Angle", sngl(pangs)) ! solar zenith angle (degrees) - call nc_diag_metadata("Sol_Azimuth_Angle", sngl(data_s(isazi_ang,n))) ! solar azimuth angle (degrees) + call screen_to_single_nc_diag_metadata("Latitude",(cenlat)) ! observation latitude (degrees) + call screen_to_single_nc_diag_metadata("Longitude",(cenlon)) ! observation longitude (degrees) + call screen_to_single_nc_diag_metadata("Obs_Time",(dtime))!-time_offset)) ! observation time (hours relative to analysis time) + call screen_to_single_nc_diag_metadata("Sol_Zenith_Angle",(pangs)) ! solar zenith angle (degrees) + call screen_to_single_nc_diag_metadata("Sol_Azimuth_Angle",(data_s(isazi_ang,n))) ! solar azimuth angle (degrees) call nc_diag_metadata("Surface_type", nint(data_s(istyp,n))) call nc_diag_metadata("MODIS_deep_blue_flag", nint(dbcf) ) - call nc_diag_metadata("Observation", sngl(diagbufchan(1,i)) ) ! observed aod - call nc_diag_metadata("Obs_Minus_Forecast_adjusted",sngl(diagbufchan(2,i))) - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted",sngl(diagbufchan(2,i)))! obs - sim aod with no bias correction + call nc_diag_metadata("Observation",(diagbufchan(1,i)) ) ! observed aod + call nc_diag_metadata("Obs_Minus_Forecast_adjusted",(diagbufchan(2,i))) + call nc_diag_metadata("Obs_Minus_Forecast_unadjusted",(diagbufchan(2,i)))! obs - sim aod with no bias correction if (diagbufchan(3,i) > tiny_r_kind) then tmp(1)=one/diagbufchan(3,i) @@ -859,7 +860,7 @@ subroutine contents_netcdf_diag_ end if call nc_diag_metadata("Observation_Error",tmp(1)) - call nc_diag_metadata("QC_Flag", sngl(diagbufchan(4,i))) !quality control mark or event indicator + call nc_diag_metadata("QC_Flag",(diagbufchan(4,i))) !quality control mark or event indicator tmp(1)=get_zsfc() call nc_diag_metadata("sfc_height",tmp(1)) ! height in meters diff --git a/src/gsi/setupdbz.f90 b/src/gsi/setupdbz.f90 index 96f0378c52..3e97d031d4 100644 --- a/src/gsi/setupdbz.f90 +++ b/src/gsi/setupdbz.f90 @@ -1920,6 +1920,8 @@ subroutine contents_binary_dirZDA_diag_(odiag) end subroutine contents_binary_dirZDA_diag_ subroutine contents_netcdf_diag_(odiag) + use constants, only: r_missing + use screen_to_ncdiag type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' dbz' @@ -1928,29 +1930,37 @@ subroutine contents_netcdf_diag_(odiag) call nc_diag_metadata("Observation_Class", obsclass ) call nc_diag_metadata("Observation_Type", ictype(ikx) ) call nc_diag_metadata("Observation_Subtype", icsubtype(ikx) ) - call nc_diag_metadata("Latitude", sngl(data(ilate,i)) ) - call nc_diag_metadata("Longitude", sngl(data(ilone,i)) ) - call nc_diag_metadata("Station_Elevation", sngl(data(ielev,i)) ) - call nc_diag_metadata("Pressure", sngl(presw) ) - call nc_diag_metadata("Height", sngl(data(ihgt,i)) ) - call nc_diag_metadata("Time", sngl(dtime-time_offset)) - call nc_diag_metadata("Prep_QC_Mark", sngl(zero) ) - call nc_diag_metadata("Prep_Use_Flag", sngl(data(iuse,i)) ) + call screen_to_single_nc_diag_metadata("Latitude",(data(ilate,i)) ) + call screen_to_single_nc_diag_metadata("Longitude",(data(ilone,i)) ) + call screen_to_single_nc_diag_metadata("Station_Elevation",(data(ielev,i)) ) + call screen_to_single_nc_diag_metadata("Pressure",(presw) ) + call screen_to_single_nc_diag_metadata("Height",(data(ihgt,i)) ) + if(isnan(dtime) .or. isnan(time_offset)) then + call nc_diag_metadata("Time",sngl(real(r_missing))) + else + call nc_diag_metadata("Time",sngl(dtime-time_offset)) + endif + call screen_to_single_nc_diag_metadata("Prep_QC_Mark",(zero) ) + call screen_to_single_nc_diag_metadata("Prep_Use_Flag",(data(iuse,i)) ) ! call nc_diag_metadata("Nonlinear_QC_Var_Jb", var_jb ! ) - call nc_diag_metadata("Nonlinear_QC_Rel_Wgt", sngl(rwgt) ) + call screen_to_single_nc_diag_metadata("Nonlinear_QC_Rel_Wgt",(rwgt) ) if(muse(i)) then call nc_diag_metadata("Analysis_Use_Flag", sngl(one) ) else call nc_diag_metadata("Analysis_Use_Flag", sngl(-one) ) endif - call nc_diag_metadata("Errinv_Input", sngl(errinv_input) ) - call nc_diag_metadata("Errinv_Adjust", sngl(errinv_adjst) ) - call nc_diag_metadata("Errinv_Final", sngl(errinv_final) ) + call screen_to_single_nc_diag_metadata("Errinv_Input",(errinv_input) ) + call screen_to_single_nc_diag_metadata("Errinv_Adjust",(errinv_adjst) ) + call screen_to_single_nc_diag_metadata("Errinv_Final",(errinv_final) ) - call nc_diag_metadata("Observation", sngl(data(idbzob,i)) ) - call nc_diag_metadata("Obs_Minus_Forecast_adjusted", sngl(ddiff) ) - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(data(idbzob,i)-rdBZ) ) + call screen_to_single_nc_diag_metadata("Observation",(data(idbzob,i)) ) + call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_adjusted",(ddiff) ) + if(isnan(data(idbzob,i)) .or. isnan(rdBZ)) then + call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(real(r_missing))) + else + call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(data(idbzob,i)-rdBZ) ) + endif if (lobsdiagsave) then do jj=1,miter diff --git a/src/gsi/setupdw.f90 b/src/gsi/setupdw.f90 index 93749b2ad9..c1fa133c57 100644 --- a/src/gsi/setupdw.f90 +++ b/src/gsi/setupdw.f90 @@ -895,6 +895,8 @@ subroutine contents_binary_diag_(odiag) end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_(odiag) + use constants, only: r_missing + use screen_to_ncdiag type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' dw' @@ -904,29 +906,37 @@ subroutine contents_netcdf_diag_(odiag) call nc_diag_metadata("Observation_Class", obsclass ) call nc_diag_metadata("Observation_Type", ictype(ikx) ) call nc_diag_metadata("Observation_Subtype", icsubtype(ikx) ) - call nc_diag_metadata("Latitude", sngl(data(ilate,i)) ) - call nc_diag_metadata("Longitude", sngl(data(ilone,i)) ) + call screen_to_single_nc_diag_metadata("Latitude",(data(ilate,i)) ) + call screen_to_single_nc_diag_metadata("Longitude",(data(ilone,i)) ) call nc_diag_metadata("Station_Elevation", missing ) - call nc_diag_metadata("Pressure", sngl(presw) ) - call nc_diag_metadata("Height", sngl(data(ihgt,i)) ) - call nc_diag_metadata("Time", sngl(dtime-time_offset)) + call screen_to_single_nc_diag_metadata("Pressure",(presw) ) + call screen_to_single_nc_diag_metadata("Height",(data(ihgt,i)) ) + if(isnan(dtime) .or. isnan(time_offset)) then + call nc_diag_metadata("Time",sngl(real(r_missing))) + else + call nc_diag_metadata("Time",sngl(dtime-time_offset)) + endif call nc_diag_metadata("Prep_QC_Mark", missing ) - call nc_diag_metadata("Prep_Use_Flag", sngl(data(iuse,i)) ) + call screen_to_single_nc_diag_metadata("Prep_Use_Flag",(data(iuse,i)) ) ! call nc_diag_metadata("Nonlinear_QC_Var_Jb", var_jb ) - call nc_diag_metadata("Nonlinear_QC_Rel_Wgt", sngl(rwgt) ) + call screen_to_single_nc_diag_metadata("Nonlinear_QC_Rel_Wgt",(rwgt) ) if(muse(i)) then call nc_diag_metadata("Analysis_Use_Flag", sngl(one) ) else - call nc_diag_metadata("Analysis_Use_Flag", sngl(-one) ) + call nc_diag_metadata("Analysis_Use_Flag", sngl(-one) ) endif - call nc_diag_metadata("Errinv_Input", sngl(errinv_input) ) - call nc_diag_metadata("Errinv_Adjust", sngl(errinv_adjst) ) - call nc_diag_metadata("Errinv_Final", sngl(errinv_final) ) + call screen_to_single_nc_diag_metadata("Errinv_Input",(errinv_input) ) + call screen_to_single_nc_diag_metadata("Errinv_Adjust",(errinv_adjst) ) + call screen_to_single_nc_diag_metadata("Errinv_Final",(errinv_final) ) - call nc_diag_metadata("Observation", sngl(data(ilob,i))) - call nc_diag_metadata("Obs_Minus_Forecast_adjusted", sngl(ddiff) ) - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(data(ilob,i)-dwwind)) + call screen_to_single_nc_diag_metadata("Observation",(data(ilob,i))) + call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_adjusted",(ddiff) ) + if(isnan(data(ilob,i)) .or. isnan(dwwind)) then + call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(real(r_missing))) + else + call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(data(ilob,i)-dwwind)) + endif !_RT_NC4_TODO !_RT rdiagbuf(20,ii) = factw ! 10m wind reduction factor diff --git a/src/gsi/setuplight.f90 b/src/gsi/setuplight.f90 index e9ed19d3c3..ffbba3af8f 100644 --- a/src/gsi/setuplight.f90 +++ b/src/gsi/setuplight.f90 @@ -1614,30 +1614,36 @@ end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_(odiag) ! Observation class + use constants, only: r_missing + use screen_to_ncdiag type(obs_diag),pointer,intent(in):: odiag character(7),parameter :: obsclass = ' light' real(r_single),parameter:: missing = -9.99e9_r_single real(r_kind),dimension(miter) :: obsdiag_iuse - call nc_diag_metadata("GLM_Detect_Err", sngl(data(ier,i)) ) - call nc_diag_metadata("Latitude", sngl(data(ilate,i)) ) - call nc_diag_metadata("Longitude", sngl(data(ilone,i)) ) - call nc_diag_metadata("Lightning_FR_Obs", sngl(dlight ) ) - call nc_diag_metadata("Time", sngl(dtime) ) - call nc_diag_metadata("GLM_QC_Mark", sngl(data(iqc,i)) ) - call nc_diag_metadata("GLM_Orig_Detect_Err", sngl(data(ier2,i)) ) - call nc_diag_metadata("GLM_Use_Flag", sngl(data(iuse,i)) ) + call screen_to_single_nc_diag_metadata("GLM_Detect_Err",(data(ier,i)) ) + call screen_to_single_nc_diag_metadata("Latitude",(data(ilate,i)) ) + call screen_to_single_nc_diag_metadata("Longitude",(data(ilone,i)) ) + call screen_to_single_nc_diag_metadata("Lightning_FR_Obs",(dlight ) ) + call screen_to_single_nc_diag_metadata("Time",(dtime) ) + call screen_to_single_nc_diag_metadata("GLM_QC_Mark",(data(iqc,i)) ) + call screen_to_single_nc_diag_metadata("GLM_Orig_Detect_Err",(data(ier2,i)) ) + call screen_to_single_nc_diag_metadata("GLM_Use_Flag",(data(iuse,i)) ) if(muse(i)) then call nc_diag_metadata("Analysis_Use_Flag", 1._r_single ) else call nc_diag_metadata("Analysis_Use_Flag", -1._r_single ) endif - call nc_diag_metadata("Nonlinear_QC_Rel_Wgt", sngl(rwgt) ) - call nc_diag_metadata("Errinv_Input", sngl(errinv_input) ) - call nc_diag_metadata("Errinv_Adjust", sngl(errinv_adjst) ) - call nc_diag_metadata("Errinv_Final", sngl(errinv_final) ) - call nc_diag_metadata("Obs_Minus_Forecast_VarBC", sngl(ddiff) ) - call nc_diag_metadata("Obs_Minus_Forecast_NoVarBC", sngl(dlight-lightges0) ) + call screen_to_single_nc_diag_metadata("Nonlinear_QC_Rel_Wgt",(rwgt) ) + call screen_to_single_nc_diag_metadata("Errinv_Input",(errinv_input) ) + call screen_to_single_nc_diag_metadata("Errinv_Adjust",(errinv_adjst) ) + call screen_to_single_nc_diag_metadata("Errinv_Final",(errinv_final) ) + call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_VarBC",(ddiff) ) + if(isnan(dlight) .or. isnan(lightges0)) then + call nc_diag_metadata("Obs_Minus_Forecast_NoVarBC", sngl(real(r_missing))) + else + call nc_diag_metadata("Obs_Minus_Forecast_NoVarBC", sngl(dlight-lightges0) ) + endif if (lobsdiagsave) then do jj=1,miter if (odiag%muse(jj)) then diff --git a/src/gsi/setuplwcp.f90 b/src/gsi/setuplwcp.f90 index 7e06144f68..21e6f5e2ff 100644 --- a/src/gsi/setuplwcp.f90 +++ b/src/gsi/setuplwcp.f90 @@ -837,6 +837,8 @@ subroutine contents_binary_diag_(odiag) end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_(odiag) + use constants, only: r_missing + use screen_to_ncdiag type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' lwcp' @@ -848,28 +850,36 @@ subroutine contents_netcdf_diag_(odiag) call nc_diag_metadata("Observation_Class", obsclass ) call nc_diag_metadata("Observation_Type", ictype(ikx) ) call nc_diag_metadata("Observation_Subtype", icsubtype(ikx) ) - call nc_diag_metadata("Latitude", sngl(data(ilate,i)) ) - call nc_diag_metadata("Longitude", sngl(data(ilone,i)) ) - call nc_diag_metadata("Station_Elevation", sngl(data(istnelv,i)) ) - call nc_diag_metadata("Pressure", sngl(data(iobsprs,i)) ) - call nc_diag_metadata("Height", sngl(data(iobshgt,i)) ) - call nc_diag_metadata("Time", sngl(dtime-time_offset)) - call nc_diag_metadata("Prep_QC_Mark", sngl(data(iqc,i)) ) - call nc_diag_metadata("Setup_QC_Mark", sngl(rmiss_single) ) - call nc_diag_metadata("Prep_Use_Flag", sngl(data(iuse,i)) ) + call screen_to_single_nc_diag_metadata("Latitude",(data(ilate,i)) ) + call screen_to_single_nc_diag_metadata("Longitude",(data(ilone,i)) ) + call screen_to_single_nc_diag_metadata("Station_Elevation",(data(istnelv,i)) ) + call screen_to_single_nc_diag_metadata("Pressure",(data(iobsprs,i)) ) + call screen_to_single_nc_diag_metadata("Height",(data(iobshgt,i)) ) + if(isnan(dtime) .or. isnan(time_offset)) then + call nc_diag_metadata("Time",sngl(real(r_missing))) + else + call nc_diag_metadata("Time",sngl(dtime-time_offset)) + endif + call screen_to_single_nc_diag_metadata("Prep_QC_Mark",(data(iqc,i)) ) + call nc_diag_metadata("Setup_QC_Mark",(rmiss_single) ) + call screen_to_single_nc_diag_metadata("Prep_Use_Flag",(data(iuse,i)) ) if(muse(i)) then call nc_diag_metadata("Analysis_Use_Flag", sngl(one) ) else call nc_diag_metadata("Analysis_Use_Flag", sngl(-one) ) endif - call nc_diag_metadata("Nonlinear_QC_Rel_Wgt", sngl(rwgt) ) - call nc_diag_metadata("Errinv_Input", sngl(errinv_input) ) - call nc_diag_metadata("Errinv_Adjust", sngl(errinv_adjst) ) - call nc_diag_metadata("Errinv_Final", sngl(errinv_final) ) - call nc_diag_metadata("Observation", sngl(dlwcp) ) - call nc_diag_metadata("Obs_Minus_Forecast_adjusted", sngl(ddiff) ) - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(dlwcp-lwcpges)) + call screen_to_single_nc_diag_metadata("Nonlinear_QC_Rel_Wgt",(rwgt) ) + call screen_to_single_nc_diag_metadata("Errinv_Input",(errinv_input) ) + call screen_to_single_nc_diag_metadata("Errinv_Adjust",(errinv_adjst) ) + call screen_to_single_nc_diag_metadata("Errinv_Final",(errinv_final) ) + call screen_to_single_nc_diag_metadata("Observation",(dlwcp) ) + call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_adjusted",(ddiff) ) + if(isnan(dlwcp) .or. isnan(lwcpges)) then + call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(real(r_missing))) + else + call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(dlwcp-lwcpges)) + endif if (lobsdiagsave) then do jj=1,miter diff --git a/src/gsi/setupoz.f90 b/src/gsi/setupoz.f90 index 24381df447..caaeaa22aa 100644 --- a/src/gsi/setupoz.f90 +++ b/src/gsi/setupoz.f90 @@ -112,7 +112,7 @@ subroutine setupozlay(obsLL,odiagLL,lunin,mype,stats_oz,nlevs,nreal,nobs,& use state_vectors, only: svars3d, levels - use constants, only : zero,half,one,two,tiny_r_kind + use constants, only : zero,half,one,two,tiny_r_kind,r_missing use constants, only : rozcon,cg_term,wgtlim,h300,r10 use m_obsdiagNode, only : obs_diag @@ -152,6 +152,7 @@ subroutine setupozlay(obsLL,odiagLL,lunin,mype,stats_oz,nlevs,nreal,nobs,& use m_dtime, only: dtime_setup, dtime_check use gsi_bundlemod, only : gsi_bundlegetpointer use gsi_metguess_mod, only : gsi_metguess_get,gsi_metguess_bundle + use screen_to_ncdiag implicit none ! !INPUT PARAMETERS: @@ -575,27 +576,31 @@ subroutine setupozlay(obsLL,odiagLL,lunin,mype,stats_oz,nlevs,nreal,nobs,& if (netcdf_diag) then call nc_diag_metadata("MPI_Task_Number", mype ) - call nc_diag_metadata("Latitude", sngl(data(ilate,i)) ) - call nc_diag_metadata("Longitude", sngl(data(ilone,i)) ) - call nc_diag_metadata("Time", sngl(data(itime,i)-time_offset) ) - call nc_diag_metadata("Reference_Pressure", sngl(pobs(k)) ) + call screen_to_single_nc_diag_metadata("Latitude",(data(ilate,i)) ) + call screen_to_single_nc_diag_metadata("Longitude",(data(ilone,i)) ) + if(isnan(dtime) .or. isnan(time_offset)) then + call nc_diag_metadata("Time",sngl(real(r_missing))) + else + call nc_diag_metadata("Time",sngl(dtime-time_offset)) + endif + call screen_to_single_nc_diag_metadata("Reference_Pressure",(pobs(k)) ) call nc_diag_metadata("Analysis_Use_Flag", iouse(k) ) - call nc_diag_metadata("Observation", sngl(ozobs(k))) - call nc_diag_metadata("Inverse_Observation_Error", sngl(errorinv)) - call nc_diag_metadata("Obs_Minus_Forecast_adjusted", sngl(ozone_inv(k))) - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted",sngl(ozone_inv(k))) + call screen_to_single_nc_diag_metadata("Observation",(ozobs(k))) + call screen_to_single_nc_diag_metadata("Inverse_Observation_Error",(errorinv)) + call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_adjusted",(ozone_inv(k))) + call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_unadjusted",(ozone_inv(k))) if (obstype == 'gome' .or. obstype == 'omieff' .or. & obstype == 'omi' .or. obstype == 'tomseff' ) then - call nc_diag_metadata("Solar_Zenith_Angle", sngl(data(isolz,i)) ) - call nc_diag_metadata("Scan_Position", sngl(data(ifovn,i)) ) + call screen_to_single_nc_diag_metadata("Solar_Zenith_Angle",(data(isolz,i)) ) + call screen_to_single_nc_diag_metadata("Scan_Position",(data(ifovn,i)) ) else - call nc_diag_metadata("Solar_Zenith_Angle", sngl(rmiss) ) - call nc_diag_metadata("Scan_Position", sngl(rmiss) ) + call screen_to_single_nc_diag_metadata("Solar_Zenith_Angle",(rmiss) ) + call screen_to_single_nc_diag_metadata("Scan_Position",(rmiss) ) endif if (obstype == 'omieff' .or. obstype == 'omi' ) then - call nc_diag_metadata("Row_Anomaly_Index", sngl(data(itoqf,i)) ) + call screen_to_single_nc_diag_metadata("Row_Anomaly_Index",(data(itoqf,i)) ) else - call nc_diag_metadata("Row_Anomaly_Index", sngl(rmiss) ) + call screen_to_single_nc_diag_metadata("Row_Anomaly_Index",(rmiss) ) endif if (save_jacobian) then call nc_diag_data2d("Observation_Operator_Jacobian_stind", dhx_dx%st_ind) @@ -1656,24 +1661,30 @@ subroutine contents_binary_diag_(odiag) end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_(odiag) + use constants, only: r_missing + use screen_to_ncdiag type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' ozlev' real(r_kind),dimension(miter) :: obsdiag_iuse - call nc_diag_metadata("Latitude", sngl(data(ilate,i)) ) - call nc_diag_metadata("Longitude", sngl(data(ilone,i)) ) + call screen_to_single_nc_diag_metadata("Latitude",(data(ilate,i)) ) + call screen_to_single_nc_diag_metadata("Longitude",(data(ilone,i)) ) call nc_diag_metadata("MPI_Task_Number", mype ) - call nc_diag_metadata("Time", sngl(data(itime,i)-time_offset)) - call nc_diag_metadata("Inverse_Observation_Error", sngl(errorinv) ) - call nc_diag_metadata("Observation", sngl(ozlv) ) - call nc_diag_metadata("Obs_Minus_Forecast_adjusted", sngl(ozone_inv) ) - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted",sngl(ozone_inv) ) - call nc_diag_metadata("Reference_Pressure", sngl(preso3l) ) - call nc_diag_metadata("Input_Observation_Error", sngl(obserror) ) + if(isnan(dtime) .or. isnan(time_offset)) then + call nc_diag_metadata("Time",sngl(real(r_missing))) + else + call nc_diag_metadata("Time",sngl(dtime-time_offset)) + endif + call screen_to_single_nc_diag_metadata("Inverse_Observation_Error",(errorinv) ) + call screen_to_single_nc_diag_metadata("Observation",(ozlv) ) + call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_adjusted",(ozone_inv) ) + call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_unadjusted",(ozone_inv) ) + call screen_to_single_nc_diag_metadata("Reference_Pressure",(preso3l) ) + call screen_to_single_nc_diag_metadata("Input_Observation_Error",(obserror) ) if(obstype =="omps_lp")then - call nc_diag_metadata("Log10 Air Number Density", sngl(airnd)) - call nc_diag_metadata("Log10 Ozone Number Density UV", sngl(uvnd)) - call nc_diag_metadata("Log10 Ozone Number Density VIS",sngl(visnd)) + call screen_to_single_nc_diag_metadata("Log10 Air Number Density",(airnd)) + call screen_to_single_nc_diag_metadata("Log10 Ozone Number Density UV",(uvnd)) + call screen_to_single_nc_diag_metadata("Log10 Ozone Number Density VIS",(visnd)) endif if(luse(i)) then diff --git a/src/gsi/setupps.f90 b/src/gsi/setupps.f90 index 6a0fdd4fb2..35a1669fec 100644 --- a/src/gsi/setupps.f90 +++ b/src/gsi/setupps.f90 @@ -130,7 +130,7 @@ subroutine setupps(obsLL,odiagLL,lunin,mype,bwork,awork,nele,nobs,is,conv_diagsa use gridmod, only: nsig,get_ij,twodvar_regional use constants, only: zero,one_tenth,one,half,pi,g_over_rd, & huge_r_kind,tiny_r_kind,two,huge_single, & - r1000,wgtlim,tiny_single,r10,three + r1000,wgtlim,tiny_single,r10,three, r_missing use jfunc, only: jiter,last,jiterstart,miter use qcmod, only: dfact,dfact1,npres_print,vqc,nvqc use guess_grids, only: hrdifsig,ges_lnprsl,nfldsig,ntguessig @@ -882,6 +882,7 @@ subroutine contents_binary_diag_(odiag) end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_(odiag) + use screen_to_ncdiag type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' ps' @@ -890,30 +891,54 @@ subroutine contents_netcdf_diag_(odiag) call nc_diag_metadata("Observation_Class", obsclass ) call nc_diag_metadata("Observation_Type", ictype(ikx) ) call nc_diag_metadata("Observation_Subtype", icsubtype(ikx) ) - call nc_diag_metadata("Latitude", sngl(data(ilate,i)) ) - call nc_diag_metadata("Longitude", sngl(data(ilone,i)) ) - call nc_diag_metadata("Station_Elevation", sngl(data(istnelv,i)) ) - call nc_diag_metadata("Pressure", sngl(data(ipres,i)*r10)) - call nc_diag_metadata("Height", sngl(dhgt) ) - call nc_diag_metadata("Time", sngl(dtime-time_offset)) - call nc_diag_metadata("Prep_QC_Mark", sngl(data(iqc,i)) ) - call nc_diag_metadata("Prep_Use_Flag", sngl(data(iuse,i)) ) - call nc_diag_metadata("Nonlinear_QC_Var_Jb", sngl(var_jb) ) - call nc_diag_metadata("Nonlinear_QC_Rel_Wgt", sngl(rwgt) ) + !Replace direct calls to nc_diag_metadata with the screening subroutine + call screen_to_single_nc_diag_metadata("Latitude",(data(ilate,i)) ) + call screen_to_single_nc_diag_metadata("Longitude",(data(ilone,i)) ) + call screen_to_single_nc_diag_metadata("Station_Elevation",(data(istnelv,i)) ) + if(isnan(data(ipres,i))) then + call nc_diag_metadata("Pressure",sngl(real(r_missing))) + else + call screen_to_single_nc_diag_metadata("Pressure",data(ipres,i)*r10) + endif + call screen_to_single_nc_diag_metadata("Height",dhgt) + if(isnan(dtime) .or. isnan(time_offset)) then + call nc_diag_metadata("Time",sngl(real(r_missing))) + else + call nc_diag_metadata("Time",sngl(dtime-time_offset)) + endif + call screen_to_single_nc_diag_metadata("Prep_QC_Mark",(data(iqc,i)) ) + call screen_to_single_nc_diag_metadata("Prep_Use_Flag",(data(iuse,i)) ) + call screen_to_single_nc_diag_metadata("Nonlinear_QC_Var_Jb",(var_jb) ) + call screen_to_single_nc_diag_metadata("Nonlinear_QC_Rel_Wgt",rwgt ) if(muse(i)) then call nc_diag_metadata("Analysis_Use_Flag", sngl(one) ) else - call nc_diag_metadata("Analysis_Use_Flag", sngl(-one) ) + call nc_diag_metadata("Analysis_Use_Flag", sngl(-one) ) endif - call nc_diag_metadata("Errinv_Input", sngl(errinv_input) ) - call nc_diag_metadata("Errinv_Adjust", sngl(errinv_adjst) ) - call nc_diag_metadata("Errinv_Final", sngl(errinv_final) ) + call screen_to_single_nc_diag_metadata("Errinv_Input",(errinv_input) ) + call screen_to_single_nc_diag_metadata("Errinv_Adjust",(errinv_adjst) ) + call screen_to_single_nc_diag_metadata("Errinv_Final",(errinv_final) ) + + if(isnan(pob)) then + call nc_diag_metadata("Observation",sngl(real(r_missing)) ) + 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("Observation",sngl(pob) ) + if(isnan(pges)) then + call nc_diag_metadata("Obs_Minus_Forecast_adjusted",sngl(real(r_missing))) + else + call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_adjusted",pob-pges) + endif + + if(isnan(pgesorig)) then + call nc_diag_metadata("Obs_Minus_Forecast_unadjusted",sngl(real(r_missing))) + else + call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_unadjusted",pob-pgesorig) + endif + endif - call nc_diag_metadata("Observation", sngl(pob) ) - call nc_diag_metadata("Obs_Minus_Forecast_adjusted", sngl(pob-pges) ) - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(pob-pgesorig)) - if (lobsdiagsave) then do jj=1,miter diff --git a/src/gsi/setuppw.f90 b/src/gsi/setuppw.f90 index b22d4eb661..801d7768b8 100644 --- a/src/gsi/setuppw.f90 +++ b/src/gsi/setuppw.f90 @@ -710,6 +710,8 @@ subroutine contents_binary_diag_(odiag) end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_(odiag) + use constants, only: r_missing + use screen_to_ncdiag type(obs_diag),pointer,intent(in):: odiag ! Observation class ! use model surface pressure, so PW can be used in EnKF analysis @@ -721,27 +723,35 @@ subroutine contents_netcdf_diag_(odiag) call nc_diag_metadata("Observation_Class", obsclass ) call nc_diag_metadata("Observation_Type", ictype(ikx) ) call nc_diag_metadata("Observation_Subtype", icsubtype(ikx) ) - call nc_diag_metadata("Latitude", sngl(data(ilate,i)) ) - call nc_diag_metadata("Longitude", sngl(data(ilone,i)) ) - call nc_diag_metadata("Station_Elevation", sngl(data(istnelv,i)) ) - call nc_diag_metadata("Pressure", sngl(prest) ) - call nc_diag_metadata("Height", sngl(data(iobshgt,i)) ) - call nc_diag_metadata("Time", sngl(dtime-time_offset) ) - call nc_diag_metadata("Prep_QC_Mark", sngl(data(iqc,i)) ) - call nc_diag_metadata("Prep_Use_Flag", sngl(data(iuse,i)) ) + call screen_to_single_nc_diag_metadata("Latitude",(data(ilate,i)) ) + call screen_to_single_nc_diag_metadata("Longitude",(data(ilone,i)) ) + call screen_to_single_nc_diag_metadata("Station_Elevation",(data(istnelv,i)) ) + call screen_to_single_nc_diag_metadata("Pressure",(prest) ) + call screen_to_single_nc_diag_metadata("Height",(data(iobshgt,i)) ) + if(isnan(dtime) .or. isnan(time_offset)) then + call nc_diag_metadata("Time",sngl(real(r_missing))) + else + call nc_diag_metadata("Time",sngl(dtime-time_offset)) + endif + call screen_to_single_nc_diag_metadata("Prep_QC_Mark",(data(iqc,i)) ) + call screen_to_single_nc_diag_metadata("Prep_Use_Flag",(data(iuse,i)) ) call nc_diag_metadata("Setup_QC_Mark", missing ) if(muse(i)) then call nc_diag_metadata("Analysis_Use_Flag", 1._r_single ) else call nc_diag_metadata("Analysis_Use_Flag", -1._r_single ) endif - call nc_diag_metadata("Nonlinear_QC_Rel_Wgt", sngl(rwgt) ) - call nc_diag_metadata("Errinv_Input", sngl(errinv_input) ) - call nc_diag_metadata("Errinv_Adjust", sngl(errinv_adjst) ) - call nc_diag_metadata("Errinv_Final", sngl(errinv_final) ) - call nc_diag_metadata("Observation", sngl(dpw) ) - call nc_diag_metadata("Obs_Minus_Forecast_adjusted", sngl(ddiff) ) - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(dpw-pwges) ) + call screen_to_single_nc_diag_metadata("Nonlinear_QC_Rel_Wgt",(rwgt) ) + call screen_to_single_nc_diag_metadata("Errinv_Input",(errinv_input) ) + call screen_to_single_nc_diag_metadata("Errinv_Adjust",(errinv_adjst) ) + call screen_to_single_nc_diag_metadata("Errinv_Final",(errinv_final) ) + call screen_to_single_nc_diag_metadata("Observation",(dpw) ) + call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_adjusted",(ddiff) ) + if(isnan(dpw) .or. isnan(pwges)) then + call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(real(r_missing))) + else + call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(dpw-pwges)) + endif if (lobsdiagsave) then do jj=1,miter if (odiag%muse(jj)) then diff --git a/src/gsi/setupq.f90 b/src/gsi/setupq.f90 index ed9fbb13db..ec8704ff9b 100644 --- a/src/gsi/setupq.f90 +++ b/src/gsi/setupq.f90 @@ -1261,6 +1261,8 @@ subroutine contents_binary_diagp_(odiag) end subroutine contents_binary_diagp_ subroutine contents_netcdf_diag_(odiag) + use constants, only: r_missing + use screen_to_ncdiag type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' q' @@ -1270,29 +1272,37 @@ subroutine contents_netcdf_diag_(odiag) call nc_diag_metadata("Observation_Class", obsclass ) call nc_diag_metadata("Observation_Type", ictype(ikx) ) call nc_diag_metadata("Observation_Subtype", icsubtype(ikx) ) - call nc_diag_metadata("Latitude", sngl(data(ilate,i)) ) - call nc_diag_metadata("Longitude", sngl(data(ilone,i)) ) - call nc_diag_metadata("Station_Elevation", sngl(data(istnelv,i)) ) - call nc_diag_metadata("Pressure", sngl(presq) ) - call nc_diag_metadata("Height", sngl(data(iobshgt,i)) ) - call nc_diag_metadata("Time", sngl(dtime-time_offset)) - call nc_diag_metadata("Prep_QC_Mark", sngl(data(iqc,i)) ) - call nc_diag_metadata("Prep_Use_Flag", sngl(data(iuse,i)) ) - call nc_diag_metadata("Nonlinear_QC_Var_Jb", sngl(var_jb) ) - call nc_diag_metadata("Nonlinear_QC_Rel_Wgt", sngl(rwgt) ) + call screen_to_single_nc_diag_metadata("Latitude",(data(ilate,i)) ) + call screen_to_single_nc_diag_metadata("Longitude",(data(ilone,i)) ) + call screen_to_single_nc_diag_metadata("Station_Elevation",(data(istnelv,i)) ) + call screen_to_single_nc_diag_metadata("Pressure",(presq) ) + call screen_to_single_nc_diag_metadata("Height",(data(iobshgt,i)) ) + if(isnan(dtime) .or. isnan(time_offset)) then + call nc_diag_metadata("Time",sngl(real(r_missing))) + else + call nc_diag_metadata("Time",sngl(dtime-time_offset)) + endif + call screen_to_single_nc_diag_metadata("Prep_QC_Mark",(data(iqc,i)) ) + call screen_to_single_nc_diag_metadata("Prep_Use_Flag",(data(iuse,i)) ) + call screen_to_single_nc_diag_metadata("Nonlinear_QC_Var_Jb",(var_jb) ) + call screen_to_single_nc_diag_metadata("Nonlinear_QC_Rel_Wgt",(rwgt) ) if(muse(i)) then call nc_diag_metadata("Analysis_Use_Flag", sngl(one) ) else call nc_diag_metadata("Analysis_Use_Flag", sngl(-one) ) endif - call nc_diag_metadata("Errinv_Input", sngl(errinv_input) ) - call nc_diag_metadata("Errinv_Adjust", sngl(errinv_adjst) ) - call nc_diag_metadata("Errinv_Final", sngl(errinv_final) ) - - call nc_diag_metadata("Observation", sngl(data(iqob,i))) - call nc_diag_metadata("Obs_Minus_Forecast_adjusted", sngl(ddiff) ) - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(qob-qges) ) - call nc_diag_metadata("Forecast_Saturation_Spec_Hum", sngl(qsges) ) + call screen_to_single_nc_diag_metadata("Errinv_Input",(errinv_input) ) + call screen_to_single_nc_diag_metadata("Errinv_Adjust",(errinv_adjst) ) + call screen_to_single_nc_diag_metadata("Errinv_Final",(errinv_final) ) + + call screen_to_single_nc_diag_metadata("Observation",(data(iqob,i))) + call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_adjusted",(ddiff) ) + if(isnan(qob) .or. isnan(qges)) then + call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(real(r_missing))) + else + call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(qob-qges)) + endif + call screen_to_single_nc_diag_metadata("Forecast_Saturation_Spec_Hum",(qsges) ) if (lobsdiagsave) then do jj=1,miter if (odiag%muse(jj)) then @@ -1305,14 +1315,14 @@ subroutine contents_netcdf_diag_(odiag) call nc_diag_data2d("ObsDiagSave_iuse", obsdiag_iuse ) call nc_diag_data2d("ObsDiagSave_nldepart", odiag%nldepart ) call nc_diag_data2d("ObsDiagSave_tldepart", odiag%tldepart ) - call nc_diag_data2d("ObsDiagSave_obssen", odiag%obssen ) + call nc_diag_data2d("ObsDiagSave_obssen", odiag%obssen ) endif if (twodvar_regional .or. l_obsprvdiag) then call nc_diag_metadata("Dominant_Sfc_Type", data(idomsfc,i) ) call nc_diag_metadata("Model_Terrain", data(izz,i) ) r_prvstg = data(iprvd,i) - call nc_diag_metadata("Provider_Name", c_prvstg ) + call nc_diag_metadata("Provider_Name", c_prvstg ) r_sprvstg = data(isprvd,i) call nc_diag_metadata("Subprovider_Name", c_sprvstg ) endif @@ -1325,6 +1335,8 @@ subroutine contents_netcdf_diag_(odiag) end subroutine contents_netcdf_diag_ subroutine contents_netcdf_diagp_(odiag) + use constants, only: r_missing + use screen_to_ncdiag type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' q' @@ -1334,29 +1346,33 @@ subroutine contents_netcdf_diagp_(odiag) call nc_diag_metadata("Observation_Class", obsclass ) call nc_diag_metadata("Observation_Type", ictype(ikx) ) call nc_diag_metadata("Observation_Subtype", -1 ) ! (-1 for pseudo obs sub-type) - call nc_diag_metadata("Latitude", sngl(data(ilate,i)) ) - call nc_diag_metadata("Longitude", sngl(data(ilone,i)) ) - call nc_diag_metadata("Station_Elevation", sngl(data(istnelv,i)) ) - call nc_diag_metadata("Pressure", sngl(presq) ) - call nc_diag_metadata("Height", sngl(data(iobshgt,i)) ) - call nc_diag_metadata("Time", sngl(dtime-time_offset)) - call nc_diag_metadata("Prep_QC_Mark", sngl(data(iqc,i)) ) - call nc_diag_metadata("Prep_Use_Flag", sngl(data(iuse,i)) ) - call nc_diag_metadata("Nonlinear_QC_Var_Jb", sngl(var_jb) ) - call nc_diag_metadata("Nonlinear_QC_Rel_Wgt", sngl(rwgt) ) + call screen_to_single_nc_diag_metadata("Latitude",(data(ilate,i)) ) + call screen_to_single_nc_diag_metadata("Longitude",(data(ilone,i)) ) + call screen_to_single_nc_diag_metadata("Station_Elevation",(data(istnelv,i)) ) + call screen_to_single_nc_diag_metadata("Pressure",(presq) ) + call screen_to_single_nc_diag_metadata("Height",(data(iobshgt,i)) ) + if(isnan(dtime) .or. isnan(time_offset)) then + call nc_diag_metadata("Time",sngl(real(r_missing))) + else + call nc_diag_metadata("Time",sngl(dtime-time_offset)) + endif + call screen_to_single_nc_diag_metadata("Prep_QC_Mark",(data(iqc,i)) ) + call screen_to_single_nc_diag_metadata("Prep_Use_Flag",(data(iuse,i)) ) + call screen_to_single_nc_diag_metadata("Nonlinear_QC_Var_Jb",(var_jb) ) + call screen_to_single_nc_diag_metadata("Nonlinear_QC_Rel_Wgt",(rwgt) ) if(muse(i)) then call nc_diag_metadata("Analysis_Use_Flag", sngl(one) ) else call nc_diag_metadata("Analysis_Use_Flag", sngl(-one) ) endif - call nc_diag_metadata("Errinv_Input", sngl(errinv_input) ) - call nc_diag_metadata("Errinv_Adjust", sngl(errinv_adjst) ) - call nc_diag_metadata("Errinv_Final", sngl(errinv_final) ) - - call nc_diag_metadata("Observation", sngl(data(iqob,i))) - call nc_diag_metadata("Obs_Minus_Forecast_adjusted", sngl(ddiff) ) - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(ddiff) ) - call nc_diag_metadata("Forecast_Saturation_Spec_Hum", sngl(qsges) ) + call screen_to_single_nc_diag_metadata("Errinv_Input",(errinv_input) ) + call screen_to_single_nc_diag_metadata("Errinv_Adjust",(errinv_adjst) ) + call screen_to_single_nc_diag_metadata("Errinv_Final",(errinv_final) ) + + call screen_to_single_nc_diag_metadata("Observation",(data(iqob,i))) + call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_adjusted",(ddiff) ) + call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_unadjusted",(ddiff) ) + call screen_to_single_nc_diag_metadata("Forecast_Saturation_Spec_Hum",(qsges) ) !---- if (lobsdiagsave) then do jj=1,miter @@ -1370,14 +1386,14 @@ subroutine contents_netcdf_diagp_(odiag) call nc_diag_data2d("ObsDiagSave_iuse", obsdiag_iuse ) call nc_diag_data2d("ObsDiagSave_nldepart", odiag%nldepart ) call nc_diag_data2d("ObsDiagSave_tldepart", odiag%tldepart ) - call nc_diag_data2d("ObsDiagSave_obssen", odiag%obssen ) + call nc_diag_data2d("ObsDiagSave_obssen", odiag%obssen ) endif if (twodvar_regional .or. l_obsprvdiag) then call nc_diag_metadata("Dominant_Sfc_Type", data(idomsfc,i) ) call nc_diag_metadata("Model_Terrain", data(izz,i) ) r_prvstg = data(iprvd,i) - call nc_diag_metadata("Provider_Name", "88888888" ) + call nc_diag_metadata("Provider_Name", "88888888" ) r_sprvstg = data(isprvd,i) call nc_diag_metadata("Subprovider_Name", "88888888" ) endif diff --git a/src/gsi/setuprad.f90 b/src/gsi/setuprad.f90 index 479d27af96..4cc3a47955 100644 --- a/src/gsi/setuprad.f90 +++ b/src/gsi/setuprad.f90 @@ -551,10 +551,12 @@ subroutine setuprad(obsLL,odiagLL,lunin,mype,aivals,stats,nchanl,nreal,nobs,& end if ! Load channel numbers into local array based on satellite type + if (iuse_rad(j)==4) then + predx(:,j)=zero + endif ich(jc)=j do i=1,npred - if (iuse_rad(j)==4) predx(i,j)=zero predchan(i,jc)=predx(i,j) end do ! @@ -2550,6 +2552,7 @@ subroutine contents_binary_diag_(odiags,idv,iob) end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_(odiags,idv,iob) + use screen_to_ncdiag type(fptr_obsdiagNode),dimension(:),intent(in):: odiags integer(i_kind),intent(in):: idv,iob @@ -2571,41 +2574,53 @@ subroutine contents_netcdf_diag_(odiags,idv,iob) do i=1,nchanl_diag call nc_diag_metadata("Channel_Index", i ) call nc_diag_metadata("Observation_Class", obsclass ) - call nc_diag_metadata("Latitude", sngl(cenlat) ) ! observation latitude (degrees) - call nc_diag_metadata("Longitude", sngl(cenlon) ) ! observation longitude (degrees) + call screen_to_single_nc_diag_metadata("Latitude",(cenlat) ) ! observation latitude (degrees) + call screen_to_single_nc_diag_metadata("Longitude",(cenlon) ) ! observation longitude (degrees) - call nc_diag_metadata("Elevation", sngl(zsges) ) ! model (guess) elevation at observation location + call screen_to_single_nc_diag_metadata("Elevation",(zsges) ) ! model (guess) elevation at observation location - call nc_diag_metadata("Obs_Time", sngl(dtime-time_offset) ) ! observation time (hours relative to analysis time) + if(isnan(dtime) .or. isnan(time_offset)) then + call nc_diag_metadata("Time",sngl(real(r_missing))) + else + call nc_diag_metadata("Time",sngl(dtime-time_offset)) + endif - call nc_diag_metadata("Scan_Position", sngl(data_s(iscan_pos,n)) ) ! sensor scan position - call nc_diag_metadata("Sat_Zenith_Angle", sngl(zasat*rad2deg) ) ! satellite zenith angle (degrees) - call nc_diag_metadata("Sat_Azimuth_Angle", sngl(data_s(ilazi_ang,n)) ) ! satellite azimuth angle (degrees) - call nc_diag_metadata("Sol_Zenith_Angle", sngl(pangs) ) ! solar zenith angle (degrees) - call nc_diag_metadata("Sol_Azimuth_Angle", sngl(data_s(isazi_ang,n)) ) ! solar azimuth angle (degrees) - call nc_diag_metadata("Sun_Glint_Angle", sngl(sgagl) ) ! sun glint angle (degrees) (sgagl) - call nc_diag_metadata("Scan_Angle", sngl(data_s(iscan_ang,n)*rad2deg) ) ! scan angle + call screen_to_single_nc_diag_metadata("Scan_Position",(data_s(iscan_pos,n)) ) ! sensor scan position + if(isnan(zasat)) then + call nc_diag_metadata("Sat_Zenith_Angle", sngl(real(r_missing))) ! satellite zenith angle (degrees) + else + call nc_diag_metadata("Sat_Zenith_Angle", sngl(zasat*rad2deg)) ! satellite zenith angle (degrees) + endif + call screen_to_single_nc_diag_metadata("Sat_Azimuth_Angle",(data_s(ilazi_ang,n)) ) ! satellite azimuth angle (degrees) + call screen_to_single_nc_diag_metadata("Sol_Zenith_Angle",(pangs) ) ! solar zenith angle (degrees) + call screen_to_single_nc_diag_metadata("Sol_Azimuth_Angle",(data_s(isazi_ang,n)) ) ! solar azimuth angle (degrees) + call screen_to_single_nc_diag_metadata("Sun_Glint_Angle",(sgagl) ) ! sun glint angle (degrees) (sgagl) + if(isnan(data_s(iscan_ang,n))) then + call nc_diag_metadata("Scan_Angle",sngl(real(r_missing))) ! scan angle + else + call nc_diag_metadata("Scan_Angle",sngl(data_s(iscan_ang,n)*rad2deg)) ! scan angle + endif - call nc_diag_metadata("Water_Fraction", sngl(surface(1)%water_coverage) ) ! fractional coverage by water - call nc_diag_metadata("Land_Fraction", sngl(surface(1)%land_coverage) ) ! fractional coverage by land - call nc_diag_metadata("Ice_Fraction", sngl(surface(1)%ice_coverage) ) ! fractional coverage by ice - call nc_diag_metadata("Snow_Fraction", sngl(surface(1)%snow_coverage) ) ! fractional coverage by snow + call screen_to_single_nc_diag_metadata("Water_Fraction",(surface(1)%water_coverage) ) ! fractional coverage by water + call screen_to_single_nc_diag_metadata("Land_Fraction",(surface(1)%land_coverage) ) ! fractional coverage by land + call screen_to_single_nc_diag_metadata("Ice_Fraction",(surface(1)%ice_coverage) ) ! fractional coverage by ice + call screen_to_single_nc_diag_metadata("Snow_Fraction",(surface(1)%snow_coverage) ) ! fractional coverage by snow if(.not. retrieval)then - call nc_diag_metadata("Water_Temperature", sngl(surface(1)%water_temperature) ) ! surface temperature over water (K) - call nc_diag_metadata("Land_Temperature", sngl(surface(1)%land_temperature) ) ! surface temperature over land (K) - call nc_diag_metadata("Ice_Temperature", sngl(surface(1)%ice_temperature) ) ! surface temperature over ice (K) - call nc_diag_metadata("Snow_Temperature", sngl(surface(1)%snow_temperature) ) ! surface temperature over snow (K) - call nc_diag_metadata("Soil_Temperature", sngl(surface(1)%soil_temperature) ) ! soil temperature (K) - call nc_diag_metadata("Soil_Moisture", sngl(surface(1)%soil_moisture_content) ) ! soil moisture + call screen_to_single_nc_diag_metadata("Water_Temperature",(surface(1)%water_temperature) ) ! surface temperature over water (K) + call screen_to_single_nc_diag_metadata("Land_Temperature",(surface(1)%land_temperature) ) ! surface temperature over land (K) + call screen_to_single_nc_diag_metadata("Ice_Temperature",(surface(1)%ice_temperature) ) ! surface temperature over ice (K) + call screen_to_single_nc_diag_metadata("Snow_Temperature",(surface(1)%snow_temperature) ) ! surface temperature over snow (K) + call screen_to_single_nc_diag_metadata("Soil_Temperature",(surface(1)%soil_temperature) ) ! soil temperature (K) + call screen_to_single_nc_diag_metadata("Soil_Moisture",(surface(1)%soil_moisture_content) ) ! soil moisture call nc_diag_metadata("Land_Type_Index", surface(1)%land_type ) ! surface land type call nc_diag_metadata("tsavg5", missing ) ! SST first guess used for SST retrieval - call nc_diag_metadata("sstcu", missing ) ! NCEP SST analysis at t - call nc_diag_metadata("sstph", missing ) ! Physical SST retrieval - call nc_diag_metadata("sstnv", missing ) ! Navy SST retrieval + call nc_diag_metadata("sstcu", missing ) ! NCEP SST analysis at t + call nc_diag_metadata("sstph", missing ) ! Physical SST retrieval + call nc_diag_metadata("sstnv", missing ) ! Navy SST retrieval call nc_diag_metadata("dta", missing ) ! d(ta) corresponding to sstph call nc_diag_metadata("dqa", missing ) ! d(qa) corresponding to sstph - call nc_diag_metadata("dtp_avh", missing ) ! data type + call nc_diag_metadata("dtp_avh", missing ) ! data type else call nc_diag_metadata("Water_Temperature", missing ) ! surface temperature over water (K) call nc_diag_metadata("Land_Temperature", missing ) ! surface temperature over land (K) @@ -2614,27 +2629,27 @@ subroutine contents_netcdf_diag_(odiags,idv,iob) call nc_diag_metadata("Soil_Temperature", missing ) ! soil temperature (K) call nc_diag_metadata("Soil_Moisture", missing ) ! soil moisture call nc_diag_metadata("Land_Type_Index", imissing ) ! surface land type - call nc_diag_metadata("tsavg5", sngl(tsavg5) ) ! SST first guess used for SST retrieval - call nc_diag_metadata("sstcu", sngl(sstcu) ) ! NCEP SST analysis at t - call nc_diag_metadata("sstph", sngl(sstph) ) ! Physical SST retrieval - call nc_diag_metadata("sstnv", sngl(sstnv) ) ! Navy SST retrieval - call nc_diag_metadata("dta", sngl(dta) ) ! d(ta) corresponding to sstph - call nc_diag_metadata("dqa", sngl(dqa) ) ! d(qa) corresponding to sstph - call nc_diag_metadata("dtp_avh", sngl(dtp_avh) ) ! data type + call screen_to_single_nc_diag_metadata("tsavg5",(tsavg5) ) ! SST first guess used for SST retrieval + call screen_to_single_nc_diag_metadata("sstcu",(sstcu) ) ! NCEP SST analysis at t + call screen_to_single_nc_diag_metadata("sstph",(sstph) ) ! Physical SST retrieval + call screen_to_single_nc_diag_metadata("sstnv",(sstnv) ) ! Navy SST retrieval + call screen_to_single_nc_diag_metadata("dta",(dta) ) ! d(ta) corresponding to sstph + call screen_to_single_nc_diag_metadata("dqa",(dqa) ) ! d(qa) corresponding to sstph + call screen_to_single_nc_diag_metadata("dtp_avh",(dtp_avh) ) ! data type endif - call nc_diag_metadata("Vegetation_Fraction", sngl(surface(1)%vegetation_fraction) ) - call nc_diag_metadata("Snow_Depth", sngl(surface(1)%snow_depth) ) - call nc_diag_metadata("tpwc", sngl(tpwc_obs) ) - call nc_diag_metadata("clw_guess_retrieval", sngl(clw_guess_retrieval) ) + call screen_to_single_nc_diag_metadata("Vegetation_Fraction",(surface(1)%vegetation_fraction) ) + call screen_to_single_nc_diag_metadata("Snow_Depth",(surface(1)%snow_depth) ) + call screen_to_single_nc_diag_metadata("tpwc",(tpwc_obs) ) + call screen_to_single_nc_diag_metadata("clw_guess_retrieval",(clw_guess_retrieval) ) - call nc_diag_metadata("Sfc_Wind_Speed", sngl(surface(1)%wind_speed) ) - call nc_diag_metadata("Cloud_Frac", sngl(cld) ) - call nc_diag_metadata("CTP", sngl(cldp) ) - call nc_diag_metadata("CLW", sngl(clw_obs) ) - call nc_diag_metadata("TPWC", sngl(tpwc_obs) ) - call nc_diag_metadata("clw_obs", sngl(clw_obs) ) - call nc_diag_metadata("clw_guess", sngl(clw_guess) ) + call screen_to_single_nc_diag_metadata("Sfc_Wind_Speed",(surface(1)%wind_speed) ) + call screen_to_single_nc_diag_metadata("Cloud_Frac",(cld) ) + call screen_to_single_nc_diag_metadata("CTP",(cldp) ) + call screen_to_single_nc_diag_metadata("CLW",(clw_obs) ) + call screen_to_single_nc_diag_metadata("TPWC",(tpwc_obs) ) + call screen_to_single_nc_diag_metadata("clw_obs",(clw_obs) ) + call screen_to_single_nc_diag_metadata("clw_guess",(clw_guess) ) if (nstinfo==0) then data_s(itref,n) = missing @@ -2643,21 +2658,21 @@ subroutine contents_netcdf_diag_(odiags,idv,iob) data_s(itz_tr,n) = missing endif - call nc_diag_metadata("Foundation_Temperature", sngl(data_s(itref,n)) ) ! reference temperature (Tr) in NSST - call nc_diag_metadata("SST_Warm_layer_dt", sngl(data_s(idtw,n)) ) ! dt_warm at zob - call nc_diag_metadata("SST_Cool_layer_tdrop", sngl(data_s(idtc,n)) ) ! dt_cool at zob - call nc_diag_metadata("SST_dTz_dTfound", sngl(data_s(itz_tr,n)) ) ! d(Tz)/d(Tr) + call screen_to_single_nc_diag_metadata("Foundation_Temperature",(data_s(itref,n)) ) ! reference temperature (Tr) in NSST + call screen_to_single_nc_diag_metadata("SST_Warm_layer_dt",(data_s(idtw,n)) ) ! dt_warm at zob + call screen_to_single_nc_diag_metadata("SST_Cool_layer_tdrop",(data_s(idtc,n)) ) ! dt_cool at zob + call screen_to_single_nc_diag_metadata("SST_dTz_dTfound",(data_s(itz_tr,n)) ) ! d(Tz)/d(Tr) - call nc_diag_metadata("Observation", sngl(tb_obs0(ich_diag(i))) ) ! observed brightness temperature (K) - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(tbcnob(ich_diag(i))) ) ! observed - simulated Tb with no bias correction (K) - call nc_diag_metadata("Obs_Minus_Forecast_adjusted", sngl(tbc0(ich_diag(i) )) ) ! observed - simulated Tb with bias corrrection (K) + call screen_to_single_nc_diag_metadata("Observation",(tb_obs0(ich_diag(i))) ) ! observed brightness temperature (K) + call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_unadjusted",(tbcnob(ich_diag(i))) ) ! observed - simulated Tb with no bias correction (K) + call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_adjusted",(tbc0(ich_diag(i) )) ) ! observed - simulated Tb with bias corrrection (K) errinv = sqrt(varinv0(ich_diag(i))) - call nc_diag_metadata("Inverse_Observation_Error", sngl(errinv) ) + call screen_to_single_nc_diag_metadata("Inverse_Observation_Error",(errinv) ) if (save_jacobian .and. allocated(idnames)) then - call nc_diag_metadata("Observation_scaled", sngl(tb_obs(ich_diag(i))) ) ! observed brightness temperature (K) scaled by R^{-1/2} - call nc_diag_metadata("Obs_Minus_Forecast_adjusted_scaled", sngl(tbc(ich_diag(i) )) ) ! observed - simulated Tb with bias corrrection (K) scaled by R^{-1/2} + call screen_to_single_nc_diag_metadata("Observation_scaled",(tb_obs(ich_diag(i))) ) ! observed brightness temperature (K) scaled by R^{-1/2} + call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_adjusted_scaled",(tbc(ich_diag(i) )) ) ! observed - simulated Tb with bias corrrection (K) scaled by R^{-1/2} errinv = sqrt(varinv(ich_diag(i))) - call nc_diag_metadata("Inverse_Observation_Error_scaled", sngl(errinv) ) + call screen_to_single_nc_diag_metadata("Inverse_Observation_Error_scaled",(errinv) ) endif if (save_jacobian) then j = 1 @@ -2696,34 +2711,34 @@ subroutine contents_netcdf_diag_(odiags,idv,iob) useflag=one if (iuse_rad(ich(ich_diag(i))) < 1) useflag=-one - call nc_diag_metadata("QC_Flag", sngl(id_qc(ich_diag(i))*useflag) ) ! quality control mark or event indicator - - call nc_diag_metadata("Emissivity", sngl(emissivity(ich_diag(i))) ) ! surface emissivity - call nc_diag_metadata("Weighted_Lapse_Rate", sngl(tlapchn(ich_diag(i))) ) ! stability index - call nc_diag_metadata("dTb_dTs", sngl(ts(ich_diag(i))) ) ! d(Tb)/d(Ts) - - call nc_diag_metadata("BC_Constant", sngl(predbias(1,ich_diag(i))) ) ! constant bias correction term - call nc_diag_metadata("BC_Scan_Angle", sngl(predbias(2,ich_diag(i))) ) ! scan angle bias correction term - call nc_diag_metadata("BC_Cloud_Liquid_Water", sngl(predbias(3,ich_diag(i))) ) ! CLW bias correction term - call nc_diag_metadata("BC_Lapse_Rate_Squared", sngl(predbias(4,ich_diag(i))) ) ! square lapse rate bias correction term - call nc_diag_metadata("BC_Lapse_Rate", sngl(predbias(5,ich_diag(i))) ) ! lapse rate bias correction term - call nc_diag_metadata("BC_Cosine_Latitude_times_Node", sngl(predbias(6,ich_diag(i))) ) ! node*cos(lat) bias correction term - call nc_diag_metadata("BC_Sine_Latitude", sngl(predbias(7,ich_diag(i))) ) ! sin(lat) bias correction term - call nc_diag_metadata("BC_Emissivity", sngl(predbias(8,ich_diag(i))) ) ! emissivity sensitivity bias correction term - call nc_diag_metadata("BC_Fixed_Scan_Position", sngl(predbias(npred+1,ich_diag(i))) ) ! external scan angle + call nc_diag_metadata("QC_Flag",sngl(id_qc(ich_diag(i))*useflag))! quality control mark or event indicator + + call screen_to_single_nc_diag_metadata("Emissivity",(emissivity(ich_diag(i))) ) ! surface emissivity + call screen_to_single_nc_diag_metadata("Weighted_Lapse_Rate",(tlapchn(ich_diag(i))) ) ! stability index + call screen_to_single_nc_diag_metadata("dTb_dTs",(ts(ich_diag(i))) ) ! d(Tb)/d(Ts) + + call screen_to_single_nc_diag_metadata("BC_Constant",(predbias(1,ich_diag(i))) ) ! constant bias correction term + call screen_to_single_nc_diag_metadata("BC_Scan_Angle",(predbias(2,ich_diag(i))) ) ! scan angle bias correction term + call screen_to_single_nc_diag_metadata("BC_Cloud_Liquid_Water",(predbias(3,ich_diag(i))) ) ! CLW bias correction term + call screen_to_single_nc_diag_metadata("BC_Lapse_Rate_Squared",(predbias(4,ich_diag(i))) ) ! square lapse rate bias correction term + call screen_to_single_nc_diag_metadata("BC_Lapse_Rate",(predbias(5,ich_diag(i))) ) ! lapse rate bias correction term + call screen_to_single_nc_diag_metadata("BC_Cosine_Latitude_times_Node",(predbias(6,ich_diag(i))) ) ! node*cos(lat) bias correction term + call screen_to_single_nc_diag_metadata("BC_Sine_Latitude",(predbias(7,ich_diag(i))) ) ! sin(lat) bias correction term + call screen_to_single_nc_diag_metadata("BC_Emissivity",(predbias(8,ich_diag(i))) ) ! emissivity sensitivity bias correction term + call screen_to_single_nc_diag_metadata("BC_Fixed_Scan_Position",(predbias(npred+1,ich_diag(i))) ) ! external scan angle if (lwrite_predterms) then - call nc_diag_metadata("BCPred_Constant", sngl(pred(1,ich_diag(i))) ) ! constant bias correction term - call nc_diag_metadata("BCPred_Scan_Angle", sngl(pred(2,ich_diag(i))) ) ! scan angle bias correction term - call nc_diag_metadata("BCPred_Cloud_Liquid_Water", sngl(pred(3,ich_diag(i))) ) ! CLW bias correction term - call nc_diag_metadata("BCPred_Lapse_Rate_Squared", sngl(pred(4,ich_diag(i))) ) ! square lapse rate bias correction term - call nc_diag_metadata("BCPred_Lapse_Rate", sngl(pred(5,ich_diag(i))) ) ! lapse rate bias correction term - call nc_diag_metadata("BCPred_Cosine_Latitude_times_Node", sngl(pred(6,ich_diag(i))) ) ! node*cos(lat) bias correction term - call nc_diag_metadata("BCPred_Sine_Latitude", sngl(pred(7,ich_diag(i))) ) ! sin(lat) bias correction term - call nc_diag_metadata("BCPred_Emissivity", sngl(pred(8,ich_diag(i))) ) ! emissivity sensitivity bias correction term + call screen_to_single_nc_diag_metadata("BCPred_Constant",(pred(1,ich_diag(i))) ) ! constant bias correction term + call screen_to_single_nc_diag_metadata("BCPred_Scan_Angle",(pred(2,ich_diag(i))) ) ! scan angle bias correction term + call screen_to_single_nc_diag_metadata("BCPred_Cloud_Liquid_Water",(pred(3,ich_diag(i))) ) ! CLW bias correction term + call screen_to_single_nc_diag_metadata("BCPred_Lapse_Rate_Squared",(pred(4,ich_diag(i))) ) ! square lapse rate bias correction term + call screen_to_single_nc_diag_metadata("BCPred_Lapse_Rate",(pred(5,ich_diag(i))) ) ! lapse rate bias correction term + call screen_to_single_nc_diag_metadata("BCPred_Cosine_Latitude_times_Node",(pred(6,ich_diag(i))) ) ! node*cos(lat) bias correction term + call screen_to_single_nc_diag_metadata("BCPred_Sine_Latitude",(pred(7,ich_diag(i))) ) ! sin(lat) bias correction term + call screen_to_single_nc_diag_metadata("BCPred_Emissivity",(pred(8,ich_diag(i))) ) ! emissivity sensitivity bias correction term endif if (lwrite_peakwt) then - call nc_diag_metadata("Press_Max_Weight_Function", sngl(weightmax(ich_diag(i))) ) + call screen_to_single_nc_diag_metadata("Press_Max_Weight_Function",(weightmax(ich_diag(i))) ) endif if (adp_anglebc) then do j=1, angord diff --git a/src/gsi/setuprw.f90 b/src/gsi/setuprw.f90 index c32ea80ab7..882c1f8081 100644 --- a/src/gsi/setuprw.f90 +++ b/src/gsi/setuprw.f90 @@ -1311,6 +1311,8 @@ subroutine contents_binary_diag_(odiag) end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_(odiag) + use constants, only: r_missing + use screen_to_ncdiag type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' rw' @@ -1319,29 +1321,37 @@ subroutine contents_netcdf_diag_(odiag) call nc_diag_metadata("Observation_Class", obsclass ) call nc_diag_metadata("Observation_Type", ictype(ikx) ) call nc_diag_metadata("Observation_Subtype", icsubtype(ikx) ) - call nc_diag_metadata("Latitude", sngl(data(ilate,i)) ) - call nc_diag_metadata("Longitude", sngl(data(ilone,i)) ) - call nc_diag_metadata("Station_Elevation", sngl(data(ielev,i)) ) - call nc_diag_metadata("Pressure", sngl(presw) ) - call nc_diag_metadata("Height", sngl(data(ihgt,i)) ) - call nc_diag_metadata("Time", sngl(dtime-time_offset)) + call screen_to_single_nc_diag_metadata("Latitude",(data(ilate,i)) ) + call screen_to_single_nc_diag_metadata("Longitude",(data(ilone,i)) ) + call screen_to_single_nc_diag_metadata("Station_Elevation",(data(ielev,i)) ) + call screen_to_single_nc_diag_metadata("Pressure",(presw) ) + call screen_to_single_nc_diag_metadata("Height",(data(ihgt,i)) ) + if(isnan(dtime) .or. isnan(time_offset)) then + call nc_diag_metadata("Time",sngl(real(r_missing))) + else + call nc_diag_metadata("Time",sngl(dtime-time_offset)) + endif call nc_diag_metadata("Prep_QC_Mark", sngl(zero) ) - call nc_diag_metadata("Prep_Use_Flag", sngl(data(iuse,i)) ) + call screen_to_single_nc_diag_metadata("Prep_Use_Flag",(data(iuse,i)) ) ! call nc_diag_metadata("Nonlinear_QC_Var_Jb", var_jb ) - call nc_diag_metadata("Nonlinear_QC_Rel_Wgt", sngl(rwgt) ) + call screen_to_single_nc_diag_metadata("Nonlinear_QC_Rel_Wgt",(rwgt) ) if(muse(i)) then call nc_diag_metadata("Analysis_Use_Flag", sngl(one) ) else call nc_diag_metadata("Analysis_Use_Flag", sngl(-one) ) endif - call nc_diag_metadata("Errinv_Input", sngl(errinv_input) ) - call nc_diag_metadata("Errinv_Adjust", sngl(errinv_adjst) ) - call nc_diag_metadata("Errinv_Final", sngl(errinv_final) ) + call screen_to_single_nc_diag_metadata("Errinv_Input",(errinv_input) ) + call screen_to_single_nc_diag_metadata("Errinv_Adjust",(errinv_adjst) ) + call screen_to_single_nc_diag_metadata("Errinv_Final",(errinv_final) ) - call nc_diag_metadata("Observation", sngl(data(irwob,i)) ) - call nc_diag_metadata("Obs_Minus_Forecast_adjusted", sngl(ddiff) ) - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(data(irwob,i)-rwwind) ) + call screen_to_single_nc_diag_metadata("Observation",(data(irwob,i)) ) + call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_adjusted",(ddiff) ) + if(isnan(data(irwob,i)) .or. isnan(rwwind)) then + call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(real(r_missing))) + else + call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(data(irwob,i)-rwwind) ) + endif if (lobsdiagsave) then do jj=1,miter diff --git a/src/gsi/setupspd.f90 b/src/gsi/setupspd.f90 index 91b2467bf3..8ccbeb8cad 100644 --- a/src/gsi/setupspd.f90 +++ b/src/gsi/setupspd.f90 @@ -941,6 +941,8 @@ subroutine contents_binary_diag_(odiag) end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_(odiag) + use constants, only: r_missing + use screen_to_ncdiag type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' spd' @@ -949,29 +951,37 @@ subroutine contents_netcdf_diag_(odiag) call nc_diag_metadata("Observation_Class", obsclass ) call nc_diag_metadata("Observation_Type", ictype(ikx) ) call nc_diag_metadata("Observation_Subtype", icsubtype(ikx) ) - call nc_diag_metadata("Latitude", sngl(data(ilate,i)) ) - call nc_diag_metadata("Longitude", sngl(data(ilone,i)) ) - call nc_diag_metadata("Station_Elevation", sngl(data(istnelv,i)) ) - call nc_diag_metadata("Pressure", sngl(presw) ) - call nc_diag_metadata("Height", sngl(data(ihgt,i)) ) - call nc_diag_metadata("Time", sngl(dtime-time_offset)) - call nc_diag_metadata("Prep_QC_Mark", sngl(data(iqc,i)) ) - call nc_diag_metadata("Prep_Use_Flag", sngl(data(iuse,i)) ) + call screen_to_single_nc_diag_metadata("Latitude",(data(ilate,i)) ) + call screen_to_single_nc_diag_metadata("Longitude",(data(ilone,i)) ) + call screen_to_single_nc_diag_metadata("Station_Elevation",(data(istnelv,i)) ) + call screen_to_single_nc_diag_metadata("Pressure",(presw) ) + call screen_to_single_nc_diag_metadata("Height",(data(ihgt,i)) ) + if(isnan(dtime) .or. isnan(time_offset)) then + call nc_diag_metadata("Time",sngl(real(r_missing))) + else + call nc_diag_metadata("Time",sngl(dtime-time_offset)) + endif + call screen_to_single_nc_diag_metadata("Prep_QC_Mark",(data(iqc,i)) ) + call screen_to_single_nc_diag_metadata("Prep_Use_Flag",(data(iuse,i)) ) ! call nc_diag_metadata("Nonlinear_QC_Var_Jb", var_jb ) - call nc_diag_metadata("Nonlinear_QC_Rel_Wgt", sngl(rwgt) ) + call screen_to_single_nc_diag_metadata("Nonlinear_QC_Rel_Wgt",(rwgt) ) if(muse(i)) then call nc_diag_metadata("Analysis_Use_Flag", sngl(one) ) else call nc_diag_metadata("Analysis_Use_Flag", sngl(-one) ) endif - call nc_diag_metadata("Errinv_Input", sngl(errinv_input) ) - call nc_diag_metadata("Errinv_Adjust", sngl(errinv_adjst) ) - call nc_diag_metadata("Errinv_Final", sngl(errinv_final) ) + call screen_to_single_nc_diag_metadata("Errinv_Input",(errinv_input) ) + call screen_to_single_nc_diag_metadata("Errinv_Adjust",(errinv_adjst) ) + call screen_to_single_nc_diag_metadata("Errinv_Final",(errinv_final) ) - call nc_diag_metadata("Observation", sngl(spdob) ) - call nc_diag_metadata("Obs_Minus_Forecast_adjusted", sngl(ddiff) ) - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(spdob0-spdges) ) + call screen_to_single_nc_diag_metadata("Observation",(spdob) ) + call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_adjusted",(ddiff) ) + if(isnan(spdob0) .or. isnan(spdges)) then + call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(real(r_missing))) + else + call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(spdob0-spdges) ) + endif if (lobsdiagsave) then do jj=1,miter diff --git a/src/gsi/setupsst.f90 b/src/gsi/setupsst.f90 index 6562d0392f..31ed0c8458 100644 --- a/src/gsi/setupsst.f90 +++ b/src/gsi/setupsst.f90 @@ -576,6 +576,7 @@ subroutine contents_binary_diag_(odiag) endif end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_(odiag) + use screen_to_ncdiag type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' sst' @@ -585,35 +586,43 @@ subroutine contents_netcdf_diag_(odiag) call nc_diag_metadata("Observation_Class", obsclass ) call nc_diag_metadata("Observation_Type", ictype(ikx) ) call nc_diag_metadata("Observation_Subtype", icsubtype(ikx) ) - call nc_diag_metadata("Latitude", sngl(data(ilate,i)) ) - call nc_diag_metadata("Longitude", sngl(data(ilone,i)) ) - call nc_diag_metadata("Station_Elevation", sngl(data(istnelv,i)) ) + call screen_to_single_nc_diag_metadata("Latitude",(data(ilate,i)) ) + call screen_to_single_nc_diag_metadata("Longitude",(data(ilone,i)) ) + call screen_to_single_nc_diag_metadata("Station_Elevation",(data(istnelv,i)) ) call nc_diag_metadata("Pressure", missing ) - call nc_diag_metadata("Height", sngl(data(izob,i)) ) - call nc_diag_metadata("Time", sngl(dtime-time_offset)) - call nc_diag_metadata("Prep_QC_Mark", sngl(data(ipct,i)) ) - call nc_diag_metadata("Prep_Use_Flag", sngl(data(iuse,i)) ) + call screen_to_single_nc_diag_metadata("Height",(data(izob,i)) ) + if(isnan(dtime) .or. isnan(time_offset)) then + call nc_diag_metadata("Time",sngl(real(r_missing))) + else + call nc_diag_metadata("Time",sngl(dtime-time_offset)) + endif + call screen_to_single_nc_diag_metadata("Prep_QC_Mark",(data(ipct,i)) ) + call screen_to_single_nc_diag_metadata("Prep_Use_Flag",(data(iuse,i)) ) ! call nc_diag_metadata("Nonlinear_QC_Var_Jb", var_jb ) - call nc_diag_metadata("Nonlinear_QC_Rel_Wgt", sngl(rwgt) ) + call screen_to_single_nc_diag_metadata("Nonlinear_QC_Rel_Wgt",(rwgt) ) if(muse(i)) then call nc_diag_metadata("Analysis_Use_Flag", sngl(one) ) else call nc_diag_metadata("Analysis_Use_Flag", sngl(-one) ) endif - call nc_diag_metadata("Errinv_Input", sngl(errinv_input) ) - call nc_diag_metadata("Errinv_Adjust", sngl(errinv_adjst) ) - call nc_diag_metadata("Errinv_Final", sngl(errinv_final) ) + call screen_to_single_nc_diag_metadata("Errinv_Input",(errinv_input) ) + call screen_to_single_nc_diag_metadata("Errinv_Adjust",(errinv_adjst) ) + call screen_to_single_nc_diag_metadata("Errinv_Final",(errinv_final) ) - call nc_diag_metadata("Observation", sngl(data(isst,i)) ) - call nc_diag_metadata("Obs_Minus_Forecast_adjusted", sngl(ddiff) ) - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(data(isst,i)-sstges) ) + call screen_to_single_nc_diag_metadata("Observation",(data(isst,i)) ) + call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_adjusted",(ddiff) ) + if(isnan(data(isst,i)) .or. isnan(sstges)) then + call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(real(r_missing))) + else + call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(data(isst,i)-sstges)) + endif if (nst_gsi>0) then - call nc_diag_metadata("FoundationTempBG", sngl(data(itref,i)) ) - call nc_diag_metadata("DiurnalWarming_at_zob", sngl(data(idtw,i)) ) - call nc_diag_metadata("SkinLayerCooling_at_zob", sngl(data(idtw,i)) ) - call nc_diag_metadata("Sensitivity_Tzob_Tr", sngl(data(itz_tr,i)) ) + call screen_to_single_nc_diag_metadata("FoundationTempBG",(data(itref,i)) ) + call screen_to_single_nc_diag_metadata("DiurnalWarming_at_zob",(data(idtw,i)) ) + call screen_to_single_nc_diag_metadata("SkinLayerCooling_at_zob",(data(idtw,i)) ) + call screen_to_single_nc_diag_metadata("Sensitivity_Tzob_Tr",(data(itz_tr,i)) ) endif if (lobsdiagsave) then diff --git a/src/gsi/setupswcp.f90 b/src/gsi/setupswcp.f90 index c65ad1495c..d0a745a914 100644 --- a/src/gsi/setupswcp.f90 +++ b/src/gsi/setupswcp.f90 @@ -882,6 +882,8 @@ subroutine contents_binary_diag_(odiag) end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_(odiag) + use constants, only: r_missing + use screen_to_ncdiag type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' swcp' @@ -893,28 +895,36 @@ subroutine contents_netcdf_diag_(odiag) call nc_diag_metadata("Observation_Class", obsclass ) call nc_diag_metadata("Observation_Type", ictype(ikx) ) call nc_diag_metadata("Observation_Subtype", icsubtype(ikx) ) - call nc_diag_metadata("Latitude", sngl(data(ilate,i)) ) - call nc_diag_metadata("Longitude", sngl(data(ilone,i)) ) - call nc_diag_metadata("Station_Elevation", sngl(data(istnelv,i)) ) - call nc_diag_metadata("Pressure", sngl(data(iobsprs,i)) ) - call nc_diag_metadata("Height", sngl(data(iobshgt,i)) ) - call nc_diag_metadata("Time", sngl(dtime-time_offset)) - call nc_diag_metadata("Prep_QC_Mark", sngl(data(iqc,i)) ) - call nc_diag_metadata("Setup_QC_Mark", sngl(rmiss_single) ) - call nc_diag_metadata("Prep_Use_Flag", sngl(data(iuse,i)) ) + call screen_to_single_nc_diag_metadata("Latitude",(data(ilate,i)) ) + call screen_to_single_nc_diag_metadata("Longitude",(data(ilone,i)) ) + call screen_to_single_nc_diag_metadata("Station_Elevation",(data(istnelv,i)) ) + call screen_to_single_nc_diag_metadata("Pressure",(data(iobsprs,i)) ) + call screen_to_single_nc_diag_metadata("Height",(data(iobshgt,i)) ) + if(isnan(dtime) .or. isnan(time_offset)) then + call nc_diag_metadata("Time",sngl(real(r_missing))) + else + call nc_diag_metadata("Time",sngl(dtime-time_offset)) + endif + call screen_to_single_nc_diag_metadata("Prep_QC_Mark",(data(iqc,i)) ) + call nc_diag_metadata("Setup_QC_Mark",(rmiss_single) ) + call screen_to_single_nc_diag_metadata("Prep_Use_Flag",(data(iuse,i)) ) if(muse(i)) then call nc_diag_metadata("Analysis_Use_Flag", sngl(one) ) else call nc_diag_metadata("Analysis_Use_Flag", sngl(-one) ) endif - call nc_diag_metadata("Nonlinear_QC_Rel_Wgt", sngl(rwgt) ) - call nc_diag_metadata("Errinv_Input", sngl(errinv_input) ) - call nc_diag_metadata("Errinv_Adjust", sngl(errinv_adjst) ) - call nc_diag_metadata("Errinv_Final", sngl(errinv_final) ) - call nc_diag_metadata("Observation", sngl(dswcp) ) - call nc_diag_metadata("Obs_Minus_Forecast_adjusted", sngl(ddiff) ) - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(dswcp-swcpges)) + call screen_to_single_nc_diag_metadata("Nonlinear_QC_Rel_Wgt",(rwgt) ) + call screen_to_single_nc_diag_metadata("Errinv_Input",(errinv_input) ) + call screen_to_single_nc_diag_metadata("Errinv_Adjust",(errinv_adjst) ) + call screen_to_single_nc_diag_metadata("Errinv_Final",(errinv_final) ) + call screen_to_single_nc_diag_metadata("Observation",(dswcp) ) + call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_adjusted",(ddiff) ) + if(isnan(dswcp) .or. isnan(swcpges)) then + call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(real(r_missing))) + else + call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(dswcp-swcpges)) + endif if (lobsdiagsave) then do jj=1,miter diff --git a/src/gsi/setupt.f90 b/src/gsi/setupt.f90 index 815c16014d..3a37515007 100644 --- a/src/gsi/setupt.f90 +++ b/src/gsi/setupt.f90 @@ -63,7 +63,7 @@ subroutine setupt(obsLL,odiagLL,lunin,mype,bwork,awork,nele,nobs,is,conv_diagsav use constants, only: zero, one, four,t0c,rd_over_cp,three,rd_over_cp_mass,ten use constants, only: tiny_r_kind,half,two use constants, only: huge_single,r1000,wgtlim,r10,fv - use constants, only: one_quad + use constants, only: one_quad, r_missing use convinfo, only: nconvtype,cermin,cermax,cgross,cvar_b,cvar_pg,ictype,icsubtype use convinfo, only: ibeta,ikapa use converr_t, only: ptabl_t @@ -1663,6 +1663,7 @@ subroutine contents_binary_diagp_(odiag) end subroutine contents_binary_diagp_ subroutine contents_netcdf_diag_(odiag) + use screen_to_ncdiag type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' t' @@ -1674,36 +1675,44 @@ subroutine contents_netcdf_diag_(odiag) call nc_diag_metadata("Observation_Class", obsclass ) call nc_diag_metadata("Observation_Type", ictype(ikx) ) call nc_diag_metadata("Observation_Subtype", icsubtype(ikx) ) - call nc_diag_metadata("Latitude", sngl(data(ilate,i)) ) - call nc_diag_metadata("Longitude", sngl(data(ilone,i)) ) - call nc_diag_metadata("Station_Elevation", sngl(data(istnelv,i)) ) - call nc_diag_metadata("Pressure", sngl(prest) ) - call nc_diag_metadata("Height", sngl(data(iobshgt,i)) ) - call nc_diag_metadata("Time", sngl(dtime-time_offset)) - call nc_diag_metadata("Prep_QC_Mark", sngl(data(iqc,i)) ) - call nc_diag_metadata("Setup_QC_Mark", sngl(data(iqt,i)) ) - call nc_diag_metadata("Prep_Use_Flag", sngl(data(iuse,i)) ) + call screen_to_single_nc_diag_metadata("Latitude",data(ilate,i)) + call screen_to_single_nc_diag_metadata("Longitude",data(ilone,i)) + call screen_to_single_nc_diag_metadata("Station_Elevation",data(istnelv,i)) + call screen_to_single_nc_diag_metadata("Pressure",prest) + call screen_to_single_nc_diag_metadata("Height",data(iobshgt,i)) + if(isnan(dtime) .or. isnan(time_offset)) then + call nc_diag_metadata("Time",sngl(real(r_missing))) + else + call nc_diag_metadata("Time",sngl(dtime-time_offset)) + endif + call screen_to_single_nc_diag_metadata("Prep_QC_Mark",data(iqc,i)) + call screen_to_single_nc_diag_metadata("Setup_QC_Mark",data(iqt,i)) + call screen_to_single_nc_diag_metadata("Prep_Use_Flag",data(iuse,i)) if(muse(i)) then call nc_diag_metadata("Analysis_Use_Flag", sngl(one) ) else call nc_diag_metadata("Analysis_Use_Flag", sngl(-one) ) endif - call nc_diag_metadata("Nonlinear_QC_Rel_Wgt", sngl(rwgt) ) - call nc_diag_metadata("Errinv_Input", sngl(errinv_input) ) - call nc_diag_metadata("Errinv_Adjust", sngl(errinv_adjst) ) - call nc_diag_metadata("Errinv_Final", sngl(errinv_final) ) - call nc_diag_metadata("Observation", sngl(data(itob,i)) ) - call nc_diag_metadata("Obs_Minus_Forecast_adjusted", sngl(ddiff) ) - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(tob-tges) ) + call screen_to_single_nc_diag_metadata("Nonlinear_QC_Rel_Wgt",rwgt) + call screen_to_single_nc_diag_metadata("Errinv_Input",errinv_input ) + call screen_to_single_nc_diag_metadata("Errinv_Adjust",errinv_adjst ) + call screen_to_single_nc_diag_metadata("Errinv_Final",errinv_final ) + call screen_to_single_nc_diag_metadata("Observation",data(itob,i)) + call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_adjusted",ddiff ) + if(isnan(tob) .or. isnan(tges)) then + call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(real(r_missing)) ) + else + call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(tob-tges) ) + endif if (aircraft_t_bc_pof .or. aircraft_t_bc .or. aircraft_t_bc_ext) then - call nc_diag_metadata("Data_Pof", sngl(data(ipof,i)) ) - call nc_diag_metadata("Data_Vertical_Velocity", sngl(data(ivvlc,i)) ) + call screen_to_single_nc_diag_metadata("Data_Pof",data(ipof,i)) + call screen_to_single_nc_diag_metadata("Data_Vertical_Velocity",data(ivvlc,i)) if (npredt .gt. one) then call nc_diag_data2d("Bias_Correction_Terms", sngl(predbias) ) else if (npredt .eq. one) then - call nc_diag_metadata("Bias_Correction_Terms", sngl(predbias(1)) ) + call screen_to_single_nc_diag_metadata("Bias_Correction_Terms",predbias(1)) endif else call nc_diag_metadata("Data_Pof", missing ) @@ -1751,6 +1760,7 @@ subroutine contents_netcdf_diag_(odiag) end subroutine contents_netcdf_diag_ subroutine contents_netcdf_diagp_(odiag) + use screen_to_ncdiag type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' t' @@ -1762,28 +1772,36 @@ subroutine contents_netcdf_diagp_(odiag) call nc_diag_metadata("Observation_Class", obsclass ) call nc_diag_metadata("Observation_Type", ictype(ikx) ) call nc_diag_metadata("Observation_Subtype", -1 ) ! (-1 for pseudo obs sub-type) - call nc_diag_metadata("Latitude", sngl(data(ilate,i)) ) - call nc_diag_metadata("Longitude", sngl(data(ilone,i)) ) - call nc_diag_metadata("Station_Elevation", sngl(data(istnelv,i)) ) - call nc_diag_metadata("Pressure", sngl(prest) ) - call nc_diag_metadata("Height", sngl(data(iobshgt,i)) ) - call nc_diag_metadata("Time", sngl(dtime-time_offset)) - call nc_diag_metadata("Prep_QC_Mark", sngl(data(iqc,i)) ) - call nc_diag_metadata("Setup_QC_Mark", sngl(data(iqt,i)) ) - call nc_diag_metadata("Prep_Use_Flag", sngl(data(iuse,i)) ) + call screen_to_single_nc_diag_metadata("Latitude",data(ilate,i)) + call screen_to_single_nc_diag_metadata("Longitude",data(ilone,i)) + call screen_to_single_nc_diag_metadata("Station_Elevation",data(istnelv,i)) + call screen_to_single_nc_diag_metadata("Pressure",prest) + call screen_to_single_nc_diag_metadata("Height",data(iobshgt,i)) + if(isnan(dtime) .or. isnan(time_offset)) then + call nc_diag_metadata("Time",sngl(real(r_missing))) + else + call nc_diag_metadata("Time",sngl(dtime-time_offset)) + endif + call screen_to_single_nc_diag_metadata("Prep_QC_Mark",data(iqc,i)) + call screen_to_single_nc_diag_metadata("Setup_QC_Mark",data(iqt,i)) + call screen_to_single_nc_diag_metadata("Prep_Use_Flag",data(iuse,i)) if(muse(i)) then call nc_diag_metadata("Analysis_Use_Flag", sngl(one) ) else call nc_diag_metadata("Analysis_Use_Flag", sngl(-one) ) endif - call nc_diag_metadata("Nonlinear_QC_Rel_Wgt", sngl(var_jb*1.0e+6+rwgt)) - call nc_diag_metadata("Errinv_Input", sngl(errinv_input) ) - call nc_diag_metadata("Errinv_Adjust", sngl(errinv_adjst) ) - call nc_diag_metadata("Errinv_Final", sngl(errinv_final) ) - call nc_diag_metadata("Observation", sngl(data(itob,i)) ) - call nc_diag_metadata("Obs_Minus_Forecast_adjusted", sngl(ddiff) ) - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(ddiff) ) + if(isnan(var_jb) .or. isnan(rwgt)) then + call nc_diag_metadata("Nonlinear_QC_Rel_Wgt",sngl(real(r_missing))) + else + call nc_diag_metadata("Nonlinear_QC_Rel_Wgt",sngl(var_jb*1.0e+6+rwgt)) + endif + call screen_to_single_nc_diag_metadata("Errinv_Input",errinv_input ) + call screen_to_single_nc_diag_metadata("Errinv_Adjust",errinv_adjst ) + call screen_to_single_nc_diag_metadata("Errinv_Final",errinv_final ) + call screen_to_single_nc_diag_metadata("Observation",data(itob,i)) + call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_adjusted",ddiff ) + call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_unadjusted",ddiff ) !---- if (lobsdiagsave) then diff --git a/src/gsi/setuptcp.f90 b/src/gsi/setuptcp.f90 index cfef05d06c..ff9d1017e1 100644 --- a/src/gsi/setuptcp.f90 +++ b/src/gsi/setuptcp.f90 @@ -684,6 +684,8 @@ subroutine contents_binary_diag_(odiag) end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_(odiag) + use screen_to_ncdiag + use constants, only: r_missing type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' tcp' @@ -692,29 +694,45 @@ subroutine contents_netcdf_diag_(odiag) call nc_diag_metadata("Observation_Class", obsclass ) call nc_diag_metadata("Observation_Type", ictype(ikx) ) call nc_diag_metadata("Observation_Subtype", icsubtype(ikx) ) - call nc_diag_metadata("Latitude", sngl(data(ilate,i)) ) - call nc_diag_metadata("Longitude", sngl(data(ilone,i)) ) + call screen_to_single_nc_diag_metadata("Latitude",(data(ilate,i)) ) + call screen_to_single_nc_diag_metadata("Longitude",(data(ilone,i)) ) call nc_diag_metadata("Station_Elevation", sngl(zero) ) - call nc_diag_metadata("Pressure", sngl(data(ipres,i)*r10)) - call nc_diag_metadata("Height", sngl(zero) ) - call nc_diag_metadata("Time", sngl(dtime-time_offset)) + if(isnan(data(ipres,i))) then + call nc_diag_metadata("Pressure",sngl(real(r_missing))) + else + call nc_diag_metadata("Pressure", sngl(data(ipres,i)*r10)) + endif + call screen_to_single_nc_diag_metadata("Height",(zero) ) + if(isnan(dtime) .or. isnan(time_offset)) then + call nc_diag_metadata("Time",sngl(real(r_missing))) + else + call nc_diag_metadata("Time",sngl(dtime-time_offset)) + endif call nc_diag_metadata("Prep_QC_Mark", sngl(one) ) call nc_diag_metadata("Prep_Use_Flag", sngl(one) ) - call nc_diag_metadata("Nonlinear_QC_Rel_Wgt", sngl(rwgt) ) + call screen_to_single_nc_diag_metadata("Nonlinear_QC_Rel_Wgt",(rwgt) ) if(muse(i)) then call nc_diag_metadata("Analysis_Use_Flag", sngl(one) ) else call nc_diag_metadata("Analysis_Use_Flag", sngl(-one) ) endif - call nc_diag_metadata("Errinv_Input", sngl(errinv_input) ) - call nc_diag_metadata("Errinv_Adjust", sngl(errinv_adjst) ) - call nc_diag_metadata("Errinv_Final", sngl(errinv_final) ) + call screen_to_single_nc_diag_metadata("Errinv_Input",(errinv_input) ) + call screen_to_single_nc_diag_metadata("Errinv_Adjust",(errinv_adjst) ) + call screen_to_single_nc_diag_metadata("Errinv_Final",(errinv_final) ) - call nc_diag_metadata("Observation", sngl(pob) ) - call nc_diag_metadata("Obs_Minus_Forecast_adjusted", sngl(pob-pges) ) - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(pob-pgesorig)) + call screen_to_single_nc_diag_metadata("Observation",(pob) ) + if(isnan(pob) .or. isnan(pges)) then + call nc_diag_metadata("Obs_Minus_Forecast_adjusted", sngl(real(r_missing))) + else + call nc_diag_metadata("Obs_Minus_Forecast_adjusted", sngl(pob-pges) ) + endif + if(isnan(pob) .or. isnan(pgesorig)) then + call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(real(r_missing))) + else + call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(pob-pgesorig)) + endif if (lobsdiagsave) then do jj=1,miter diff --git a/src/gsi/setupw.f90 b/src/gsi/setupw.f90 index 62b58a0485..d3f0ea6a8b 100644 --- a/src/gsi/setupw.f90 +++ b/src/gsi/setupw.f90 @@ -1779,6 +1779,8 @@ subroutine contents_binary_diag_(udiag,vdiag) end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_(udiag,vdiag) + use constants, only: r_missing + use screen_to_ncdiag type(obs_diag),pointer,intent(in):: udiag,vdiag ! Observation class character(7),parameter :: obsclass = ' uv' @@ -1788,37 +1790,49 @@ subroutine contents_netcdf_diag_(udiag,vdiag) call nc_diag_metadata("Observation_Class", obsclass ) call nc_diag_metadata("Observation_Type", ictype(ikx) ) call nc_diag_metadata("Observation_Subtype", icsubtype(ikx) ) - call nc_diag_metadata("Latitude", sngl(data(ilate,i)) ) - call nc_diag_metadata("Longitude", sngl(data(ilone,i)) ) - call nc_diag_metadata("Station_Elevation", sngl(data(ielev,i)) ) - call nc_diag_metadata("Pressure", sngl(presw) ) - call nc_diag_metadata("Height", sngl(data(ihgt,i)) ) - call nc_diag_metadata("Time", sngl(dtime-time_offset)) - call nc_diag_metadata("Prep_QC_Mark", sngl(data(iqc,i)) ) + call screen_to_single_nc_diag_metadata("Latitude",(data(ilate,i)) ) + call screen_to_single_nc_diag_metadata("Longitude",(data(ilone,i)) ) + call screen_to_single_nc_diag_metadata("Station_Elevation",(data(ielev,i)) ) + call screen_to_single_nc_diag_metadata("Pressure",(presw) ) + call screen_to_single_nc_diag_metadata("Height",(data(ihgt,i)) ) + if(isnan(dtime) .or. isnan(time_offset)) then + call nc_diag_metadata("Time",sngl(real(r_missing))) + else + call nc_diag_metadata("Time",sngl(dtime-time_offset)) + endif + call screen_to_single_nc_diag_metadata("Prep_QC_Mark",(data(iqc,i)) ) ! call nc_diag_metadata("Setup_QC_Mark", rmiss_single ) - call nc_diag_metadata("Setup_QC_Mark", sngl(bmiss) ) - call nc_diag_metadata("Nonlinear_QC_Var_Jb", sngl(var_jb) ) - call nc_diag_metadata("Prep_Use_Flag", sngl(data(iuse,i)) ) + call screen_to_single_nc_diag_metadata("Setup_QC_Mark",(bmiss) ) + call screen_to_single_nc_diag_metadata("Nonlinear_QC_Var_Jb",(var_jb) ) + call screen_to_single_nc_diag_metadata("Prep_Use_Flag",(data(iuse,i)) ) if(muse(i)) then call nc_diag_metadata("Analysis_Use_Flag", sngl(one) ) else call nc_diag_metadata("Analysis_Use_Flag", sngl(-one) ) endif - call nc_diag_metadata("Nonlinear_QC_Rel_Wgt", sngl(rwgt) ) - call nc_diag_metadata("Errinv_Input", sngl(errinv_input) ) - call nc_diag_metadata("Errinv_Adjust", sngl(errinv_adjst) ) - call nc_diag_metadata("Errinv_Final", sngl(errinv_final) ) - call nc_diag_metadata("Wind_Reduction_Factor_at_10m", sngl(factw) ) + call screen_to_single_nc_diag_metadata("Nonlinear_QC_Rel_Wgt",(rwgt) ) + call screen_to_single_nc_diag_metadata("Errinv_Input",(errinv_input) ) + call screen_to_single_nc_diag_metadata("Errinv_Adjust",(errinv_adjst) ) + call screen_to_single_nc_diag_metadata("Errinv_Final",(errinv_final) ) + call screen_to_single_nc_diag_metadata("Wind_Reduction_Factor_at_10m",(factw)) if (.not. regional .or. fv3_regional) then - call nc_diag_metadata("u_Observation", sngl(data(iuob,i)) ) - call nc_diag_metadata("u_Obs_Minus_Forecast_adjusted", sngl(dudiff) ) - call nc_diag_metadata("u_Obs_Minus_Forecast_unadjusted", sngl(uob-ugesin) ) + call screen_to_single_nc_diag_metadata("u_Observation",(data(iuob,i)) ) + call screen_to_single_nc_diag_metadata("u_Obs_Minus_Forecast_adjusted",(dudiff) ) + if(isnan(uob) .or. isnan(ugesin)) then + call nc_diag_metadata("u_Obs_Minus_Forecast_unadjusted",sngl(real(r_missing))) + else + call nc_diag_metadata("u_Obs_Minus_Forecast_unadjusted",sngl(uob-ugesin)) + endif - call nc_diag_metadata("v_Observation", sngl(data(ivob,i)) ) - call nc_diag_metadata("v_Obs_Minus_Forecast_adjusted", sngl(dvdiff) ) - call nc_diag_metadata("v_Obs_Minus_Forecast_unadjusted", sngl(vob-vgesin) ) + call screen_to_single_nc_diag_metadata("v_Observation",(data(ivob,i)) ) + call screen_to_single_nc_diag_metadata("v_Obs_Minus_Forecast_adjusted",(dvdiff) ) + if(isnan(vob) .or. isnan(vgesin)) then + call nc_diag_metadata("v_Obs_Minus_Forecast_unadjusted",sngl(real(r_missing))) + else + call nc_diag_metadata("v_Obs_Minus_Forecast_unadjusted",sngl(vob-vgesin)) + endif else ! (if regional) ! replace positions 17-22 with earth relative wind component information @@ -1829,13 +1843,21 @@ subroutine contents_netcdf_diag_(udiag,vdiag) call rotate_wind_xy2ll(ugesin,vgesin,uges_e,vges_e,dlon_e,dlon,dlat) call rotate_wind_xy2ll(dudiff,dvdiff,dudiff_e,dvdiff_e,dlon_e,dlon,dlat) - call nc_diag_metadata("u_Observation", sngl(uob_e) ) - call nc_diag_metadata("u_Obs_Minus_Forecast_adjusted", sngl(dudiff_e) ) - call nc_diag_metadata("u_Obs_Minus_Forecast_unadjusted", sngl(uob_e-uges_e) ) + call screen_to_single_nc_diag_metadata("u_Observation",(uob_e) ) + call screen_to_single_nc_diag_metadata("u_Obs_Minus_Forecast_adjusted",(dudiff_e) ) + if(isnan(uob_e) .or. isnan(uges_e)) then + call nc_diag_metadata("u_Obs_Minus_Forecast_unadjusted",sngl(real(r_missing))) + else + call nc_diag_metadata("u_Obs_Minus_Forecast_unadjusted",sngl(uob_e-uges_e)) + endif - call nc_diag_metadata("v_Observation", sngl(vob_e) ) - call nc_diag_metadata("v_Obs_Minus_Forecast_adjusted", sngl(dvdiff_e) ) - call nc_diag_metadata("v_Obs_Minus_Forecast_unadjusted", sngl(vob_e-vges_e) ) + call screen_to_single_nc_diag_metadata("v_Observation",(vob_e) ) + call screen_to_single_nc_diag_metadata("v_Obs_Minus_Forecast_adjusted",(dvdiff_e) ) + if(isnan(vob_e) .or. isnan(vges_e)) then + call nc_diag_metadata("v_Obs_Minus_Forecast_unadjusted",sngl(real(r_missing))) + else + call nc_diag_metadata("v_Obs_Minus_Forecast_unadjusted",sngl(vob_e-vges_e)) + endif endif if (lobsdiagsave) then From 13591455393b4d30027362f9176f4600edf1621d Mon Sep 17 00:00:00 2001 From: "Ming.Hu" Date: Tue, 9 May 2023 23:34:03 +0000 Subject: [PATCH 02/44] Update Hera Intel compiler to intel 2022.01. --- modulefiles/gsi_common.lua | 6 ++++-- modulefiles/gsi_hera.intel.lua | 15 +++++++-------- regression/regression_namelists.sh | 14 +++++++------- src/gsi/general_read_gfsatm.f90 | 1 - 4 files changed, 18 insertions(+), 18 deletions(-) diff --git a/modulefiles/gsi_common.lua b/modulefiles/gsi_common.lua index b2b08f1197..58a9ece619 100644 --- a/modulefiles/gsi_common.lua +++ b/modulefiles/gsi_common.lua @@ -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" 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" @@ -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)) diff --git a/modulefiles/gsi_hera.intel.lua b/modulefiles/gsi_hera.intel.lua index 1efb6f4405..1e0ec97bbe 100644 --- a/modulefiles/gsi_hera.intel.lua +++ b/modulefiles/gsi_hera.intel.lua @@ -1,13 +1,12 @@ help([[ ]]) -prepend_path("MODULEPATH", "/scratch2/NCEPDEV/nwprod/hpc-stack/libs/hpc-stack/modulefiles/stack") +prepend_path("MODULEPATH", "/scratch1/NCEPDEV/nems/role.epic/hpc-stack/libs/intel-2022.1.2/modulefiles/stack") -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" +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)) @@ -15,9 +14,9 @@ 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)) +prepend_path("MODULEPATH", "/scratch1/NCEPDEV/nems/role.epic/miniconda3/modulefiles") +miniconda3_ver=os.getenv("miniconda3_ver") or "4.12.0" +load(pathJoin("miniconda3", miniconda3_ver)) load("gsi_common") diff --git a/regression/regression_namelists.sh b/regression/regression_namelists.sh index 824c6f0719..2463856499 100755 --- a/regression/regression_namelists.sh +++ b/regression/regression_namelists.sh @@ -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., use_readin_anl_sfcmask=.true., crtm_coeffs_path='./crtm_coeffs/', newpc4pred=.true.,adp_anglebc=.true.,angord=4,passive_bc=.true.,use_edges=.false., @@ -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 @@ -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 @@ -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., @@ -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, @@ -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., @@ -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 diff --git a/src/gsi/general_read_gfsatm.f90 b/src/gsi/general_read_gfsatm.f90 index a5d5fb77f4..0216b95fb6 100755 --- a/src/gsi/general_read_gfsatm.f90 +++ b/src/gsi/general_read_gfsatm.f90 @@ -2821,7 +2821,6 @@ subroutine general_read_gfsatm_allhydro_nc(grd,sp_a,filename,uvflag,vordivflag,z 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 From 362c76705841d5fa871685538bdde85ed5160e61 Mon Sep 17 00:00:00 2001 From: hu5970 Date: Wed, 10 May 2023 00:36:59 -0500 Subject: [PATCH 03/44] Update intel compile for Jet and Orion for using intel 2022.1 --- modulefiles/gsi_hera.intel.lua | 8 ++++---- modulefiles/gsi_jet.lua | 15 +++++++-------- modulefiles/gsi_orion.lua | 14 ++++++++------ 3 files changed, 19 insertions(+), 18 deletions(-) diff --git a/modulefiles/gsi_hera.intel.lua b/modulefiles/gsi_hera.intel.lua index 1e0ec97bbe..7c98d48ad9 100644 --- a/modulefiles/gsi_hera.intel.lua +++ b/modulefiles/gsi_hera.intel.lua @@ -1,6 +1,10 @@ help([[ ]]) +prepend_path("MODULEPATH", "/scratch1/NCEPDEV/nems/role.epic/miniconda3/modulefiles") +miniconda3_ver=os.getenv("miniconda3_ver") or "4.12.0" +load(pathJoin("miniconda3", miniconda3_ver)) + prepend_path("MODULEPATH", "/scratch1/NCEPDEV/nems/role.epic/hpc-stack/libs/intel-2022.1.2/modulefiles/stack") local hpc_ver=os.getenv("hpc_ver") or "1.2.0" @@ -14,10 +18,6 @@ load(pathJoin("hpc-intel", hpc_intel_ver)) load(pathJoin("hpc-impi", hpc_impi_ver)) load(pathJoin("cmake", cmake_ver)) -prepend_path("MODULEPATH", "/scratch1/NCEPDEV/nems/role.epic/miniconda3/modulefiles") -miniconda3_ver=os.getenv("miniconda3_ver") or "4.12.0" -load(pathJoin("miniconda3", miniconda3_ver)) - load("gsi_common") load(pathJoin("prod_util", prod_util_ver)) diff --git a/modulefiles/gsi_jet.lua b/modulefiles/gsi_jet.lua index 855597a08e..2f8cacff8a 100644 --- a/modulefiles/gsi_jet.lua +++ b/modulefiles/gsi_jet.lua @@ -1,13 +1,16 @@ 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") +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") 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)) @@ -15,10 +18,6 @@ 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)) diff --git a/modulefiles/gsi_orion.lua b/modulefiles/gsi_orion.lua index b69467f7ce..1f0787be50 100644 --- a/modulefiles/gsi_orion.lua +++ b/modulefiles/gsi_orion.lua @@ -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") +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") + +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") From 437d6fb4d94b3ecc67310f436751fa0593faae4d Mon Sep 17 00:00:00 2001 From: David Huber Date: Wed, 10 May 2023 15:17:35 +0000 Subject: [PATCH 04/44] Update S4 module, remove TODO. #447 --- modulefiles/gsi_s4.lua | 6 +++--- src/gsi/genstats_gps.f90 | 1 - 2 files changed, 3 insertions(+), 4 deletions(-) diff --git a/modulefiles/gsi_s4.lua b/modulefiles/gsi_s4.lua index f393ce516a..52e942f458 100644 --- a/modulefiles/gsi_s4.lua +++ b/modulefiles/gsi_s4.lua @@ -1,9 +1,9 @@ help([[ ]]) -local hpc_ver=os.getenv("hpc_ver") or "1.1.0" -local hpc_intel_ver=os.getenv("hpc_intel_ver") or "18.0.4" -local hpc_impi_ver=os.getenv("hpc_impi_ver") or "18.0.4" +local hpc_ver=os.getenv("hpc_ver") or "1.2.0" +local hpc_intel_ver=os.getenv("hpc_intel_ver") or "2022.1" +local hpc_impi_ver=os.getenv("hpc_impi_ver") or "2022.1" local miniconda_ver=os.getenv("miniconda_ver") or "3.8-s4" local prod_util_ver=os.getenv("prod_util_ver") or "1.2.2" diff --git a/src/gsi/genstats_gps.f90 b/src/gsi/genstats_gps.f90 index d20587e49d..ab61f531de 100644 --- a/src/gsi/genstats_gps.f90 +++ b/src/gsi/genstats_gps.f90 @@ -784,7 +784,6 @@ subroutine contents_netcdf_diag_ 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 if(isnan(gps_allptr%rdiag(17)) .or. isnan(gps_allptr%rdiag(5))) then call nc_diag_metadata("Obs_Minus_Forecast_adjusted", sngl(real(r_missing))) call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(real(r_missing))) From f5d200d68421e4c9f58e15b6323d980694d5bf5b Mon Sep 17 00:00:00 2001 From: David Huber Date: Tue, 16 May 2023 21:43:57 -0500 Subject: [PATCH 05/44] Fix out of bounds ref and cleanup. #447 This fixes an array out of bounds error in read_iasi.f90 It also changes a cludge fix for huge integers It also adds 'only' statements for new `use` statements and matches endif/end if keywords with their surroundings. --- src/gsi/genstats_gps.f90 | 2 +- src/gsi/read_iasi.f90 | 2 -- src/gsi/read_prepbufr.f90 | 73 ++++++++++++++++----------------------- src/gsi/setupaod.f90 | 2 +- src/gsi/setupdbz.f90 | 2 +- src/gsi/setupdw.f90 | 2 +- src/gsi/setuplight.f90 | 2 +- src/gsi/setuplwcp.f90 | 2 +- src/gsi/setupoz.f90 | 4 +-- src/gsi/setupps.f90 | 2 +- src/gsi/setuppw.f90 | 2 +- src/gsi/setupq.f90 | 4 +-- src/gsi/setuprad.f90 | 2 +- src/gsi/setuprw.f90 | 2 +- src/gsi/setupspd.f90 | 2 +- src/gsi/setupsst.f90 | 2 +- src/gsi/setupswcp.f90 | 2 +- src/gsi/setupt.f90 | 4 +-- src/gsi/setuptcp.f90 | 2 +- src/gsi/setupw.f90 | 2 +- 20 files changed, 50 insertions(+), 67 deletions(-) diff --git a/src/gsi/genstats_gps.f90 b/src/gsi/genstats_gps.f90 index ab61f531de..20ba5de79b 100644 --- a/src/gsi/genstats_gps.f90 +++ b/src/gsi/genstats_gps.f90 @@ -754,7 +754,7 @@ end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_ use sparsearr, only: sparr2, readarray, fullarray use constants, only: r_missing - use screen_to_ncdiag + use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata integer(i_kind),dimension(miter) :: obsdiag_iuse integer(i_kind) :: obstype, obssubtype type(sparr2) :: dhx_dx diff --git a/src/gsi/read_iasi.f90 b/src/gsi/read_iasi.f90 index d0a3793b4e..c3cefe099a 100644 --- a/src/gsi/read_iasi.f90 +++ b/src/gsi/read_iasi.f90 @@ -729,8 +729,6 @@ subroutine read_iasi(mype,val_iasi,ithin,isfcalc,rmesh,jsatid,gstime,& else temperature(bufr_chan) = tbmin endif - else - temperature(bufr_chan) = tbmin end if end do channel_loop diff --git a/src/gsi/read_prepbufr.f90 b/src/gsi/read_prepbufr.f90 index 32ec3e8836..e8d7ec756f 100644 --- a/src/gsi/read_prepbufr.f90 +++ b/src/gsi/read_prepbufr.f90 @@ -689,26 +689,20 @@ subroutine read_prepbufr(nread,ndata,nodata,infile,obstype,lunout,twindin,sis,& ! identify drifting buoys - TYP=180/280 T29=562 and last three digits of SID between 500 and 999 ! (see https://www.wmo.int/pages/prog/amp/mmop/wmo-number-rules.html) Set kx to 199/299 - ! Prevent integer overflow by nint - if(hdr(3) < huge_i_kind) then - if (id_drifter .and. (kx==180 .or. kx==280) .and. idnint(hdr(3))==562) then - rstation_id=hdr(4) - read(c_station_id,*,iostat=ios) iwmo - if (ios == 0 .and. iwmo > 0) then - if(mod(iwmo,1000) >=500) then - kx = kx + 19 - end if + if (id_drifter .and. (kx==180 .or. kx==280) .and. nint(hdr(3),r_double)==562) then + rstation_id=hdr(4) + read(c_station_id,*,iostat=ios) iwmo + if (ios == 0 .and. iwmo > 0) then + if(mod(iwmo,1000) >=500) then + kx = kx + 19 end if end if end if - !Prevent integer overflow by nint - if(hdr(3) < huge_i_kind) then - if (id_ship .and. (kx==180) .and. (idnint(hdr(3))==522 .or. idnint(hdr(3))==523)) then - rstation_id=hdr(4) - kx = kx + 18 - end if - endif + if (id_ship .and. (kx==180) .and. (nint(hdr(3),r_double)==522 .or. nint(hdr(3),r_double)==523)) then + rstation_id=hdr(4) + kx = kx + 18 + end if if(twodvar_regional)then ! If running in 2d-var (surface analysis) mode, check to see if observation @@ -974,26 +968,20 @@ subroutine read_prepbufr(nread,ndata,nodata,infile,obstype,lunout,twindin,sis,& ! ! identify drifting buoys - TYP=180/280 T29=562 and last three digits of SID between 500 and 999 ! (see https://www.wmo.int/pages/prog/amp/mmop/wmo-number-rules.html) Set kx to 199/299 - !Prevent integer overflow by nint - if(hdr(8) < huge_i_kind) then - if (id_drifter .and. (kx==180 .or. kx==280) .and. idnint(hdr(8))==562 ) then - rstation_id=hdr(1) - read(c_station_id,*,iostat=ios) iwmo - if (ios == 0 .and. iwmo > 0) then - if(mod(iwmo,1000) >=500) then - kx = kx + 19 - end if + if (id_drifter .and. (kx==180 .or. kx==280) .and. nint(hdr(8),r_double)==562) then + rstation_id=hdr(1) + read(c_station_id,*,iostat=ios) iwmo + if (ios == 0 .and. iwmo > 0) then + if(mod(iwmo,1000) >=500) then + kx = kx + 19 end if end if - endif + end if - !Prevent integer overflow by nint - if(hdr(8) < huge_i_kind) then - if (id_ship .and. (kx==180) .and. (idnint(hdr(8))==522 .or. idnint(hdr(8))==523) ) then - rstation_id=hdr(1) - kx = kx + 18 - end if - endif + if (id_ship .and. (kx==180) .and. (nint(hdr(8),r_double)==522 .or. nint(hdr(8),r_double)==523) ) then + rstation_id=hdr(1) + kx = kx + 18 + end if ! ! check VAD subtype. 1--old, 2--new, other--old @@ -1650,8 +1638,8 @@ subroutine read_prepbufr(nread,ndata,nodata,infile,obstype,lunout,twindin,sis,& qcmark(3,k)=min(tobaux(2,k,j),qcmark_huge) tqm(k)=idnint(qcmark(3,k)) exit - endif - endif + end if + end if if (tpc(k,j)==vtcd) then obsdat(3,k)=tobaux(1,k,j+1) qcmark(3,k)=min(tobaux(2,k,j+1),qcmark_huge) @@ -2143,23 +2131,20 @@ subroutine read_prepbufr(nread,ndata,nodata,infile,obstype,lunout,twindin,sis,& oelev=windsensht+selev !windsensht: read in from prepbufr else oelev=r10+selev - endif + end if if (kx == 280 )then - !Prevent integer overflow by nint - if(hdr(8) < huge_i_kind) then - it29=idnint(hdr(8)) - if(it29 == 522 .or. it29 == 523 .or. it29 == 531)then + it29=nint(hdr(8),r_double) + if(it29 == 522 .or. it29 == 523 .or. it29 == 531)then ! oelev=r20+selev - oelev=r20 - end if + oelev=r20 end if - endif + end if if (kx == 282) oelev=r20+selev if (kx == 285 .or. kx == 289 .or. kx == 290) then oelev=selev selev=zero - endif + end if else if((kx >= 221 .and. kx <= 229) & .and. selev >= oelev) oelev=r10+selev diff --git a/src/gsi/setupaod.f90 b/src/gsi/setupaod.f90 index 5a67b1e034..f01fb3398c 100644 --- a/src/gsi/setupaod.f90 +++ b/src/gsi/setupaod.f90 @@ -827,7 +827,7 @@ subroutine contents_netcdf_diag_ ! subroutine to write contents to netcdf diag files ! original: pagowski ! modified: 2019-03-21 - martin - cleaned up to fit GSI coding norms - use screen_to_ncdiag + use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata implicit none character(7),parameter :: obsclass = ' aod' character(128) :: fieldname diff --git a/src/gsi/setupdbz.f90 b/src/gsi/setupdbz.f90 index 3e97d031d4..8e26abd579 100644 --- a/src/gsi/setupdbz.f90 +++ b/src/gsi/setupdbz.f90 @@ -1921,7 +1921,7 @@ subroutine contents_binary_dirZDA_diag_(odiag) end subroutine contents_binary_dirZDA_diag_ subroutine contents_netcdf_diag_(odiag) use constants, only: r_missing - use screen_to_ncdiag + use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' dbz' diff --git a/src/gsi/setupdw.f90 b/src/gsi/setupdw.f90 index c1fa133c57..19ad49a27e 100644 --- a/src/gsi/setupdw.f90 +++ b/src/gsi/setupdw.f90 @@ -896,7 +896,7 @@ subroutine contents_binary_diag_(odiag) end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_(odiag) use constants, only: r_missing - use screen_to_ncdiag + use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' dw' diff --git a/src/gsi/setuplight.f90 b/src/gsi/setuplight.f90 index ffbba3af8f..f80f317474 100644 --- a/src/gsi/setuplight.f90 +++ b/src/gsi/setuplight.f90 @@ -1615,7 +1615,7 @@ end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_(odiag) ! Observation class use constants, only: r_missing - use screen_to_ncdiag + use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata type(obs_diag),pointer,intent(in):: odiag character(7),parameter :: obsclass = ' light' real(r_single),parameter:: missing = -9.99e9_r_single diff --git a/src/gsi/setuplwcp.f90 b/src/gsi/setuplwcp.f90 index 21e6f5e2ff..275105011c 100644 --- a/src/gsi/setuplwcp.f90 +++ b/src/gsi/setuplwcp.f90 @@ -838,7 +838,7 @@ end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_(odiag) use constants, only: r_missing - use screen_to_ncdiag + use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' lwcp' diff --git a/src/gsi/setupoz.f90 b/src/gsi/setupoz.f90 index caaeaa22aa..a5784647a9 100644 --- a/src/gsi/setupoz.f90 +++ b/src/gsi/setupoz.f90 @@ -152,7 +152,7 @@ subroutine setupozlay(obsLL,odiagLL,lunin,mype,stats_oz,nlevs,nreal,nobs,& use m_dtime, only: dtime_setup, dtime_check use gsi_bundlemod, only : gsi_bundlegetpointer use gsi_metguess_mod, only : gsi_metguess_get,gsi_metguess_bundle - use screen_to_ncdiag + use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata implicit none ! !INPUT PARAMETERS: @@ -1662,7 +1662,7 @@ subroutine contents_binary_diag_(odiag) end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_(odiag) use constants, only: r_missing - use screen_to_ncdiag + use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' ozlev' diff --git a/src/gsi/setupps.f90 b/src/gsi/setupps.f90 index 35a1669fec..802a6566b9 100644 --- a/src/gsi/setupps.f90 +++ b/src/gsi/setupps.f90 @@ -882,7 +882,7 @@ subroutine contents_binary_diag_(odiag) end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_(odiag) - use screen_to_ncdiag + use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' ps' diff --git a/src/gsi/setuppw.f90 b/src/gsi/setuppw.f90 index 801d7768b8..fe2de99522 100644 --- a/src/gsi/setuppw.f90 +++ b/src/gsi/setuppw.f90 @@ -711,7 +711,7 @@ subroutine contents_binary_diag_(odiag) end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_(odiag) use constants, only: r_missing - use screen_to_ncdiag + use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata type(obs_diag),pointer,intent(in):: odiag ! Observation class ! use model surface pressure, so PW can be used in EnKF analysis diff --git a/src/gsi/setupq.f90 b/src/gsi/setupq.f90 index ec8704ff9b..9e82a43ac2 100644 --- a/src/gsi/setupq.f90 +++ b/src/gsi/setupq.f90 @@ -1262,7 +1262,7 @@ end subroutine contents_binary_diagp_ subroutine contents_netcdf_diag_(odiag) use constants, only: r_missing - use screen_to_ncdiag + use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' q' @@ -1336,7 +1336,7 @@ end subroutine contents_netcdf_diag_ subroutine contents_netcdf_diagp_(odiag) use constants, only: r_missing - use screen_to_ncdiag + use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' q' diff --git a/src/gsi/setuprad.f90 b/src/gsi/setuprad.f90 index edbe9d6878..f6c1994271 100644 --- a/src/gsi/setuprad.f90 +++ b/src/gsi/setuprad.f90 @@ -2543,7 +2543,7 @@ subroutine contents_binary_diag_(odiags,idv,iob) end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_(odiags,idv,iob) - use screen_to_ncdiag + use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata type(fptr_obsdiagNode),dimension(:),intent(in):: odiags integer(i_kind),intent(in):: idv,iob diff --git a/src/gsi/setuprw.f90 b/src/gsi/setuprw.f90 index 882c1f8081..11788491f1 100644 --- a/src/gsi/setuprw.f90 +++ b/src/gsi/setuprw.f90 @@ -1312,7 +1312,7 @@ subroutine contents_binary_diag_(odiag) end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_(odiag) use constants, only: r_missing - use screen_to_ncdiag + use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' rw' diff --git a/src/gsi/setupspd.f90 b/src/gsi/setupspd.f90 index 8ccbeb8cad..f4efa4b28f 100644 --- a/src/gsi/setupspd.f90 +++ b/src/gsi/setupspd.f90 @@ -942,7 +942,7 @@ subroutine contents_binary_diag_(odiag) end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_(odiag) use constants, only: r_missing - use screen_to_ncdiag + use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' spd' diff --git a/src/gsi/setupsst.f90 b/src/gsi/setupsst.f90 index 31ed0c8458..cce6023c3b 100644 --- a/src/gsi/setupsst.f90 +++ b/src/gsi/setupsst.f90 @@ -576,7 +576,7 @@ subroutine contents_binary_diag_(odiag) endif end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_(odiag) - use screen_to_ncdiag + use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' sst' diff --git a/src/gsi/setupswcp.f90 b/src/gsi/setupswcp.f90 index d0a745a914..5e94f35dc4 100644 --- a/src/gsi/setupswcp.f90 +++ b/src/gsi/setupswcp.f90 @@ -883,7 +883,7 @@ end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_(odiag) use constants, only: r_missing - use screen_to_ncdiag + use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' swcp' diff --git a/src/gsi/setupt.f90 b/src/gsi/setupt.f90 index 3a37515007..bb6dfcf569 100644 --- a/src/gsi/setupt.f90 +++ b/src/gsi/setupt.f90 @@ -1663,7 +1663,7 @@ subroutine contents_binary_diagp_(odiag) end subroutine contents_binary_diagp_ subroutine contents_netcdf_diag_(odiag) - use screen_to_ncdiag + use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' t' @@ -1760,7 +1760,7 @@ subroutine contents_netcdf_diag_(odiag) end subroutine contents_netcdf_diag_ subroutine contents_netcdf_diagp_(odiag) - use screen_to_ncdiag + use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' t' diff --git a/src/gsi/setuptcp.f90 b/src/gsi/setuptcp.f90 index ff9d1017e1..bdb79010bf 100644 --- a/src/gsi/setuptcp.f90 +++ b/src/gsi/setuptcp.f90 @@ -684,7 +684,7 @@ subroutine contents_binary_diag_(odiag) end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_(odiag) - use screen_to_ncdiag + use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata use constants, only: r_missing type(obs_diag),pointer,intent(in):: odiag ! Observation class diff --git a/src/gsi/setupw.f90 b/src/gsi/setupw.f90 index d3f0ea6a8b..e094981754 100644 --- a/src/gsi/setupw.f90 +++ b/src/gsi/setupw.f90 @@ -1780,7 +1780,7 @@ subroutine contents_binary_diag_(udiag,vdiag) end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_(udiag,vdiag) use constants, only: r_missing - use screen_to_ncdiag + use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata type(obs_diag),pointer,intent(in):: udiag,vdiag ! Observation class character(7),parameter :: obsclass = ' uv' From 8c2ead4438996a11ea770e1f5e630607284cc5f7 Mon Sep 17 00:00:00 2001 From: David Huber Date: Thu, 18 May 2023 23:21:23 -0500 Subject: [PATCH 06/44] Fixed out of bounds and vector assignment bugs #471 --- src/gsi/ensctl2state.f90 | 9 +++++++-- src/gsi/ensctl2state_ad.f90 | 9 +++++++-- src/gsi/stpcalc.f90 | 22 +++++++++++++++++----- 3 files changed, 31 insertions(+), 9 deletions(-) diff --git a/src/gsi/ensctl2state.f90 b/src/gsi/ensctl2state.f90 index 0d6d3042c5..bd72e12b76 100644 --- a/src/gsi/ensctl2state.f90 +++ b/src/gsi/ensctl2state.f90 @@ -240,7 +240,6 @@ subroutine ensctl2state(xhat,mval,eval) !$omp section ! Get pointers to required state variables - call gsi_bundlegetpointer (eval(jj),'oz' ,sv_oz , istatus) call gsi_bundlegetpointer (eval(jj),'sst' ,sv_sst, istatus) if(ls_w)then call gsi_bundlegetpointer (eval(jj),'w' ,sv_w, istatus) @@ -249,7 +248,6 @@ subroutine ensctl2state(xhat,mval,eval) end if end if ! Copy variables - call gsi_bundlegetvar ( wbundle_c, 'oz' , sv_oz, istatus ) call gsi_bundlegetvar ( wbundle_c, 'sst', sv_sst, istatus ) if(lc_w)then call gsi_bundlegetvar ( wbundle_c, 'w' , sv_w, istatus ) @@ -258,6 +256,13 @@ subroutine ensctl2state(xhat,mval,eval) end if end if +! Get the ozone vector if it is defined + id=getindex(cvars3d,"oz") + if(id > 0) then + call gsi_bundlegetpointer (eval(jj),'oz' ,sv_oz , istatus) + call gsi_bundlegetvar ( wbundle_c, 'oz' , sv_oz, istatus ) + endif + !$omp end parallel sections ! Add contribution from static B, if necessary diff --git a/src/gsi/ensctl2state_ad.f90 b/src/gsi/ensctl2state_ad.f90 index 4c038c8c6e..d350743998 100644 --- a/src/gsi/ensctl2state_ad.f90 +++ b/src/gsi/ensctl2state_ad.f90 @@ -206,9 +206,7 @@ subroutine ensctl2state_ad(eval,mval,grad) !$omp section - call gsi_bundlegetpointer (eval(jj),'oz' ,rv_oz , istatus) call gsi_bundlegetpointer (eval(jj),'sst' ,rv_sst, istatus) - call gsi_bundleputvar ( wbundle_c, 'oz', rv_oz, istatus ) call gsi_bundleputvar ( wbundle_c, 'sst', rv_sst, istatus ) if(wdw_exist)then call gsi_bundlegetpointer (eval(jj),'w' ,rv_w, istatus) @@ -219,6 +217,13 @@ subroutine ensctl2state_ad(eval,mval,grad) end if end if +! Get the ozone vector if it is defined + id=getindex(cvars3d,"oz") + if(id > 0) then + call gsi_bundlegetpointer (eval(jj),'oz' ,rv_oz , istatus) + call gsi_bundleputvar ( wbundle_c, 'oz', rv_oz, istatus ) + endif + !$omp section if (do_cw_to_hydro_ad .and. .not.do_cw_to_hydro_ad_hwrf) then diff --git a/src/gsi/stpcalc.f90 b/src/gsi/stpcalc.f90 index 2d79fd3e3b..40b51b9b49 100644 --- a/src/gsi/stpcalc.f90 +++ b/src/gsi/stpcalc.f90 @@ -263,7 +263,7 @@ subroutine stpcalc(stpinout,sval,sbias,dirx,dval,dbias, & real(r_quad),parameter:: one_tenth_quad = 0.1_r_quad ! Declare local variables - integer(i_kind) i,j,mm1,ii,iis,ibin,ipenloc,it + integer(i_kind) i,j,mm1,ii,iis,final_ii,ibin,ipenloc,it integer(i_kind) istp_use,nstep,nsteptot,kprt real(r_quad),dimension(4,ipen):: pbc real(r_quad),dimension(4,nobs_type):: pbcjo @@ -299,6 +299,7 @@ subroutine stpcalc(stpinout,sval,sbias,dirx,dval,dbias, & kprt=3 pjcalc=.false. pj=zero_quad + final_ii=1 ! Begin calculating contributions to penalty and stepsize for various terms ! @@ -779,11 +780,13 @@ subroutine stpcalc(stpinout,sval,sbias,dirx,dval,dbias, & write(iout_iter,*) ' early termination due to cx or stp <=0 ',cx,stp(ii) write(iout_iter,*) ' better stepsize found',cx,stp(ii) end if + final_ii=ii exit stepsize else if(ii == istp_iter)then write(iout_iter,*) ' early termination due to no decrease in penalty ',cx,stp(ii) stp(istp_use)=zero end_iter = .true. + final_ii=ii exit stepsize else ! Try different (better?) stepsize @@ -808,12 +811,16 @@ subroutine stpcalc(stpinout,sval,sbias,dirx,dval,dbias, & end_iter = .true. ! Finalize timer call timer_fnl('stpcalc') + final_ii=ii exit stepsize end if ! Check for convergence in stepsize estimation stprat(ii)=zero if(stp(ii) > zero_quad)stprat(ii)=abs((stp(ii)-stp(ii-1))/stp(ii)) - if(stprat(ii) < 1.e-4_r_kind) exit stepsize + if(stprat(ii) < 1.e-4_r_kind) then + final_ii=ii + exit stepsize + end if dels = one_tenth_quad*dels end if @@ -840,7 +847,10 @@ subroutine stpcalc(stpinout,sval,sbias,dirx,dval,dbias, & istp_use=i end if end do - if(istp_use /= istp_iter)exit stepsize + if(istp_use /= istp_iter) then + final_ii=ii + exit stepsize + end if ! If no best stepsize set to zero and end minimization if(mype == minmype)then write(iout_iter,141)(outpen(i),i=1,nsteptot) @@ -848,8 +858,10 @@ subroutine stpcalc(stpinout,sval,sbias,dirx,dval,dbias, & end_iter = .true. stp(ii)=zero_quad istp_use=ii + final_ii=ii exit stepsize end if + final_ii=ii end do stepsize if(kprt >= 2 .and. iter == 0)then call mpl_allreduce(ipen,nobs_bins,pj) @@ -880,7 +892,7 @@ subroutine stpcalc(stpinout,sval,sbias,dirx,dval,dbias, & if(print_verbose)then write(iout_iter,200) (stp(i),i=0,istp_use) - write(iout_iter,199) (stprat(ii),ii=1,istp_use) + write(iout_iter,199) (stprat(i),i=1,istp_use) write(iout_iter,201) (outstp(i),i=1,nsteptot) write(iout_iter,202) (outpen(i)-outpen(4),i=1,nsteptot) end if @@ -888,7 +900,7 @@ subroutine stpcalc(stpinout,sval,sbias,dirx,dval,dbias, & ! Check for final stepsize negative (probable error) if(stpinout <= zero)then if(mype == minmype)then - write(iout_iter,130) ii,bx,cx,stp(ii) + write(iout_iter,130) final_ii,bx,cx,stp(final_ii) write(iout_iter,105) (bsum(i),i=1,ipen) write(iout_iter,110) (csum(i),i=1,ipen) write(iout_iter,101) (pbc(1,i)-pen_est(i),i=1,ipen) From 6dca839ef7e4e391ee798afffc014e4c9b84187b Mon Sep 17 00:00:00 2001 From: David Huber Date: Fri, 19 May 2023 14:26:24 -0500 Subject: [PATCH 07/44] Decrease radar memory footprint. #471 --- src/gsi/read_radar.f90 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/gsi/read_radar.f90 b/src/gsi/read_radar.f90 index 8e5de5aff9..40c77a7ee2 100644 --- a/src/gsi/read_radar.f90 +++ b/src/gsi/read_radar.f90 @@ -341,7 +341,7 @@ subroutine read_radar(nread,ndata,nodata,infile,lunout,obstype,twind,sis,hgtl_fu if (.not.lexist1 .and. .not.lexist2 .and. .not.lexist3) return eradkm=rearth*0.001_r_kind - maxobs=2e8 + maxobs=4e6 nreal=maxdat nchanl=0 ilon=2 From aa4297135f27cefba3e28b9702f8e3189cc3f7e5 Mon Sep 17 00:00:00 2001 From: David Huber Date: Fri, 19 May 2023 14:36:42 -0500 Subject: [PATCH 08/44] Removed duplicate call to read_hdraob #471 --- src/gsi/read_obs.F90 | 4 ---- 1 file changed, 4 deletions(-) diff --git a/src/gsi/read_obs.F90 b/src/gsi/read_obs.F90 index 9017c498c2..70dff8f84a 100644 --- a/src/gsi/read_obs.F90 +++ b/src/gsi/read_obs.F90 @@ -1513,10 +1513,6 @@ subroutine read_obs(ndata,mype) call read_fl_hdob(nread,npuse,nouse,infile,obstype,lunout,gstime,twind,sis,& prsl_full,nobs_sub1(1,i)) string='READ_FL_HDOB' - else if (index(infile,'uprair') /=0)then - call read_hdraob(nread,npuse,nouse,infile,obstype,lunout,twind,sis,& - prsl_full,hgtl_full,nobs_sub1(1,i),read_rec(i)) - string='READ_UPRAIR' else call read_prepbufr(nread,npuse,nouse,infile,obstype,lunout,twind,sis,& prsl_full,nobs_sub1(1,i),read_rec(i)) From 6383ae7cc3523d0b8816cbc2f2b1eaecf2a1c416 Mon Sep 17 00:00:00 2001 From: "[David Huber]" <[david.huber@noaa.gov]> Date: Fri, 26 May 2023 13:05:50 +0000 Subject: [PATCH 09/44] Fix out of bounds error, trim system calls, optimize do loop #447 --- src/enkf/observer_gfs.f90 | 18 +++++++++--------- src/gsi/mpeu_util.F90 | 16 ---------------- src/gsi/obsmod.F90 | 12 ++++++++++++ src/gsi/read_iasi.f90 | 2 ++ 4 files changed, 23 insertions(+), 25 deletions(-) diff --git a/src/enkf/observer_gfs.f90 b/src/enkf/observer_gfs.f90 index 1f2774f6f1..07e4f58457 100644 --- a/src/enkf/observer_gfs.f90 +++ b/src/enkf/observer_gfs.f90 @@ -76,6 +76,7 @@ subroutine setup_linhx(rlat, rlon, time, ix, delx, ixp, delxp, iy, dely, & real(r_single) ,intent(in ) :: time ! observation time relative to middle of window integer(i_kind), intent(out) :: ix, iy, it, ixp, iyp, itp real(r_kind), intent(out) :: delx, dely, delxp, delyp, delt, deltp + integer(i_kind) :: ixnlons ! find interplation indices and deltas @@ -87,22 +88,21 @@ subroutine setup_linhx(rlat, rlon, time, ix, delx, ixp, delxp, iy, dely, & ix = min(ix, nlats-1) ixp = max(ix-1, 0) + ixnlons = ix*nlons + if (ixp /= ix) then - delx = (rlat - latsgrd(ix*nlons+1)) / (latsgrd(ixp*nlons + 1) - latsgrd(ix*nlons+1)) + delx = (rlat - latsgrd(ixnlons+1)) / (latsgrd(ixp*nlons + 1) - latsgrd(ixnlons+1)) else delx = one endif delx = max(zero,min(delx,one)) - iyp = 1 - do - if (iyp > nlons .or. ix*nlons + iyp > npts) then - exit - elseif(lonsgrd(ix*nlons + iyp) > rlon) then - exit - endif - iyp = iyp + 1 + iyp=1 + do while(iyp <= nlons .and. ixnlons+iyp <= npts) + if (lonsgrd(ixnlons+iyp) > rlon) exit + iyp = iyp + 1 enddo + iy = iyp - 1 if(iy < 1) iy = iy + nlons if(iyp > nlons) iyp = iyp - nlons diff --git a/src/gsi/mpeu_util.F90 b/src/gsi/mpeu_util.F90 index 960af8b71a..76271a4770 100644 --- a/src/gsi/mpeu_util.F90 +++ b/src/gsi/mpeu_util.F90 @@ -553,22 +553,6 @@ subroutine close_if_(fname,stat) endif end subroutine close_if_ -#ifdef _NEW_CODE_ -!! need to send outputs to variables. -!! need to set return code (stat=). -subroutine ls_(files) ! show information? or just inquire(exists(file)) - call system("ls "//files) -end subroutine ls_ -subroutine rm_(files) ! delete, open();close(status='delete') - call system("rm "//files) -end subroutine rm_ -subroutine mkdir_(dir,mode,parents) - call system("mkdir "//files) -end subroutine mkdir_ -subroutine size_(file) ! faster access? - call system("wc -c "//files) -end subroutine size_ -#endif #endif function myid_(who) diff --git a/src/gsi/obsmod.F90 b/src/gsi/obsmod.F90 index bb317d0752..0bd3983fa2 100644 --- a/src/gsi/obsmod.F90 +++ b/src/gsi/obsmod.F90 @@ -1005,9 +1005,13 @@ subroutine init_directories(mype) ! machine: ibm rs/6000 sp ! !$$$ end documentation block +#ifdef __INTEL_COMPILER + use IFPORT +#endif implicit none integer(i_kind),intent(in ) :: mype + logical :: l_mkdir_stat character(len=144):: command character(len=8):: pe_name @@ -1016,7 +1020,15 @@ subroutine init_directories(mype) write(pe_name,'(i4.4)') mype dirname = 'dir.'//trim(pe_name)//'/' command = 'mkdir -p -m 755 ' // trim(dirname) +#ifdef __INTEL_COMPILER + l_mkdir_stat = MAKEDIRQQ(trim(dirname)) + if(.not. l_mkdir_stat) then + write(6, *) "Failed to create directory ", trim(dirname), " for PE ", pe_name + call stop2(678) + endif +#else call system(command) +#endif else write(pe_name,100) mype 100 format('pe',i4.4,'.') diff --git a/src/gsi/read_iasi.f90 b/src/gsi/read_iasi.f90 index c3cefe099a..02bc504a9c 100644 --- a/src/gsi/read_iasi.f90 +++ b/src/gsi/read_iasi.f90 @@ -826,6 +826,8 @@ subroutine read_iasi(mype,val_iasi,ithin,isfcalc,rmesh,jsatid,gstime,& ! Put satinfo defined channel temperatures into data array do l=1,satinfo_nchan + ! Prevent out of bounds reference from temperature + if ( bufr_index(l) == 0 ) cycle i = bufr_index(l) data_all(l+nreal,itx) = temperature(i) ! brightness temerature end do From 59b9e26dce98bf73fb9bf9adfa8d1ce56931e5ad Mon Sep 17 00:00:00 2001 From: David Huber Date: Fri, 26 May 2023 16:30:03 -0500 Subject: [PATCH 10/44] Revert to Fortran-created directories. Move metadata screening to ncdiag library #447 Note: the ncdiag library is currently built in local directories until testing is complete. --- modulefiles/gsi_common.lua | 6 +- regression/regression_namelists.sh | 14 +-- src/gsi/genstats_gps.f90 | 51 ++++----- src/gsi/gsi_files.cmake | 1 - src/gsi/screen_to_ncdiag.f90 | 30 ------ src/gsi/setupaod.f90 | 14 +-- src/gsi/setupdbz.f90 | 46 ++++----- src/gsi/setupdw.f90 | 42 +++----- src/gsi/setuplight.f90 | 38 +++---- src/gsi/setuplwcp.f90 | 48 ++++----- src/gsi/setupoz.f90 | 61 +++++------ src/gsi/setupps.f90 | 64 ++++-------- src/gsi/setuppw.f90 | 42 +++----- src/gsi/setupq.f90 | 98 ++++++++---------- src/gsi/setuprad.f90 | 160 +++++++++++++---------------- src/gsi/setuprw.f90 | 54 ++++------ src/gsi/setupspd.f90 | 46 ++++----- src/gsi/setupsst.f90 | 51 ++++----- src/gsi/setupswcp.f90 | 44 +++----- src/gsi/setupt.f90 | 94 +++++++---------- src/gsi/setuptcp.f90 | 46 +++------ src/gsi/setupw.f90 | 78 +++++--------- 22 files changed, 447 insertions(+), 681 deletions(-) delete mode 100644 src/gsi/screen_to_ncdiag.f90 diff --git a/modulefiles/gsi_common.lua b/modulefiles/gsi_common.lua index 58a9ece619..0dda5ce333 100644 --- a/modulefiles/gsi_common.lua +++ b/modulefiles/gsi_common.lua @@ -32,5 +32,9 @@ load(pathJoin("nemsio", nemsio_ver)) load(pathJoin("wrf_io", wrf_io_ver)) load(pathJoin("ncio", ncio_ver)) load(pathJoin("crtm", crtm_ver)) -load(pathJoin("ncdiag",ncdiag_ver)) +--load(pathJoin("ncdiag",ncdiag_ver)) +setenv("ncdiag_ROOT", "/work2/noaa/nesdis-rdo2/dhuber/GSI/ncdiag/1.0.1") +setenv("ncdiag_VERSION", "1.0.1") + +prepend_path("PATH", pathJoin("/work2/noaa/nesdis-rdo2/dhuber/GSI/ncdiag/1.0.1/","bin")) diff --git a/regression/regression_namelists.sh b/regression/regression_namelists.sh index 2463856499..824c6f0719 100755 --- a/regression/regression_namelists.sh +++ b/regression/regression_namelists.sh @@ -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=.false., + use_gfs_nemsio=.false.,lrun_subdirs=.true., use_readin_anl_sfcmask=.true., crtm_coeffs_path='./crtm_coeffs/', newpc4pred=.true.,adp_anglebc=.true.,angord=4,passive_bc=.true.,use_edges=.false., @@ -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=.false.,use_gfs_ncio=.true., + use_gfs_nemsio=.false.,lrun_subdirs=.true.,use_gfs_ncio=.true., $SETUP / &GRIDOPTS @@ -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=.false., + nhr_assimilation=6,lrun_subdirs=.true., $SETUP / &GRIDOPTS @@ -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=.false., + use_gfs_nemsio=.false.,lrun_subdirs=.true., use_readin_anl_sfcmask=.true., crtm_coeffs_path='./crtm_coeffs/', newpc4pred=.true.,adp_anglebc=.true.,angord=4,passive_bc=.true.,use_edges=.false., @@ -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=.false.,use_readin_anl_sfcmask=.true., + use_gfs_nemsio=.false.,lrun_subdirs=.true.,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, @@ -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=.false., + nhr_assimilation=6,min_offset=180,use_compress=.false.,lrun_subdirs=.true., use_similarity_2dvar=.true., neutral_stability_windfact_2dvar=.false., use_prepb_satwnd=.false., @@ -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=.false., + lrun_subdirs=.true., $SETUP / &GRIDOPTS diff --git a/src/gsi/genstats_gps.f90 b/src/gsi/genstats_gps.f90 index 20ba5de79b..acf5ca2756 100644 --- a/src/gsi/genstats_gps.f90 +++ b/src/gsi/genstats_gps.f90 @@ -250,7 +250,7 @@ subroutine genstats_gps(bwork,awork,toss_gps_sub,conv_diagsave,mype) use obsmod, only: lobsdiagsave,luse_obsdiag use obsmod, only: binary_diag,netcdf_diag,dirname,ianldate use nc_diag_write_mod, only: nc_diag_init, nc_diag_header, nc_diag_metadata, & - nc_diag_write, nc_diag_data2d + nc_diag_write, nc_diag_data2d, nc_diag_metadata_to_single use nc_diag_read_mod, only: nc_diag_read_init, nc_diag_read_get_dim, nc_diag_read_close use gridmod, only: nsig,regional use constants, only: tiny_r_kind,half,wgtlim,one,two,zero,five,four @@ -753,8 +753,6 @@ end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_ use sparsearr, only: sparr2, readarray, fullarray - use constants, only: r_missing - use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata integer(i_kind),dimension(miter) :: obsdiag_iuse integer(i_kind) :: obstype, obssubtype type(sparr2) :: dhx_dx @@ -768,32 +766,27 @@ subroutine contents_netcdf_diag_ obssubtype = gps_allptr%rdiag(2) call nc_diag_metadata("Observation_Type", obstype ) call nc_diag_metadata("Observation_Subtype", obssubtype ) - 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)) ) - if(isnan(gps_allptr%rdiag(17)) .or. isnan(gps_allptr%rdiag(5))) then - 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)) ) + call nc_diag_metadata_to_single("Latitude", gps_allptr%rdiag(3) ) + call nc_diag_metadata_to_single("Longitude", gps_allptr%rdiag(4) ) + call nc_diag_metadata_to_single("Incremental_Bending_Angle", gps_allptr%rdiag(5) ) + call nc_diag_metadata_to_single("Pressure", gps_allptr%rdiag(6) ) + call nc_diag_metadata_to_single("Height", gps_allptr%rdiag(7) ) + call nc_diag_metadata_to_single("Time", gps_allptr%rdiag(8) ) + call nc_diag_metadata_to_single("Model_Elevation", gps_allptr%rdiag(9) ) + call nc_diag_metadata_to_single("Setup_QC_Mark", gps_allptr%rdiag(10) ) + call nc_diag_metadata_to_single("Prep_Use_Flag", gps_allptr%rdiag(11) ) + call nc_diag_metadata_to_single("Analysis_Use_Flag", gps_allptr%rdiag(12) ) + + call nc_diag_metadata_to_single("Nonlinear_QC_Rel_Wgt", gps_allptr%rdiag(13) ) + call nc_diag_metadata_to_single("Errinv_Input", gps_allptr%rdiag(14) ) + call nc_diag_metadata_to_single("Errinv_Adjust", gps_allptr%rdiag(15) ) + call nc_diag_metadata_to_single("Errinv_Final", gps_allptr%rdiag(16) ) + call nc_diag_metadata_to_single("Observation", gps_allptr%rdiag(17) ) + call nc_diag_metadata_to_single("Obs_Minus_Forecast_adjusted", gps_allptr%rdiag(17),gps_allptr%rdiag(5),"*") + call nc_diag_metadata_to_single("Obs_Minus_Forecast_unadjusted",gps_allptr%rdiag(17),gps_allptr%rdiag(5),"*") + call nc_diag_metadata_to_single("GPS_Type", gps_allptr%rdiag(20) ) + call nc_diag_metadata_to_single("Temperature_at_Obs_Location", gps_allptr%rdiag(18) ) + call nc_diag_metadata_to_single("Specific_Humidity_at_Obs_Location",gps_allptr%rdiag(21) ) if (save_jacobian) then call readarray(dhx_dx, gps_allptr%rdiag(ioff+1:nreal)) diff --git a/src/gsi/gsi_files.cmake b/src/gsi/gsi_files.cmake index f7ce7734d8..b98cd2d0da 100644 --- a/src/gsi/gsi_files.cmake +++ b/src/gsi/gsi_files.cmake @@ -522,7 +522,6 @@ rsearch.F90 rtlnmc_version3.f90 rtma_comp_fact10.f90 satthin.F90 -screen_to_ncdiag.f90 set_crtm_aerosolmod.f90 set_crtm_cloudmod.f90 setupaod.f90 diff --git a/src/gsi/screen_to_ncdiag.f90 b/src/gsi/screen_to_ncdiag.f90 deleted file mode 100644 index ae5e037e40..0000000000 --- a/src/gsi/screen_to_ncdiag.f90 +++ /dev/null @@ -1,30 +0,0 @@ -module screen_to_ncdiag - implicit none - private - public:: screen_to_single_nc_diag_metadata - - !Provides a subroutine to screen quantities for NaNs before converting doubles - !to singles and sending them to nc_diag_metadata. This prevents floating - !invalids. - - contains - - subroutine screen_to_single_nc_diag_metadata(vname, var) - use constants, only: r_missing - use kinds, only: r_double, r_kind - use nc_diag_write_mod, only: nc_diag_metadata - - !Screens double variables to be sent to nc_diag_metadata by checking for NaNs first - !to prevent floating invalids (which are reported as 0) - character(len=*), intent(in) :: vname - real (r_double), intent(in) :: var - - if(isnan(var)) then - call nc_diag_metadata(vname, sngl(real(r_missing))) - else - call nc_diag_metadata(vname, sngl(var)) - endif - - endsubroutine screen_to_single_nc_diag_metadata - -endmodule screen_to_ncdiag diff --git a/src/gsi/setupaod.f90 b/src/gsi/setupaod.f90 index f01fb3398c..5fe4233ada 100644 --- a/src/gsi/setupaod.f90 +++ b/src/gsi/setupaod.f90 @@ -61,7 +61,8 @@ subroutine setupaod(obsLL,odiagLL,lunin,mype,nchanl,nreal,nobs,& dplat,lobsdiagsave,lobsdiag_allocated,& dirname,time_offset,luse_obsdiag use nc_diag_write_mod, only: nc_diag_init, nc_diag_header, nc_diag_metadata, & - nc_diag_write, nc_diag_data2d, nc_diag_chaninfo_dim_set, nc_diag_chaninfo + nc_diag_write, nc_diag_data2d, nc_diag_chaninfo_dim_set, nc_diag_chaninfo, & + nc_diag_metadata_to_single use nc_diag_read_mod, only: nc_diag_read_init, nc_diag_read_get_dim, nc_diag_read_close use gsi_4dvar, only: nobs_bins,hr_obsbin use gridmod, only: nsig,get_ij @@ -827,7 +828,6 @@ subroutine contents_netcdf_diag_ ! subroutine to write contents to netcdf diag files ! original: pagowski ! modified: 2019-03-21 - martin - cleaned up to fit GSI coding norms - use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata implicit none character(7),parameter :: obsclass = ' aod' character(128) :: fieldname @@ -842,11 +842,11 @@ subroutine contents_netcdf_diag_ if ( iuse_aero(l) < 0 ) cycle call nc_diag_metadata("Channel_Index", i) call nc_diag_metadata("Observation_Class", obsclass) - call screen_to_single_nc_diag_metadata("Latitude",(cenlat)) ! observation latitude (degrees) - call screen_to_single_nc_diag_metadata("Longitude",(cenlon)) ! observation longitude (degrees) - call screen_to_single_nc_diag_metadata("Obs_Time",(dtime))!-time_offset)) ! observation time (hours relative to analysis time) - call screen_to_single_nc_diag_metadata("Sol_Zenith_Angle",(pangs)) ! solar zenith angle (degrees) - call screen_to_single_nc_diag_metadata("Sol_Azimuth_Angle",(data_s(isazi_ang,n))) ! solar azimuth angle (degrees) + call nc_diag_metadata_to_single("Latitude",(cenlat)) ! observation latitude (degrees) + call nc_diag_metadata_to_single("Longitude",(cenlon)) ! observation longitude (degrees) + call nc_diag_metadata_to_single("Obs_Time",(dtime))!-time_offset)) ! observation time (hours relative to analysis time) + call nc_diag_metadata_to_single("Sol_Zenith_Angle",(pangs)) ! solar zenith angle (degrees) + call nc_diag_metadata_to_single("Sol_Azimuth_Angle",(data_s(isazi_ang,n))) ! solar azimuth angle (degrees) call nc_diag_metadata("Surface_type", nint(data_s(istyp,n))) call nc_diag_metadata("MODIS_deep_blue_flag", nint(dbcf) ) call nc_diag_metadata("Observation",(diagbufchan(1,i)) ) ! observed aod diff --git a/src/gsi/setupdbz.f90 b/src/gsi/setupdbz.f90 index 8e26abd579..068842cd6b 100644 --- a/src/gsi/setupdbz.f90 +++ b/src/gsi/setupdbz.f90 @@ -131,7 +131,7 @@ subroutine setupdbz(obsLL,odiagLL,lunin,mype,bwork,awork,nele,nobs,is,radardbz_d use obsmod, only: luse_obsdiag, netcdf_diag, binary_diag, dirname, ianldate use obsmod, only: doradaroneob,oneobddiff,oneobvalue use nc_diag_write_mod, only: nc_diag_init, nc_diag_header, nc_diag_metadata, & - nc_diag_write, nc_diag_data2d + nc_diag_write, nc_diag_data2d, nc_diag_metadata_to_single use nc_diag_read_mod, only: nc_diag_read_init, nc_diag_read_get_dim,nc_diag_read_close use oneobmod, only: oneobtest use oneobmod, only: maginnov @@ -1920,8 +1920,6 @@ subroutine contents_binary_dirZDA_diag_(odiag) end subroutine contents_binary_dirZDA_diag_ subroutine contents_netcdf_diag_(odiag) - use constants, only: r_missing - use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' dbz' @@ -1930,37 +1928,29 @@ subroutine contents_netcdf_diag_(odiag) call nc_diag_metadata("Observation_Class", obsclass ) call nc_diag_metadata("Observation_Type", ictype(ikx) ) call nc_diag_metadata("Observation_Subtype", icsubtype(ikx) ) - call screen_to_single_nc_diag_metadata("Latitude",(data(ilate,i)) ) - call screen_to_single_nc_diag_metadata("Longitude",(data(ilone,i)) ) - call screen_to_single_nc_diag_metadata("Station_Elevation",(data(ielev,i)) ) - call screen_to_single_nc_diag_metadata("Pressure",(presw) ) - call screen_to_single_nc_diag_metadata("Height",(data(ihgt,i)) ) - if(isnan(dtime) .or. isnan(time_offset)) then - call nc_diag_metadata("Time",sngl(real(r_missing))) - else - call nc_diag_metadata("Time",sngl(dtime-time_offset)) - endif - call screen_to_single_nc_diag_metadata("Prep_QC_Mark",(zero) ) - call screen_to_single_nc_diag_metadata("Prep_Use_Flag",(data(iuse,i)) ) + call nc_diag_metadata_to_single("Latitude", data(ilate,i) ) + call nc_diag_metadata_to_single("Longitude", data(ilone,i) ) + call nc_diag_metadata_to_single("Station_Elevation",data(ielev,i) ) + call nc_diag_metadata_to_single("Pressure", presw ) + call nc_diag_metadata_to_single("Height", data(ihgt,i) ) + call nc_diag_metadata_to_single("Time", dtime, time_offset, "-") + call nc_diag_metadata_to_single("Prep_QC_Mark", zero ) + call nc_diag_metadata_to_single("Prep_Use_Flag", data(iuse,i) ) ! call nc_diag_metadata("Nonlinear_QC_Var_Jb", var_jb ! ) - call screen_to_single_nc_diag_metadata("Nonlinear_QC_Rel_Wgt",(rwgt) ) + call nc_diag_metadata_to_single("Nonlinear_QC_Rel_Wgt",rwgt ) if(muse(i)) then - call nc_diag_metadata("Analysis_Use_Flag", sngl(one) ) + call nc_diag_metadata_to_single("Analysis_Use_Flag",one ) else - call nc_diag_metadata("Analysis_Use_Flag", sngl(-one) ) + call nc_diag_metadata_to_single("Analysis_Use_Flag",-one ) endif - call screen_to_single_nc_diag_metadata("Errinv_Input",(errinv_input) ) - call screen_to_single_nc_diag_metadata("Errinv_Adjust",(errinv_adjst) ) - call screen_to_single_nc_diag_metadata("Errinv_Final",(errinv_final) ) + call nc_diag_metadata_to_single("Errinv_Input", errinv_input ) + call nc_diag_metadata_to_single("Errinv_Adjust", errinv_adjst ) + call nc_diag_metadata_to_single("Errinv_Final", errinv_final ) - call screen_to_single_nc_diag_metadata("Observation",(data(idbzob,i)) ) - call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_adjusted",(ddiff) ) - if(isnan(data(idbzob,i)) .or. isnan(rdBZ)) then - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(real(r_missing))) - else - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(data(idbzob,i)-rdBZ) ) - endif + call nc_diag_metadata_to_single("Observation", data(idbzob,i) ) + call nc_diag_metadata_to_single("Obs_Minus_Forecast_adjusted",ddiff ) + call nc_diag_metadata_to_single("Obs_Minus_Forecast_unadjusted", data(idbzob,i), rdBZ, "-") if (lobsdiagsave) then do jj=1,miter diff --git a/src/gsi/setupdw.f90 b/src/gsi/setupdw.f90 index 19ad49a27e..63c0df4b19 100644 --- a/src/gsi/setupdw.f90 +++ b/src/gsi/setupdw.f90 @@ -37,7 +37,7 @@ subroutine setupdw(obsLL,odiagLL,lunin,mype,bwork,awork,nele,nobs,is,conv_diagsa use obsmod, only: rmiss_single,lobsdiag_forenkf use obsmod, only: netcdf_diag, binary_diag, dirname, ianldate use nc_diag_write_mod, only: nc_diag_init, nc_diag_header, nc_diag_metadata, & - nc_diag_write, nc_diag_data2d + nc_diag_write, nc_diag_data2d, nc_diag_metadata_to_single use nc_diag_read_mod, only: nc_diag_read_init, nc_diag_read_get_dim, nc_diag_read_close use m_obsdiagNode, only: obs_diag use m_obsdiagNode, only: obs_diags @@ -895,8 +895,6 @@ subroutine contents_binary_diag_(odiag) end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_(odiag) - use constants, only: r_missing - use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' dw' @@ -906,37 +904,29 @@ subroutine contents_netcdf_diag_(odiag) call nc_diag_metadata("Observation_Class", obsclass ) call nc_diag_metadata("Observation_Type", ictype(ikx) ) call nc_diag_metadata("Observation_Subtype", icsubtype(ikx) ) - call screen_to_single_nc_diag_metadata("Latitude",(data(ilate,i)) ) - call screen_to_single_nc_diag_metadata("Longitude",(data(ilone,i)) ) + call nc_diag_metadata_to_single("Latitude", data(ilate,i) ) + call nc_diag_metadata_to_single("Longitude", data(ilone,i) ) call nc_diag_metadata("Station_Elevation", missing ) - call screen_to_single_nc_diag_metadata("Pressure",(presw) ) - call screen_to_single_nc_diag_metadata("Height",(data(ihgt,i)) ) - if(isnan(dtime) .or. isnan(time_offset)) then - call nc_diag_metadata("Time",sngl(real(r_missing))) - else - call nc_diag_metadata("Time",sngl(dtime-time_offset)) - endif + call nc_diag_metadata_to_single("Pressure", presw ) + call nc_diag_metadata_to_single("Height", data(ihgt,i) ) + call nc_diag_metadata_to_single("Time", dtime,time_offset,"-" ) call nc_diag_metadata("Prep_QC_Mark", missing ) - call screen_to_single_nc_diag_metadata("Prep_Use_Flag",(data(iuse,i)) ) + call nc_diag_metadata_to_single("Prep_Use_Flag", data(iuse,i) ) ! call nc_diag_metadata("Nonlinear_QC_Var_Jb", var_jb ) - call screen_to_single_nc_diag_metadata("Nonlinear_QC_Rel_Wgt",(rwgt) ) + call nc_diag_metadata_to_single("Nonlinear_QC_Rel_Wgt",rwgt ) if(muse(i)) then - call nc_diag_metadata("Analysis_Use_Flag", sngl(one) ) + call nc_diag_metadata_to_single("Analysis_Use_Flag",one ) else - call nc_diag_metadata("Analysis_Use_Flag", sngl(-one) ) + call nc_diag_metadata_to_single("Analysis_Use_Flag",-one ) endif - call screen_to_single_nc_diag_metadata("Errinv_Input",(errinv_input) ) - call screen_to_single_nc_diag_metadata("Errinv_Adjust",(errinv_adjst) ) - call screen_to_single_nc_diag_metadata("Errinv_Final",(errinv_final) ) + call nc_diag_metadata_to_single("Errinv_Input",errinv_input ) + call nc_diag_metadata_to_single("Errinv_Adjust",errinv_adjst ) + call nc_diag_metadata_to_single("Errinv_Final",errinv_final ) - call screen_to_single_nc_diag_metadata("Observation",(data(ilob,i))) - call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_adjusted",(ddiff) ) - if(isnan(data(ilob,i)) .or. isnan(dwwind)) then - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(real(r_missing))) - else - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(data(ilob,i)-dwwind)) - endif + call nc_diag_metadata_to_single("Observation",data(ilob,i) ) + call nc_diag_metadata_to_single("Obs_Minus_Forecast_adjusted",ddiff ) + call nc_diag_metadata_to_single("Obs_Minus_Forecast_unadjusted", data(ilob,i), dwwind, '-') !_RT_NC4_TODO !_RT rdiagbuf(20,ii) = factw ! 10m wind reduction factor diff --git a/src/gsi/setuplight.f90 b/src/gsi/setuplight.f90 index f80f317474..040ef19bc6 100644 --- a/src/gsi/setuplight.f90 +++ b/src/gsi/setuplight.f90 @@ -90,7 +90,7 @@ subroutine setuplight(obsLL,odiagLL,lunin,mype,bwork,awork,nele,nobs,is,light_di nobskeep,lobsdiag_allocated use obsmod, only: netcdf_diag, binary_diag, dirname, ianldate use nc_diag_write_mod, only: nc_diag_init, nc_diag_header, nc_diag_metadata, & - nc_diag_write, nc_diag_data2d + nc_diag_write, nc_diag_data2d, nc_diag_metadata_to_single use nc_diag_read_mod, only: nc_diag_read_init, nc_diag_read_get_dim, nc_diag_read_close use obsmod, only: luse_obsdiag use m_obsNode, only: obsNode @@ -1614,36 +1614,30 @@ end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_(odiag) ! Observation class - use constants, only: r_missing - use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata type(obs_diag),pointer,intent(in):: odiag character(7),parameter :: obsclass = ' light' real(r_single),parameter:: missing = -9.99e9_r_single real(r_kind),dimension(miter) :: obsdiag_iuse - call screen_to_single_nc_diag_metadata("GLM_Detect_Err",(data(ier,i)) ) - call screen_to_single_nc_diag_metadata("Latitude",(data(ilate,i)) ) - call screen_to_single_nc_diag_metadata("Longitude",(data(ilone,i)) ) - call screen_to_single_nc_diag_metadata("Lightning_FR_Obs",(dlight ) ) - call screen_to_single_nc_diag_metadata("Time",(dtime) ) - call screen_to_single_nc_diag_metadata("GLM_QC_Mark",(data(iqc,i)) ) - call screen_to_single_nc_diag_metadata("GLM_Orig_Detect_Err",(data(ier2,i)) ) - call screen_to_single_nc_diag_metadata("GLM_Use_Flag",(data(iuse,i)) ) + call nc_diag_metadata_to_single("GLM_Detect_Err", data(ier,i) ) + call nc_diag_metadata_to_single("Latitude", data(ilate,i) ) + call nc_diag_metadata_to_single("Longitude", data(ilone,i) ) + call nc_diag_metadata_to_single("Lightning_FR_Obs", dlight ) + call nc_diag_metadata_to_single("Time", dtime ) + call nc_diag_metadata_to_single("GLM_QC_Mark", data(iqc,i) ) + call nc_diag_metadata_to_single("GLM_Orig_Detect_Err", data(ier2,i) ) + call nc_diag_metadata_to_single("GLM_Use_Flag", data(iuse,i) ) if(muse(i)) then call nc_diag_metadata("Analysis_Use_Flag", 1._r_single ) else call nc_diag_metadata("Analysis_Use_Flag", -1._r_single ) endif - call screen_to_single_nc_diag_metadata("Nonlinear_QC_Rel_Wgt",(rwgt) ) - call screen_to_single_nc_diag_metadata("Errinv_Input",(errinv_input) ) - call screen_to_single_nc_diag_metadata("Errinv_Adjust",(errinv_adjst) ) - call screen_to_single_nc_diag_metadata("Errinv_Final",(errinv_final) ) - call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_VarBC",(ddiff) ) - if(isnan(dlight) .or. isnan(lightges0)) then - call nc_diag_metadata("Obs_Minus_Forecast_NoVarBC", sngl(real(r_missing))) - else - call nc_diag_metadata("Obs_Minus_Forecast_NoVarBC", sngl(dlight-lightges0) ) - endif + call nc_diag_metadata_to_single("Nonlinear_QC_Rel_Wgt",rwgt ) + call nc_diag_metadata_to_single("Errinv_Input", errinv_input ) + call nc_diag_metadata_to_single("Errinv_Adjust", errinv_adjst ) + call nc_diag_metadata_to_single("Errinv_Final", errinv_final ) + call nc_diag_metadata_to_single("Obs_Minus_Forecast_VarBC",ddiff ) + call nc_diag_metadata_to_single("Obs_Minus_Forecast_NoVarBC",dlight,lightges0,'-') if (lobsdiagsave) then do jj=1,miter if (odiag%muse(jj)) then @@ -1656,7 +1650,7 @@ subroutine contents_netcdf_diag_(odiag) call nc_diag_data2d("ObsDiagSave_iuse", obsdiag_iuse ) call nc_diag_data2d("ObsDiagSave_nldepart", odiag%nldepart ) call nc_diag_data2d("ObsDiagSave_tldepart", odiag%tldepart ) - call nc_diag_data2d("ObsDiagSave_obssen", odiag%obssen ) + call nc_diag_data2d("ObsDiagSave_obssen", odiag%obssen ) endif end subroutine contents_netcdf_diag_ diff --git a/src/gsi/setuplwcp.f90 b/src/gsi/setuplwcp.f90 index 275105011c..7b1549aab4 100644 --- a/src/gsi/setuplwcp.f90 +++ b/src/gsi/setuplwcp.f90 @@ -68,7 +68,7 @@ subroutine setuplwcp(obsLL,odiagLL,lunin,mype,bwork,awork,nele,nobs,is,conv_diag use obsmod, only: netcdf_diag, binary_diag, dirname use nc_diag_write_mod, only: nc_diag_init, nc_diag_header,nc_diag_metadata, & - nc_diag_write, nc_diag_data2d + nc_diag_write, nc_diag_data2d, nc_diag_metadata_to_single use nc_diag_read_mod, only: nc_diag_read_init, nc_diag_read_get_dim,nc_diag_read_close use state_vectors, only: svars3d, levels @@ -837,8 +837,6 @@ subroutine contents_binary_diag_(odiag) end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_(odiag) - use constants, only: r_missing - use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' lwcp' @@ -850,36 +848,28 @@ subroutine contents_netcdf_diag_(odiag) call nc_diag_metadata("Observation_Class", obsclass ) call nc_diag_metadata("Observation_Type", ictype(ikx) ) call nc_diag_metadata("Observation_Subtype", icsubtype(ikx) ) - call screen_to_single_nc_diag_metadata("Latitude",(data(ilate,i)) ) - call screen_to_single_nc_diag_metadata("Longitude",(data(ilone,i)) ) - call screen_to_single_nc_diag_metadata("Station_Elevation",(data(istnelv,i)) ) - call screen_to_single_nc_diag_metadata("Pressure",(data(iobsprs,i)) ) - call screen_to_single_nc_diag_metadata("Height",(data(iobshgt,i)) ) - if(isnan(dtime) .or. isnan(time_offset)) then - call nc_diag_metadata("Time",sngl(real(r_missing))) - else - call nc_diag_metadata("Time",sngl(dtime-time_offset)) - endif - call screen_to_single_nc_diag_metadata("Prep_QC_Mark",(data(iqc,i)) ) - call nc_diag_metadata("Setup_QC_Mark",(rmiss_single) ) - call screen_to_single_nc_diag_metadata("Prep_Use_Flag",(data(iuse,i)) ) + call nc_diag_metadata_to_single("Latitude", data(ilate,i) ) + call nc_diag_metadata_to_single("Longitude", data(ilone,i) ) + call nc_diag_metadata_to_single("Station_Elevation",data(istnelv,i) ) + call nc_diag_metadata_to_single("Pressure", data(iobsprs,i) ) + call nc_diag_metadata_to_single("Height", data(iobshgt,i) ) + call nc_diag_metadata_to_single("Time", dtime,time_offset,'-' ) + call nc_diag_metadata_to_single("Prep_QC_Mark", data(iqc,i) ) + call nc_diag_metadata("Setup_QC_Mark", rmiss_single ) + call nc_diag_metadata_to_single("Prep_Use_Flag", data(iuse,i) ) if(muse(i)) then - call nc_diag_metadata("Analysis_Use_Flag", sngl(one) ) + call nc_diag_metadata("Analysis_Use_Flag", 1.0_r_single ) else - call nc_diag_metadata("Analysis_Use_Flag", sngl(-one) ) + call nc_diag_metadata("Analysis_Use_Flag", -1.0_r_single ) endif - call screen_to_single_nc_diag_metadata("Nonlinear_QC_Rel_Wgt",(rwgt) ) - call screen_to_single_nc_diag_metadata("Errinv_Input",(errinv_input) ) - call screen_to_single_nc_diag_metadata("Errinv_Adjust",(errinv_adjst) ) - call screen_to_single_nc_diag_metadata("Errinv_Final",(errinv_final) ) - call screen_to_single_nc_diag_metadata("Observation",(dlwcp) ) - call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_adjusted",(ddiff) ) - if(isnan(dlwcp) .or. isnan(lwcpges)) then - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(real(r_missing))) - else - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(dlwcp-lwcpges)) - endif + call nc_diag_metadata_to_single("Nonlinear_QC_Rel_Wgt",rwgt ) + call nc_diag_metadata_to_single("Errinv_Input", errinv_input ) + call nc_diag_metadata_to_single("Errinv_Adjust", errinv_adjst ) + call nc_diag_metadata_to_single("Errinv_Final", errinv_final ) + call nc_diag_metadata_to_single("Observation", dlwcp ) + call nc_diag_metadata_to_single("Obs_Minus_Forecast_adjusted",ddiff ) + call nc_diag_metadata_to_single("Obs_Minus_Forecast_unadjusted",dlwcp,lwcpges,'-') if (lobsdiagsave) then do jj=1,miter diff --git a/src/gsi/setupoz.f90 b/src/gsi/setupoz.f90 index a5784647a9..eebebfe983 100644 --- a/src/gsi/setupoz.f90 +++ b/src/gsi/setupoz.f90 @@ -134,7 +134,7 @@ subroutine setupozlay(obsLL,odiagLL,lunin,mype,stats_oz,nlevs,nreal,nobs,& use obsmod, only: netcdf_diag, binary_diag, dirname use nc_diag_write_mod, only: nc_diag_init, nc_diag_header, nc_diag_metadata, & - nc_diag_write, nc_diag_data2d + nc_diag_write, nc_diag_data2d, nc_diag_metadata_to_single use nc_diag_read_mod, only: nc_diag_read_init, nc_diag_read_get_dim, nc_diag_read_close use gsi_4dvar, only: nobs_bins,hr_obsbin @@ -152,7 +152,6 @@ subroutine setupozlay(obsLL,odiagLL,lunin,mype,stats_oz,nlevs,nreal,nobs,& use m_dtime, only: dtime_setup, dtime_check use gsi_bundlemod, only : gsi_bundlegetpointer use gsi_metguess_mod, only : gsi_metguess_get,gsi_metguess_bundle - use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata implicit none ! !INPUT PARAMETERS: @@ -576,31 +575,31 @@ subroutine setupozlay(obsLL,odiagLL,lunin,mype,stats_oz,nlevs,nreal,nobs,& if (netcdf_diag) then call nc_diag_metadata("MPI_Task_Number", mype ) - call screen_to_single_nc_diag_metadata("Latitude",(data(ilate,i)) ) - call screen_to_single_nc_diag_metadata("Longitude",(data(ilone,i)) ) + call nc_diag_metadata_to_single("Latitude",(data(ilate,i)) ) + call nc_diag_metadata_to_single("Longitude",(data(ilone,i)) ) if(isnan(dtime) .or. isnan(time_offset)) then call nc_diag_metadata("Time",sngl(real(r_missing))) else call nc_diag_metadata("Time",sngl(dtime-time_offset)) endif - call screen_to_single_nc_diag_metadata("Reference_Pressure",(pobs(k)) ) + call nc_diag_metadata_to_single("Reference_Pressure",(pobs(k)) ) call nc_diag_metadata("Analysis_Use_Flag", iouse(k) ) - call screen_to_single_nc_diag_metadata("Observation",(ozobs(k))) - call screen_to_single_nc_diag_metadata("Inverse_Observation_Error",(errorinv)) - call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_adjusted",(ozone_inv(k))) - call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_unadjusted",(ozone_inv(k))) + call nc_diag_metadata_to_single("Observation",(ozobs(k))) + call nc_diag_metadata_to_single("Inverse_Observation_Error",(errorinv)) + call nc_diag_metadata_to_single("Obs_Minus_Forecast_adjusted",(ozone_inv(k))) + call nc_diag_metadata_to_single("Obs_Minus_Forecast_unadjusted",(ozone_inv(k))) if (obstype == 'gome' .or. obstype == 'omieff' .or. & obstype == 'omi' .or. obstype == 'tomseff' ) then - call screen_to_single_nc_diag_metadata("Solar_Zenith_Angle",(data(isolz,i)) ) - call screen_to_single_nc_diag_metadata("Scan_Position",(data(ifovn,i)) ) + call nc_diag_metadata_to_single("Solar_Zenith_Angle",(data(isolz,i)) ) + call nc_diag_metadata_to_single("Scan_Position",(data(ifovn,i)) ) else - call screen_to_single_nc_diag_metadata("Solar_Zenith_Angle",(rmiss) ) - call screen_to_single_nc_diag_metadata("Scan_Position",(rmiss) ) + call nc_diag_metadata_to_single("Solar_Zenith_Angle",(rmiss) ) + call nc_diag_metadata_to_single("Scan_Position",(rmiss) ) endif if (obstype == 'omieff' .or. obstype == 'omi' ) then - call screen_to_single_nc_diag_metadata("Row_Anomaly_Index",(data(itoqf,i)) ) + call nc_diag_metadata_to_single("Row_Anomaly_Index",(data(itoqf,i)) ) else - call screen_to_single_nc_diag_metadata("Row_Anomaly_Index",(rmiss) ) + call nc_diag_metadata_to_single("Row_Anomaly_Index",(rmiss) ) endif if (save_jacobian) then call nc_diag_data2d("Observation_Operator_Jacobian_stind", dhx_dx%st_ind) @@ -1042,7 +1041,7 @@ subroutine setupozlev(obsLL,odiagLL,lunin,mype,stats_oz,nlevs,nreal,nobs,& use obsmod, only : lobsdiag_allocated,lobsdiagsave,lobsdiag_forenkf use obsmod, only: netcdf_diag, binary_diag, dirname use nc_diag_write_mod, only: nc_diag_init, nc_diag_header, nc_diag_metadata, & - nc_diag_write, nc_diag_data2d + nc_diag_write, nc_diag_data2d, nc_diag_metadata_to_single use nc_diag_read_mod, only: nc_diag_read_init, nc_diag_read_get_dim, nc_diag_read_close use m_obsNode, only: obsNode use m_o3lNode, only : o3lNode @@ -1661,30 +1660,24 @@ subroutine contents_binary_diag_(odiag) end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_(odiag) - use constants, only: r_missing - use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' ozlev' real(r_kind),dimension(miter) :: obsdiag_iuse - call screen_to_single_nc_diag_metadata("Latitude",(data(ilate,i)) ) - call screen_to_single_nc_diag_metadata("Longitude",(data(ilone,i)) ) + call nc_diag_metadata_to_single("Latitude", data(ilate,i) ) + call nc_diag_metadata_to_single("Longitude", data(ilone,i) ) call nc_diag_metadata("MPI_Task_Number", mype ) - if(isnan(dtime) .or. isnan(time_offset)) then - call nc_diag_metadata("Time",sngl(real(r_missing))) - else - call nc_diag_metadata("Time",sngl(dtime-time_offset)) - endif - call screen_to_single_nc_diag_metadata("Inverse_Observation_Error",(errorinv) ) - call screen_to_single_nc_diag_metadata("Observation",(ozlv) ) - call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_adjusted",(ozone_inv) ) - call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_unadjusted",(ozone_inv) ) - call screen_to_single_nc_diag_metadata("Reference_Pressure",(preso3l) ) - call screen_to_single_nc_diag_metadata("Input_Observation_Error",(obserror) ) + call nc_diag_metadata_to_single("Time", dtime,time_offset,'-' ) + call nc_diag_metadata_to_single("Inverse_Observation_Error",errorinv ) + call nc_diag_metadata_to_single("Observation", ozlv ) + call nc_diag_metadata_to_single("Obs_Minus_Forecast_adjusted",ozone_inv ) + call nc_diag_metadata_to_single("Obs_Minus_Forecast_unadjusted",ozone_inv ) + call nc_diag_metadata_to_single("Reference_Pressure", preso3l ) + call nc_diag_metadata_to_single("Input_Observation_Error",obserror ) if(obstype =="omps_lp")then - call screen_to_single_nc_diag_metadata("Log10 Air Number Density",(airnd)) - call screen_to_single_nc_diag_metadata("Log10 Ozone Number Density UV",(uvnd)) - call screen_to_single_nc_diag_metadata("Log10 Ozone Number Density VIS",(visnd)) + call nc_diag_metadata_to_single("Log10 Air Number Density",airnd ) + call nc_diag_metadata_to_single("Log10 Ozone Number Density UV",uvnd ) + call nc_diag_metadata_to_single("Log10 Ozone Number Density VIS",visnd ) endif if(luse(i)) then diff --git a/src/gsi/setupps.f90 b/src/gsi/setupps.f90 index 802a6566b9..118ccb45d2 100644 --- a/src/gsi/setupps.f90 +++ b/src/gsi/setupps.f90 @@ -125,12 +125,12 @@ subroutine setupps(obsLL,odiagLL,lunin,mype,bwork,awork,nele,nobs,is,conv_diagsa use obsmod, only: netcdf_diag, binary_diag, dirname use obsmod, only: l_obsprvdiag use nc_diag_write_mod, only: nc_diag_init, nc_diag_header, nc_diag_metadata, & - nc_diag_write, nc_diag_data2d + nc_diag_write, nc_diag_data2d, nc_diag_metadata_to_single use nc_diag_read_mod, only: nc_diag_read_init, nc_diag_read_get_dim, nc_diag_read_close use gridmod, only: nsig,get_ij,twodvar_regional use constants, only: zero,one_tenth,one,half,pi,g_over_rd, & huge_r_kind,tiny_r_kind,two,huge_single, & - r1000,wgtlim,tiny_single,r10,three, r_missing + r1000,wgtlim,tiny_single,r10,three use jfunc, only: jiter,last,jiterstart,miter use qcmod, only: dfact,dfact1,npres_print,vqc,nvqc use guess_grids, only: hrdifsig,ges_lnprsl,nfldsig,ntguessig @@ -882,7 +882,6 @@ subroutine contents_binary_diag_(odiag) end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_(odiag) - use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' ps' @@ -892,52 +891,29 @@ subroutine contents_netcdf_diag_(odiag) call nc_diag_metadata("Observation_Type", ictype(ikx) ) call nc_diag_metadata("Observation_Subtype", icsubtype(ikx) ) !Replace direct calls to nc_diag_metadata with the screening subroutine - call screen_to_single_nc_diag_metadata("Latitude",(data(ilate,i)) ) - call screen_to_single_nc_diag_metadata("Longitude",(data(ilone,i)) ) - call screen_to_single_nc_diag_metadata("Station_Elevation",(data(istnelv,i)) ) - if(isnan(data(ipres,i))) then - call nc_diag_metadata("Pressure",sngl(real(r_missing))) - else - call screen_to_single_nc_diag_metadata("Pressure",data(ipres,i)*r10) - endif - call screen_to_single_nc_diag_metadata("Height",dhgt) - if(isnan(dtime) .or. isnan(time_offset)) then - call nc_diag_metadata("Time",sngl(real(r_missing))) - else - call nc_diag_metadata("Time",sngl(dtime-time_offset)) - endif - call screen_to_single_nc_diag_metadata("Prep_QC_Mark",(data(iqc,i)) ) - call screen_to_single_nc_diag_metadata("Prep_Use_Flag",(data(iuse,i)) ) - call screen_to_single_nc_diag_metadata("Nonlinear_QC_Var_Jb",(var_jb) ) - call screen_to_single_nc_diag_metadata("Nonlinear_QC_Rel_Wgt",rwgt ) + call nc_diag_metadata_to_single("Latitude", data(ilate,i) ) + call nc_diag_metadata_to_single("Longitude", data(ilone,i) ) + call nc_diag_metadata_to_single("Station_Elevation",data(istnelv,i) ) + call nc_diag_metadata_to_single("Pressure", data(ipres,i),r10,'*' ) + call nc_diag_metadata_to_single("Height", dhgt ) + call nc_diag_metadata_to_single("Time", dtime,time_offset,'-' ) + call nc_diag_metadata_to_single("Prep_QC_Mark", data(iqc,i) ) + call nc_diag_metadata_to_single("Prep_Use_Flag", data(iuse,i) ) + call nc_diag_metadata_to_single("Nonlinear_QC_Var_Jb",var_jb ) + call nc_diag_metadata_to_single("Nonlinear_QC_Rel_Wgt",rwgt ) if(muse(i)) then - call nc_diag_metadata("Analysis_Use_Flag", sngl(one) ) + call nc_diag_metadata("Analysis_Use_Flag", 1.0_r_single ) else - call nc_diag_metadata("Analysis_Use_Flag", sngl(-one) ) + call nc_diag_metadata("Analysis_Use_Flag", 1.0_r_single ) endif - call screen_to_single_nc_diag_metadata("Errinv_Input",(errinv_input) ) - call screen_to_single_nc_diag_metadata("Errinv_Adjust",(errinv_adjst) ) - call screen_to_single_nc_diag_metadata("Errinv_Final",(errinv_final) ) + call nc_diag_metadata_to_single("Errinv_Input", errinv_input ) + call nc_diag_metadata_to_single("Errinv_Adjust", errinv_adjst ) + call nc_diag_metadata_to_single("Errinv_Final", errinv_final ) - if(isnan(pob)) then - call nc_diag_metadata("Observation",sngl(real(r_missing)) ) - 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("Observation",sngl(pob) ) - if(isnan(pges)) then - call nc_diag_metadata("Obs_Minus_Forecast_adjusted",sngl(real(r_missing))) - else - call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_adjusted",pob-pges) - endif - - if(isnan(pgesorig)) then - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted",sngl(real(r_missing))) - else - call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_unadjusted",pob-pgesorig) - endif - endif + call nc_diag_metadata_to_single("Observation", pob ) + call nc_diag_metadata_to_single("Obs_Minus_Forecast_adjusted",pob,pges,'-') + call nc_diag_metadata_to_single("Obs_Minus_Forecast_unadjusted",pob,pgesorig,'-') if (lobsdiagsave) then diff --git a/src/gsi/setuppw.f90 b/src/gsi/setuppw.f90 index fe2de99522..08872c0a51 100644 --- a/src/gsi/setuppw.f90 +++ b/src/gsi/setuppw.f90 @@ -96,7 +96,7 @@ subroutine setuppw(obsLL,odiagLL,lunin,mype,bwork,awork,nele,nobs,is,conv_diagsa lobsdiagsave,nobskeep,lobsdiag_allocated,time_offset use obsmod, only: netcdf_diag, binary_diag, dirname use nc_diag_write_mod, only: nc_diag_init, nc_diag_header, nc_diag_metadata, & - nc_diag_write, nc_diag_data2d + nc_diag_write, nc_diag_data2d, nc_diag_metadata_to_single use nc_diag_read_mod, only: nc_diag_read_init, nc_diag_read_get_dim, nc_diag_read_close use m_obsNode, only: obsNode use m_pwNode, only: pwNode @@ -710,8 +710,6 @@ subroutine contents_binary_diag_(odiag) end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_(odiag) - use constants, only: r_missing - use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata type(obs_diag),pointer,intent(in):: odiag ! Observation class ! use model surface pressure, so PW can be used in EnKF analysis @@ -723,35 +721,27 @@ subroutine contents_netcdf_diag_(odiag) call nc_diag_metadata("Observation_Class", obsclass ) call nc_diag_metadata("Observation_Type", ictype(ikx) ) call nc_diag_metadata("Observation_Subtype", icsubtype(ikx) ) - call screen_to_single_nc_diag_metadata("Latitude",(data(ilate,i)) ) - call screen_to_single_nc_diag_metadata("Longitude",(data(ilone,i)) ) - call screen_to_single_nc_diag_metadata("Station_Elevation",(data(istnelv,i)) ) - call screen_to_single_nc_diag_metadata("Pressure",(prest) ) - call screen_to_single_nc_diag_metadata("Height",(data(iobshgt,i)) ) - if(isnan(dtime) .or. isnan(time_offset)) then - call nc_diag_metadata("Time",sngl(real(r_missing))) - else - call nc_diag_metadata("Time",sngl(dtime-time_offset)) - endif - call screen_to_single_nc_diag_metadata("Prep_QC_Mark",(data(iqc,i)) ) - call screen_to_single_nc_diag_metadata("Prep_Use_Flag",(data(iuse,i)) ) + call nc_diag_metadata_to_single("Latitude", data(ilate,i) ) + call nc_diag_metadata_to_single("Longitude", data(ilone,i) ) + call nc_diag_metadata_to_single("Station_Elevation", data(istnelv,i) ) + call nc_diag_metadata_to_single("Pressure", prest ) + call nc_diag_metadata_to_single("Height", data(iobshgt,i) ) + call nc_diag_metadata_to_single("Time", dtime,time_offset,'-' ) + call nc_diag_metadata_to_single("Prep_QC_Mark", data(iqc,i) ) + call nc_diag_metadata_to_single("Prep_Use_Flag", data(iuse,i) ) call nc_diag_metadata("Setup_QC_Mark", missing ) if(muse(i)) then call nc_diag_metadata("Analysis_Use_Flag", 1._r_single ) else call nc_diag_metadata("Analysis_Use_Flag", -1._r_single ) endif - call screen_to_single_nc_diag_metadata("Nonlinear_QC_Rel_Wgt",(rwgt) ) - call screen_to_single_nc_diag_metadata("Errinv_Input",(errinv_input) ) - call screen_to_single_nc_diag_metadata("Errinv_Adjust",(errinv_adjst) ) - call screen_to_single_nc_diag_metadata("Errinv_Final",(errinv_final) ) - call screen_to_single_nc_diag_metadata("Observation",(dpw) ) - call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_adjusted",(ddiff) ) - if(isnan(dpw) .or. isnan(pwges)) then - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(real(r_missing))) - else - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(dpw-pwges)) - endif + call nc_diag_metadata_to_single("Nonlinear_QC_Rel_Wgt",rwgt ) + call nc_diag_metadata_to_single("Errinv_Input", errinv_input ) + call nc_diag_metadata_to_single("Errinv_Adjust", errinv_adjst ) + call nc_diag_metadata_to_single("Errinv_Final", errinv_final ) + call nc_diag_metadata_to_single("Observation", dpw ) + call nc_diag_metadata_to_single("Obs_Minus_Forecast_adjusted",ddiff ) + call nc_diag_metadata_to_single("Obs_Minus_Forecast_unadjusted", dpw,pwges,'-' ) if (lobsdiagsave) then do jj=1,miter if (odiag%muse(jj)) then diff --git a/src/gsi/setupq.f90 b/src/gsi/setupq.f90 index 9e82a43ac2..cc06d169a7 100644 --- a/src/gsi/setupq.f90 +++ b/src/gsi/setupq.f90 @@ -150,7 +150,7 @@ subroutine setupq(obsLL,odiagLL,lunin,mype,bwork,awork,nele,nobs,is,conv_diagsav use obsmod, only: netcdf_diag, binary_diag, dirname use obsmod, only: l_obsprvdiag use nc_diag_write_mod, only: nc_diag_init, nc_diag_header, nc_diag_metadata, & - nc_diag_write, nc_diag_data2d + nc_diag_write, nc_diag_data2d, nc_diag_metadata_to_single use nc_diag_read_mod, only: nc_diag_read_init, nc_diag_read_get_dim, nc_diag_read_close use gsi_4dvar, only: nobs_bins,hr_obsbin,min_offset use oneobmod, only: oneobtest,maginnov,magoberr @@ -1261,8 +1261,6 @@ subroutine contents_binary_diagp_(odiag) end subroutine contents_binary_diagp_ subroutine contents_netcdf_diag_(odiag) - use constants, only: r_missing - use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' q' @@ -1272,37 +1270,29 @@ subroutine contents_netcdf_diag_(odiag) call nc_diag_metadata("Observation_Class", obsclass ) call nc_diag_metadata("Observation_Type", ictype(ikx) ) call nc_diag_metadata("Observation_Subtype", icsubtype(ikx) ) - call screen_to_single_nc_diag_metadata("Latitude",(data(ilate,i)) ) - call screen_to_single_nc_diag_metadata("Longitude",(data(ilone,i)) ) - call screen_to_single_nc_diag_metadata("Station_Elevation",(data(istnelv,i)) ) - call screen_to_single_nc_diag_metadata("Pressure",(presq) ) - call screen_to_single_nc_diag_metadata("Height",(data(iobshgt,i)) ) - if(isnan(dtime) .or. isnan(time_offset)) then - call nc_diag_metadata("Time",sngl(real(r_missing))) - else - call nc_diag_metadata("Time",sngl(dtime-time_offset)) - endif - call screen_to_single_nc_diag_metadata("Prep_QC_Mark",(data(iqc,i)) ) - call screen_to_single_nc_diag_metadata("Prep_Use_Flag",(data(iuse,i)) ) - call screen_to_single_nc_diag_metadata("Nonlinear_QC_Var_Jb",(var_jb) ) - call screen_to_single_nc_diag_metadata("Nonlinear_QC_Rel_Wgt",(rwgt) ) + call nc_diag_metadata_to_single("Latitude", data(ilate,i) ) + call nc_diag_metadata_to_single("Longitude", data(ilone,i) ) + call nc_diag_metadata_to_single("Station_Elevation",data(istnelv,i) ) + call nc_diag_metadata_to_single("Pressure", presq ) + call nc_diag_metadata_to_single("Height", data(iobshgt,i) ) + call nc_diag_metadata_to_single("Time", dtime,time_offset,'-' ) + call nc_diag_metadata_to_single("Prep_QC_Mark", data(iqc,i) ) + call nc_diag_metadata_to_single("Prep_Use_Flag",data(iuse,i) ) + call nc_diag_metadata_to_single("Nonlinear_QC_Var_Jb",var_jb ) + call nc_diag_metadata_to_single("Nonlinear_QC_Rel_Wgt",rwgt ) if(muse(i)) then - call nc_diag_metadata("Analysis_Use_Flag", sngl(one) ) - else - call nc_diag_metadata("Analysis_Use_Flag", sngl(-one) ) - endif - call screen_to_single_nc_diag_metadata("Errinv_Input",(errinv_input) ) - call screen_to_single_nc_diag_metadata("Errinv_Adjust",(errinv_adjst) ) - call screen_to_single_nc_diag_metadata("Errinv_Final",(errinv_final) ) - - call screen_to_single_nc_diag_metadata("Observation",(data(iqob,i))) - call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_adjusted",(ddiff) ) - if(isnan(qob) .or. isnan(qges)) then - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(real(r_missing))) + call nc_diag_metadata("Analysis_Use_Flag", 1.0_r_single ) else - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(qob-qges)) + call nc_diag_metadata("Analysis_Use_Flag", -1.0_r_single ) endif - call screen_to_single_nc_diag_metadata("Forecast_Saturation_Spec_Hum",(qsges) ) + call nc_diag_metadata_to_single("Errinv_Input", errinv_input ) + call nc_diag_metadata_to_single("Errinv_Adjust",errinv_adjst ) + call nc_diag_metadata_to_single("Errinv_Final", errinv_final ) + + call nc_diag_metadata_to_single("Observation", data(iqob,i) ) + call nc_diag_metadata_to_single("Obs_Minus_Forecast_adjusted",ddiff ) + call nc_diag_metadata_to_single("Obs_Minus_Forecast_unadjusted",qob,qges,'-') + call nc_diag_metadata_to_single("Forecast_Saturation_Spec_Hum",qsges ) if (lobsdiagsave) then do jj=1,miter if (odiag%muse(jj)) then @@ -1335,8 +1325,6 @@ subroutine contents_netcdf_diag_(odiag) end subroutine contents_netcdf_diag_ subroutine contents_netcdf_diagp_(odiag) - use constants, only: r_missing - use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' q' @@ -1346,33 +1334,29 @@ subroutine contents_netcdf_diagp_(odiag) call nc_diag_metadata("Observation_Class", obsclass ) call nc_diag_metadata("Observation_Type", ictype(ikx) ) call nc_diag_metadata("Observation_Subtype", -1 ) ! (-1 for pseudo obs sub-type) - call screen_to_single_nc_diag_metadata("Latitude",(data(ilate,i)) ) - call screen_to_single_nc_diag_metadata("Longitude",(data(ilone,i)) ) - call screen_to_single_nc_diag_metadata("Station_Elevation",(data(istnelv,i)) ) - call screen_to_single_nc_diag_metadata("Pressure",(presq) ) - call screen_to_single_nc_diag_metadata("Height",(data(iobshgt,i)) ) - if(isnan(dtime) .or. isnan(time_offset)) then - call nc_diag_metadata("Time",sngl(real(r_missing))) - else - call nc_diag_metadata("Time",sngl(dtime-time_offset)) - endif - call screen_to_single_nc_diag_metadata("Prep_QC_Mark",(data(iqc,i)) ) - call screen_to_single_nc_diag_metadata("Prep_Use_Flag",(data(iuse,i)) ) - call screen_to_single_nc_diag_metadata("Nonlinear_QC_Var_Jb",(var_jb) ) - call screen_to_single_nc_diag_metadata("Nonlinear_QC_Rel_Wgt",(rwgt) ) + call nc_diag_metadata_to_single("Latitude", data(ilate,i) ) + call nc_diag_metadata_to_single("Longitude", data(ilone,i) ) + call nc_diag_metadata_to_single("Station_Elevation",data(istnelv,i) ) + call nc_diag_metadata_to_single("Pressure", presq ) + call nc_diag_metadata_to_single("Height", data(iobshgt,i) ) + call nc_diag_metadata_to_single("Time", dtime,time_offset,'-' ) + call nc_diag_metadata_to_single("Prep_QC_Mark", data(iqc,i) ) + call nc_diag_metadata_to_single("Prep_Use_Flag", data(iuse,i) ) + call nc_diag_metadata_to_single("Nonlinear_QC_Var_Jb",var_jb ) + call nc_diag_metadata_to_single("Nonlinear_QC_Rel_Wgt",rwgt ) if(muse(i)) then - call nc_diag_metadata("Analysis_Use_Flag", sngl(one) ) + call nc_diag_metadata("Analysis_Use_Flag", 1.0_r_single ) else - call nc_diag_metadata("Analysis_Use_Flag", sngl(-one) ) + call nc_diag_metadata("Analysis_Use_Flag", -1.0_r_single ) endif - call screen_to_single_nc_diag_metadata("Errinv_Input",(errinv_input) ) - call screen_to_single_nc_diag_metadata("Errinv_Adjust",(errinv_adjst) ) - call screen_to_single_nc_diag_metadata("Errinv_Final",(errinv_final) ) - - call screen_to_single_nc_diag_metadata("Observation",(data(iqob,i))) - call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_adjusted",(ddiff) ) - call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_unadjusted",(ddiff) ) - call screen_to_single_nc_diag_metadata("Forecast_Saturation_Spec_Hum",(qsges) ) + call nc_diag_metadata_to_single("Errinv_Input", errinv_input ) + call nc_diag_metadata_to_single("Errinv_Adjust", errinv_adjst ) + call nc_diag_metadata_to_single("Errinv_Final", errinv_final ) + + call nc_diag_metadata_to_single("Observation", data(iqob,i) ) + call nc_diag_metadata_to_single("Obs_Minus_Forecast_adjusted",ddiff ) + call nc_diag_metadata_to_single("Obs_Minus_Forecast_unadjusted",ddiff ) + call nc_diag_metadata_to_single("Forecast_Saturation_Spec_Hum",qsges ) !---- if (lobsdiagsave) then do jj=1,miter diff --git a/src/gsi/setuprad.f90 b/src/gsi/setuprad.f90 index f6c1994271..ac4fd657bf 100644 --- a/src/gsi/setuprad.f90 +++ b/src/gsi/setuprad.f90 @@ -270,7 +270,8 @@ subroutine setuprad(obsLL,odiagLL,lunin,mype,aivals,stats,nchanl,nreal,nobs,& use obsmod, only: luse_obsdiag,dval_use use obsmod, only: netcdf_diag, binary_diag, dirname use nc_diag_write_mod, only: nc_diag_init, nc_diag_header, nc_diag_metadata, & - nc_diag_write, nc_diag_data2d, nc_diag_chaninfo_dim_set, nc_diag_chaninfo + nc_diag_write, nc_diag_data2d, nc_diag_chaninfo_dim_set, & + nc_diag_chaninfo, nc_diag_metadata_to_single use gsi_4dvar, only: nobs_bins,hr_obsbin,l4dvar use gridmod, only: nsig,regional,get_ij use satthin, only: super_val1 @@ -2543,7 +2544,6 @@ subroutine contents_binary_diag_(odiags,idv,iob) end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_(odiags,idv,iob) - use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata type(fptr_obsdiagNode),dimension(:),intent(in):: odiags integer(i_kind),intent(in):: idv,iob @@ -2565,45 +2565,33 @@ subroutine contents_netcdf_diag_(odiags,idv,iob) do i=1,nchanl_diag call nc_diag_metadata("Channel_Index", i ) call nc_diag_metadata("Observation_Class", obsclass ) - call screen_to_single_nc_diag_metadata("Latitude",(cenlat) ) ! observation latitude (degrees) - call screen_to_single_nc_diag_metadata("Longitude",(cenlon) ) ! observation longitude (degrees) + call nc_diag_metadata_to_single("Latitude",cenlat ) ! observation latitude (degrees) + call nc_diag_metadata_to_single("Longitude",cenlon ) ! observation longitude (degrees) - call screen_to_single_nc_diag_metadata("Elevation",(zsges) ) ! model (guess) elevation at observation location + call nc_diag_metadata_to_single("Elevation",zsges ) ! model (guess) elevation at observation location - if(isnan(dtime) .or. isnan(time_offset)) then - call nc_diag_metadata("Time",sngl(real(r_missing))) - else - call nc_diag_metadata("Time",sngl(dtime-time_offset)) - endif + call nc_diag_metadata_to_single("Time",dtime,time_offset,'-') - call screen_to_single_nc_diag_metadata("Scan_Position",(data_s(iscan_pos,n)) ) ! sensor scan position - if(isnan(zasat)) then - call nc_diag_metadata("Sat_Zenith_Angle", sngl(real(r_missing))) ! satellite zenith angle (degrees) - else - call nc_diag_metadata("Sat_Zenith_Angle", sngl(zasat*rad2deg)) ! satellite zenith angle (degrees) - endif - call screen_to_single_nc_diag_metadata("Sat_Azimuth_Angle",(data_s(ilazi_ang,n)) ) ! satellite azimuth angle (degrees) - call screen_to_single_nc_diag_metadata("Sol_Zenith_Angle",(pangs) ) ! solar zenith angle (degrees) - call screen_to_single_nc_diag_metadata("Sol_Azimuth_Angle",(data_s(isazi_ang,n)) ) ! solar azimuth angle (degrees) - call screen_to_single_nc_diag_metadata("Sun_Glint_Angle",(sgagl) ) ! sun glint angle (degrees) (sgagl) - if(isnan(data_s(iscan_ang,n))) then - call nc_diag_metadata("Scan_Angle",sngl(real(r_missing))) ! scan angle - else - call nc_diag_metadata("Scan_Angle",sngl(data_s(iscan_ang,n)*rad2deg)) ! scan angle - endif + call nc_diag_metadata_to_single("Scan_Position",data_s(iscan_pos,n) ) ! sensor scan position + call nc_diag_metadata_to_single("Sat_Zenith_Angle", zasat,rad2deg,'*') ! satellite zenith angle (degrees) + call nc_diag_metadata_to_single("Sat_Azimuth_Angle",data_s(ilazi_ang,n) ) ! satellite azimuth angle (degrees) + call nc_diag_metadata_to_single("Sol_Zenith_Angle",pangs ) ! solar zenith angle (degrees) + call nc_diag_metadata_to_single("Sol_Azimuth_Angle",data_s(isazi_ang,n) ) ! solar azimuth angle (degrees) + call nc_diag_metadata_to_single("Sun_Glint_Angle",sgagl ) ! sun glint angle (degrees) (sgagl) + call nc_diag_metadata_to_single("Scan_Angle",data_s(iscan_ang,n),rad2deg,'*' ) ! scan angle - call screen_to_single_nc_diag_metadata("Water_Fraction",(surface(1)%water_coverage) ) ! fractional coverage by water - call screen_to_single_nc_diag_metadata("Land_Fraction",(surface(1)%land_coverage) ) ! fractional coverage by land - call screen_to_single_nc_diag_metadata("Ice_Fraction",(surface(1)%ice_coverage) ) ! fractional coverage by ice - call screen_to_single_nc_diag_metadata("Snow_Fraction",(surface(1)%snow_coverage) ) ! fractional coverage by snow + call nc_diag_metadata_to_single("Water_Fraction",surface(1)%water_coverage ) ! fractional coverage by water + call nc_diag_metadata_to_single("Land_Fraction",surface(1)%land_coverage ) ! fractional coverage by land + call nc_diag_metadata_to_single("Ice_Fraction",surface(1)%ice_coverage ) ! fractional coverage by ice + call nc_diag_metadata_to_single("Snow_Fraction",surface(1)%snow_coverage ) ! fractional coverage by snow if(.not. retrieval)then - call screen_to_single_nc_diag_metadata("Water_Temperature",(surface(1)%water_temperature) ) ! surface temperature over water (K) - call screen_to_single_nc_diag_metadata("Land_Temperature",(surface(1)%land_temperature) ) ! surface temperature over land (K) - call screen_to_single_nc_diag_metadata("Ice_Temperature",(surface(1)%ice_temperature) ) ! surface temperature over ice (K) - call screen_to_single_nc_diag_metadata("Snow_Temperature",(surface(1)%snow_temperature) ) ! surface temperature over snow (K) - call screen_to_single_nc_diag_metadata("Soil_Temperature",(surface(1)%soil_temperature) ) ! soil temperature (K) - call screen_to_single_nc_diag_metadata("Soil_Moisture",(surface(1)%soil_moisture_content) ) ! soil moisture + call nc_diag_metadata_to_single("Water_Temperature",surface(1)%water_temperature ) ! surface temperature over water (K) + call nc_diag_metadata_to_single("Land_Temperature",surface(1)%land_temperature ) ! surface temperature over land (K) + call nc_diag_metadata_to_single("Ice_Temperature",surface(1)%ice_temperature ) ! surface temperature over ice (K) + call nc_diag_metadata_to_single("Snow_Temperature",surface(1)%snow_temperature ) ! surface temperature over snow (K) + call nc_diag_metadata_to_single("Soil_Temperature",surface(1)%soil_temperature ) ! soil temperature (K) + call nc_diag_metadata_to_single("Soil_Moisture",surface(1)%soil_moisture_content ) ! soil moisture call nc_diag_metadata("Land_Type_Index", surface(1)%land_type ) ! surface land type call nc_diag_metadata("tsavg5", missing ) ! SST first guess used for SST retrieval call nc_diag_metadata("sstcu", missing ) ! NCEP SST analysis at t @@ -2620,27 +2608,27 @@ subroutine contents_netcdf_diag_(odiags,idv,iob) call nc_diag_metadata("Soil_Temperature", missing ) ! soil temperature (K) call nc_diag_metadata("Soil_Moisture", missing ) ! soil moisture call nc_diag_metadata("Land_Type_Index", imissing ) ! surface land type - call screen_to_single_nc_diag_metadata("tsavg5",(tsavg5) ) ! SST first guess used for SST retrieval - call screen_to_single_nc_diag_metadata("sstcu",(sstcu) ) ! NCEP SST analysis at t - call screen_to_single_nc_diag_metadata("sstph",(sstph) ) ! Physical SST retrieval - call screen_to_single_nc_diag_metadata("sstnv",(sstnv) ) ! Navy SST retrieval - call screen_to_single_nc_diag_metadata("dta",(dta) ) ! d(ta) corresponding to sstph - call screen_to_single_nc_diag_metadata("dqa",(dqa) ) ! d(qa) corresponding to sstph - call screen_to_single_nc_diag_metadata("dtp_avh",(dtp_avh) ) ! data type + call nc_diag_metadata_to_single("tsavg5",tsavg5 ) ! SST first guess used for SST retrieval + call nc_diag_metadata_to_single("sstcu",sstcu ) ! NCEP SST analysis at t + call nc_diag_metadata_to_single("sstph",sstph ) ! Physical SST retrieval + call nc_diag_metadata_to_single("sstnv",sstnv ) ! Navy SST retrieval + call nc_diag_metadata_to_single("dta",dta ) ! d(ta) corresponding to sstph + call nc_diag_metadata_to_single("dqa",dqa ) ! d(qa) corresponding to sstph + call nc_diag_metadata_to_single("dtp_avh",dtp_avh ) ! data type endif - call screen_to_single_nc_diag_metadata("Vegetation_Fraction",(surface(1)%vegetation_fraction) ) - call screen_to_single_nc_diag_metadata("Snow_Depth",(surface(1)%snow_depth) ) - call screen_to_single_nc_diag_metadata("tpwc",(tpwc_obs) ) - call screen_to_single_nc_diag_metadata("clw_guess_retrieval",(clw_guess_retrieval) ) + call nc_diag_metadata_to_single("Vegetation_Fraction",surface(1)%vegetation_fraction ) + call nc_diag_metadata_to_single("Snow_Depth",surface(1)%snow_depth ) + call nc_diag_metadata_to_single("tpwc",tpwc_obs ) + call nc_diag_metadata_to_single("clw_guess_retrieval",clw_guess_retrieval ) - call screen_to_single_nc_diag_metadata("Sfc_Wind_Speed",(surface(1)%wind_speed) ) - call screen_to_single_nc_diag_metadata("Cloud_Frac",(cld) ) - call screen_to_single_nc_diag_metadata("CTP",(cldp) ) - call screen_to_single_nc_diag_metadata("CLW",(clw_obs) ) - call screen_to_single_nc_diag_metadata("TPWC",(tpwc_obs) ) - call screen_to_single_nc_diag_metadata("clw_obs",(clw_obs) ) - call screen_to_single_nc_diag_metadata("clw_guess",(clw_guess) ) + call nc_diag_metadata_to_single("Sfc_Wind_Speed",surface(1)%wind_speed ) + call nc_diag_metadata_to_single("Cloud_Frac",cld ) + call nc_diag_metadata_to_single("CTP",cldp ) + call nc_diag_metadata_to_single("CLW",clw_obs ) + call nc_diag_metadata_to_single("TPWC",tpwc_obs ) + call nc_diag_metadata_to_single("clw_obs",clw_obs ) + call nc_diag_metadata_to_single("clw_guess",clw_guess ) if (nstinfo==0) then data_s(itref,n) = missing @@ -2649,21 +2637,21 @@ subroutine contents_netcdf_diag_(odiags,idv,iob) data_s(itz_tr,n) = missing endif - call screen_to_single_nc_diag_metadata("Foundation_Temperature",(data_s(itref,n)) ) ! reference temperature (Tr) in NSST - call screen_to_single_nc_diag_metadata("SST_Warm_layer_dt",(data_s(idtw,n)) ) ! dt_warm at zob - call screen_to_single_nc_diag_metadata("SST_Cool_layer_tdrop",(data_s(idtc,n)) ) ! dt_cool at zob - call screen_to_single_nc_diag_metadata("SST_dTz_dTfound",(data_s(itz_tr,n)) ) ! d(Tz)/d(Tr) + call nc_diag_metadata_to_single("Foundation_Temperature",data_s(itref,n) ) ! reference temperature (Tr) in NSST + call nc_diag_metadata_to_single("SST_Warm_layer_dt",data_s(idtw,n) ) ! dt_warm at zob + call nc_diag_metadata_to_single("SST_Cool_layer_tdrop",data_s(idtc,n) ) ! dt_cool at zob + call nc_diag_metadata_to_single("SST_dTz_dTfound",data_s(itz_tr,n) ) ! d(Tz)/d(Tr) - call screen_to_single_nc_diag_metadata("Observation",(tb_obs0(ich_diag(i))) ) ! observed brightness temperature (K) - call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_unadjusted",(tbcnob(ich_diag(i))) ) ! observed - simulated Tb with no bias correction (K) - call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_adjusted",(tbc0(ich_diag(i) )) ) ! observed - simulated Tb with bias corrrection (K) + call nc_diag_metadata_to_single("Observation",tb_obs0(ich_diag(i)) ) ! observed brightness temperature (K) + call nc_diag_metadata_to_single("Obs_Minus_Forecast_unadjusted",tbcnob(ich_diag(i)) ) ! observed - simulated Tb with no bias correction (K) + call nc_diag_metadata_to_single("Obs_Minus_Forecast_adjusted",tbc0(ich_diag(i) ) ) ! observed - simulated Tb with bias corrrection (K) errinv = sqrt(varinv0(ich_diag(i))) - call screen_to_single_nc_diag_metadata("Inverse_Observation_Error",(errinv) ) + call nc_diag_metadata_to_single("Inverse_Observation_Error",errinv ) if (save_jacobian .and. allocated(idnames)) then - call screen_to_single_nc_diag_metadata("Observation_scaled",(tb_obs(ich_diag(i))) ) ! observed brightness temperature (K) scaled by R^{-1/2} - call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_adjusted_scaled",(tbc(ich_diag(i) )) ) ! observed - simulated Tb with bias corrrection (K) scaled by R^{-1/2} + call nc_diag_metadata_to_single("Observation_scaled",tb_obs(ich_diag(i)) ) ! observed brightness temperature (K) scaled by R^{-1/2} + call nc_diag_metadata_to_single("Obs_Minus_Forecast_adjusted_scaled",tbc(ich_diag(i) ) ) ! observed - simulated Tb with bias corrrection (K) scaled by R^{-1/2} errinv = sqrt(varinv(ich_diag(i))) - call screen_to_single_nc_diag_metadata("Inverse_Observation_Error_scaled",(errinv) ) + call nc_diag_metadata_to_single("Inverse_Observation_Error_scaled",errinv ) endif if (save_jacobian) then j = 1 @@ -2704,32 +2692,32 @@ subroutine contents_netcdf_diag_(odiags,idv,iob) call nc_diag_metadata("QC_Flag",sngl(id_qc(ich_diag(i))*useflag))! quality control mark or event indicator - call screen_to_single_nc_diag_metadata("Emissivity",(emissivity(ich_diag(i))) ) ! surface emissivity - call screen_to_single_nc_diag_metadata("Weighted_Lapse_Rate",(tlapchn(ich_diag(i))) ) ! stability index - call screen_to_single_nc_diag_metadata("dTb_dTs",(ts(ich_diag(i))) ) ! d(Tb)/d(Ts) - - call screen_to_single_nc_diag_metadata("BC_Constant",(predbias(1,ich_diag(i))) ) ! constant bias correction term - call screen_to_single_nc_diag_metadata("BC_Scan_Angle",(predbias(2,ich_diag(i))) ) ! scan angle bias correction term - call screen_to_single_nc_diag_metadata("BC_Cloud_Liquid_Water",(predbias(3,ich_diag(i))) ) ! CLW bias correction term - call screen_to_single_nc_diag_metadata("BC_Lapse_Rate_Squared",(predbias(4,ich_diag(i))) ) ! square lapse rate bias correction term - call screen_to_single_nc_diag_metadata("BC_Lapse_Rate",(predbias(5,ich_diag(i))) ) ! lapse rate bias correction term - call screen_to_single_nc_diag_metadata("BC_Cosine_Latitude_times_Node",(predbias(6,ich_diag(i))) ) ! node*cos(lat) bias correction term - call screen_to_single_nc_diag_metadata("BC_Sine_Latitude",(predbias(7,ich_diag(i))) ) ! sin(lat) bias correction term - call screen_to_single_nc_diag_metadata("BC_Emissivity",(predbias(8,ich_diag(i))) ) ! emissivity sensitivity bias correction term - call screen_to_single_nc_diag_metadata("BC_Fixed_Scan_Position",(predbias(npred+1,ich_diag(i))) ) ! external scan angle + call nc_diag_metadata_to_single("Emissivity",emissivity(ich_diag(i)) ) ! surface emissivity + call nc_diag_metadata_to_single("Weighted_Lapse_Rate",tlapchn(ich_diag(i)) ) ! stability index + call nc_diag_metadata_to_single("dTb_dTs",ts(ich_diag(i)) ) ! d(Tb)/d(Ts) + + call nc_diag_metadata_to_single("BC_Constant",predbias(1,ich_diag(i)) ) ! constant bias correction term + call nc_diag_metadata_to_single("BC_Scan_Angle",predbias(2,ich_diag(i)) ) ! scan angle bias correction term + call nc_diag_metadata_to_single("BC_Cloud_Liquid_Water",predbias(3,ich_diag(i)) ) ! CLW bias correction term + call nc_diag_metadata_to_single("BC_Lapse_Rate_Squared",predbias(4,ich_diag(i)) ) ! square lapse rate bias correction term + call nc_diag_metadata_to_single("BC_Lapse_Rate",predbias(5,ich_diag(i)) ) ! lapse rate bias correction term + call nc_diag_metadata_to_single("BC_Cosine_Latitude_times_Node",predbias(6,ich_diag(i)) ) ! node*cos(lat) bias correction term + call nc_diag_metadata_to_single("BC_Sine_Latitude",predbias(7,ich_diag(i)) ) ! sin(lat) bias correction term + call nc_diag_metadata_to_single("BC_Emissivity",predbias(8,ich_diag(i)) ) ! emissivity sensitivity bias correction term + call nc_diag_metadata_to_single("BC_Fixed_Scan_Position",predbias(npred+1,ich_diag(i)) ) ! external scan angle if (lwrite_predterms) then - call screen_to_single_nc_diag_metadata("BCPred_Constant",(pred(1,ich_diag(i))) ) ! constant bias correction term - call screen_to_single_nc_diag_metadata("BCPred_Scan_Angle",(pred(2,ich_diag(i))) ) ! scan angle bias correction term - call screen_to_single_nc_diag_metadata("BCPred_Cloud_Liquid_Water",(pred(3,ich_diag(i))) ) ! CLW bias correction term - call screen_to_single_nc_diag_metadata("BCPred_Lapse_Rate_Squared",(pred(4,ich_diag(i))) ) ! square lapse rate bias correction term - call screen_to_single_nc_diag_metadata("BCPred_Lapse_Rate",(pred(5,ich_diag(i))) ) ! lapse rate bias correction term - call screen_to_single_nc_diag_metadata("BCPred_Cosine_Latitude_times_Node",(pred(6,ich_diag(i))) ) ! node*cos(lat) bias correction term - call screen_to_single_nc_diag_metadata("BCPred_Sine_Latitude",(pred(7,ich_diag(i))) ) ! sin(lat) bias correction term - call screen_to_single_nc_diag_metadata("BCPred_Emissivity",(pred(8,ich_diag(i))) ) ! emissivity sensitivity bias correction term + call nc_diag_metadata_to_single("BCPred_Constant",pred(1,ich_diag(i)) ) ! constant bias correction term + call nc_diag_metadata_to_single("BCPred_Scan_Angle",pred(2,ich_diag(i)) ) ! scan angle bias correction term + call nc_diag_metadata_to_single("BCPred_Cloud_Liquid_Water",pred(3,ich_diag(i)) ) ! CLW bias correction term + call nc_diag_metadata_to_single("BCPred_Lapse_Rate_Squared",pred(4,ich_diag(i)) ) ! square lapse rate bias correction term + call nc_diag_metadata_to_single("BCPred_Lapse_Rate",pred(5,ich_diag(i)) ) ! lapse rate bias correction term + call nc_diag_metadata_to_single("BCPred_Cosine_Latitude_times_Node",pred(6,ich_diag(i)) ) ! node*cos(lat) bias correction term + call nc_diag_metadata_to_single("BCPred_Sine_Latitude",pred(7,ich_diag(i)) ) ! sin(lat) bias correction term + call nc_diag_metadata_to_single("BCPred_Emissivity",pred(8,ich_diag(i)) ) ! emissivity sensitivity bias correction term endif if (lwrite_peakwt) then - call screen_to_single_nc_diag_metadata("Press_Max_Weight_Function",(weightmax(ich_diag(i))) ) + call nc_diag_metadata_to_single("Press_Max_Weight_Function",weightmax(ich_diag(i)) ) endif if (adp_anglebc) then do j=1, angord diff --git a/src/gsi/setuprw.f90 b/src/gsi/setuprw.f90 index 11788491f1..f987a8de74 100644 --- a/src/gsi/setuprw.f90 +++ b/src/gsi/setuprw.f90 @@ -117,7 +117,7 @@ subroutine setuprw(obsLL,odiagLL,lunin,mype,bwork,awork,nele,nobs,is,conv_diagsa doradaroneob,oneobddiff,oneobvalue, if_vrobs_raw use obsmod, only: netcdf_diag, binary_diag, dirname,ianldate use nc_diag_write_mod, only: nc_diag_init, nc_diag_header, nc_diag_metadata, & - nc_diag_write, nc_diag_data2d + nc_diag_write, nc_diag_data2d, nc_diag_metadata_to_single use nc_diag_read_mod, only: nc_diag_read_init, nc_diag_read_get_dim, nc_diag_read_close use m_obsNode, only: obsNode use m_rwNode, only: rwNode @@ -1311,8 +1311,6 @@ subroutine contents_binary_diag_(odiag) end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_(odiag) - use constants, only: r_missing - use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' rw' @@ -1321,38 +1319,30 @@ subroutine contents_netcdf_diag_(odiag) call nc_diag_metadata("Observation_Class", obsclass ) call nc_diag_metadata("Observation_Type", ictype(ikx) ) call nc_diag_metadata("Observation_Subtype", icsubtype(ikx) ) - call screen_to_single_nc_diag_metadata("Latitude",(data(ilate,i)) ) - call screen_to_single_nc_diag_metadata("Longitude",(data(ilone,i)) ) - call screen_to_single_nc_diag_metadata("Station_Elevation",(data(ielev,i)) ) - call screen_to_single_nc_diag_metadata("Pressure",(presw) ) - call screen_to_single_nc_diag_metadata("Height",(data(ihgt,i)) ) - if(isnan(dtime) .or. isnan(time_offset)) then - call nc_diag_metadata("Time",sngl(real(r_missing))) - else - call nc_diag_metadata("Time",sngl(dtime-time_offset)) - endif - call nc_diag_metadata("Prep_QC_Mark", sngl(zero) ) - call screen_to_single_nc_diag_metadata("Prep_Use_Flag",(data(iuse,i)) ) + call nc_diag_metadata_to_single("Latitude",data(ilate,i) ) + call nc_diag_metadata_to_single("Longitude",data(ilone,i) ) + call nc_diag_metadata_to_single("Station_Elevation",data(ielev,i) ) + call nc_diag_metadata_to_single("Pressure",presw ) + call nc_diag_metadata_to_single("Height",data(ihgt,i) ) + call nc_diag_metadata_to_single("Time",dtime,time_offset,'-') + call nc_diag_metadata("Prep_QC_Mark", 0.0_r_single ) + call nc_diag_metadata_to_single("Prep_Use_Flag",data(iuse,i) ) ! call nc_diag_metadata("Nonlinear_QC_Var_Jb", var_jb ) - call screen_to_single_nc_diag_metadata("Nonlinear_QC_Rel_Wgt",(rwgt) ) + call nc_diag_metadata_to_single("Nonlinear_QC_Rel_Wgt",rwgt ) if(muse(i)) then - call nc_diag_metadata("Analysis_Use_Flag", sngl(one) ) + call nc_diag_metadata("Analysis_Use_Flag", 1.0_r_single ) else - call nc_diag_metadata("Analysis_Use_Flag", sngl(-one) ) + call nc_diag_metadata("Analysis_Use_Flag", -1.0_r_single ) endif - call screen_to_single_nc_diag_metadata("Errinv_Input",(errinv_input) ) - call screen_to_single_nc_diag_metadata("Errinv_Adjust",(errinv_adjst) ) - call screen_to_single_nc_diag_metadata("Errinv_Final",(errinv_final) ) + call nc_diag_metadata_to_single("Errinv_Input",errinv_input ) + call nc_diag_metadata_to_single("Errinv_Adjust",errinv_adjst ) + call nc_diag_metadata_to_single("Errinv_Final",errinv_final ) + + call nc_diag_metadata_to_single("Observation",data(irwob,i) ) + call nc_diag_metadata_to_single("Obs_Minus_Forecast_adjusted",ddiff ) + call nc_diag_metadata_to_single("Obs_Minus_Forecast_unadjusted",data(irwob,i),rwwind,'-') - call screen_to_single_nc_diag_metadata("Observation",(data(irwob,i)) ) - call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_adjusted",(ddiff) ) - if(isnan(data(irwob,i)) .or. isnan(rwwind)) then - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(real(r_missing))) - else - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(data(irwob,i)-rwwind) ) - endif - if (lobsdiagsave) then do jj=1,miter if (odiag%muse(jj)) then @@ -1361,18 +1351,18 @@ subroutine contents_netcdf_diag_(odiag) obsdiag_iuse(jj) = -one endif enddo - + call nc_diag_data2d("ObsDiagSave_iuse", obsdiag_iuse ) call nc_diag_data2d("ObsDiagSave_nldepart", odiag%nldepart ) call nc_diag_data2d("ObsDiagSave_tldepart", odiag%tldepart ) - call nc_diag_data2d("ObsDiagSave_obssen", odiag%obssen ) + call nc_diag_data2d("ObsDiagSave_obssen", odiag%obssen ) endif if (save_jacobian) then call nc_diag_data2d("Observation_Operator_Jacobian_stind", dhx_dx%st_ind) call nc_diag_data2d("Observation_Operator_Jacobian_endind", dhx_dx%end_ind) call nc_diag_data2d("Observation_Operator_Jacobian_val", real(dhx_dx%val,r_single)) endif - + end subroutine contents_netcdf_diag_ subroutine final_vars_ diff --git a/src/gsi/setupspd.f90 b/src/gsi/setupspd.f90 index f4efa4b28f..64366394cb 100644 --- a/src/gsi/setupspd.f90 +++ b/src/gsi/setupspd.f90 @@ -114,7 +114,7 @@ subroutine setupspd(obsLL,odiagLL,lunin,mype,bwork,awork,nele,nobs,is,conv_diags use obsmod, only: netcdf_diag, binary_diag, dirname, ianldate use obsmod, only: l_obsprvdiag use nc_diag_write_mod, only: nc_diag_init, nc_diag_header, nc_diag_metadata, & - nc_diag_write, nc_diag_data2d + nc_diag_write, nc_diag_data2d, nc_diag_metadata_to_single use nc_diag_read_mod, only: nc_diag_read_init, nc_diag_read_get_dim, nc_diag_read_close use m_obsNode, only: obsNode use m_spdNode, only: spdNode @@ -941,8 +941,6 @@ subroutine contents_binary_diag_(odiag) end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_(odiag) - use constants, only: r_missing - use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' spd' @@ -951,37 +949,29 @@ subroutine contents_netcdf_diag_(odiag) call nc_diag_metadata("Observation_Class", obsclass ) call nc_diag_metadata("Observation_Type", ictype(ikx) ) call nc_diag_metadata("Observation_Subtype", icsubtype(ikx) ) - call screen_to_single_nc_diag_metadata("Latitude",(data(ilate,i)) ) - call screen_to_single_nc_diag_metadata("Longitude",(data(ilone,i)) ) - call screen_to_single_nc_diag_metadata("Station_Elevation",(data(istnelv,i)) ) - call screen_to_single_nc_diag_metadata("Pressure",(presw) ) - call screen_to_single_nc_diag_metadata("Height",(data(ihgt,i)) ) - if(isnan(dtime) .or. isnan(time_offset)) then - call nc_diag_metadata("Time",sngl(real(r_missing))) - else - call nc_diag_metadata("Time",sngl(dtime-time_offset)) - endif - call screen_to_single_nc_diag_metadata("Prep_QC_Mark",(data(iqc,i)) ) - call screen_to_single_nc_diag_metadata("Prep_Use_Flag",(data(iuse,i)) ) + call nc_diag_metadata_to_single("Latitude",data(ilate,i) ) + call nc_diag_metadata_to_single("Longitude",data(ilone,i) ) + call nc_diag_metadata_to_single("Station_Elevation",data(istnelv,i) ) + call nc_diag_metadata_to_single("Pressure",presw ) + call nc_diag_metadata_to_single("Height",data(ihgt,i) ) + call nc_diag_metadata_to_single("Time",dtime,time_offset,'-') + call nc_diag_metadata_to_single("Prep_QC_Mark",data(iqc,i) ) + call nc_diag_metadata_to_single("Prep_Use_Flag",data(iuse,i) ) ! call nc_diag_metadata("Nonlinear_QC_Var_Jb", var_jb ) - call screen_to_single_nc_diag_metadata("Nonlinear_QC_Rel_Wgt",(rwgt) ) + call nc_diag_metadata_to_single("Nonlinear_QC_Rel_Wgt",rwgt ) if(muse(i)) then - call nc_diag_metadata("Analysis_Use_Flag", sngl(one) ) + call nc_diag_metadata("Analysis_Use_Flag", 1.0_r_single ) else - call nc_diag_metadata("Analysis_Use_Flag", sngl(-one) ) + call nc_diag_metadata("Analysis_Use_Flag", 1.0_r_single ) endif - call screen_to_single_nc_diag_metadata("Errinv_Input",(errinv_input) ) - call screen_to_single_nc_diag_metadata("Errinv_Adjust",(errinv_adjst) ) - call screen_to_single_nc_diag_metadata("Errinv_Final",(errinv_final) ) + call nc_diag_metadata_to_single("Errinv_Input",errinv_input ) + call nc_diag_metadata_to_single("Errinv_Adjust",errinv_adjst ) + call nc_diag_metadata_to_single("Errinv_Final",errinv_final ) - call screen_to_single_nc_diag_metadata("Observation",(spdob) ) - call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_adjusted",(ddiff) ) - if(isnan(spdob0) .or. isnan(spdges)) then - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(real(r_missing))) - else - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(spdob0-spdges) ) - endif + call nc_diag_metadata_to_single("Observation",spdob ) + call nc_diag_metadata_to_single("Obs_Minus_Forecast_adjusted",ddiff ) + call nc_diag_metadata_to_single("Obs_Minus_Forecast_unadjusted", spdob0,spdges,'-') if (lobsdiagsave) then do jj=1,miter diff --git a/src/gsi/setupsst.f90 b/src/gsi/setupsst.f90 index cce6023c3b..27d08daa86 100644 --- a/src/gsi/setupsst.f90 +++ b/src/gsi/setupsst.f90 @@ -99,7 +99,7 @@ subroutine setupsst(obsLL,odiagLL,lunin,mype,bwork,awork,nele,nobs,is,conv_diags use obsmod, only: luse_obsdiag use obsmod, only: netcdf_diag, binary_diag, dirname,ianldate use nc_diag_write_mod, only: nc_diag_init, nc_diag_header, nc_diag_metadata, & - nc_diag_write, nc_diag_data2d + nc_diag_write, nc_diag_data2d, nc_diag_metadata_to_single use nc_diag_read_mod, only: nc_diag_read_init, nc_diag_read_get_dim, nc_diag_read_close use gsi_4dvar, only: nobs_bins,hr_obsbin use oneobmod, only: magoberr,maginnov,oneobtest @@ -576,7 +576,6 @@ subroutine contents_binary_diag_(odiag) endif end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_(odiag) - use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' sst' @@ -586,43 +585,35 @@ subroutine contents_netcdf_diag_(odiag) call nc_diag_metadata("Observation_Class", obsclass ) call nc_diag_metadata("Observation_Type", ictype(ikx) ) call nc_diag_metadata("Observation_Subtype", icsubtype(ikx) ) - call screen_to_single_nc_diag_metadata("Latitude",(data(ilate,i)) ) - call screen_to_single_nc_diag_metadata("Longitude",(data(ilone,i)) ) - call screen_to_single_nc_diag_metadata("Station_Elevation",(data(istnelv,i)) ) + call nc_diag_metadata_to_single("Latitude",data(ilate,i) ) + call nc_diag_metadata_to_single("Longitude",data(ilone,i) ) + call nc_diag_metadata_to_single("Station_Elevation",data(istnelv,i) ) call nc_diag_metadata("Pressure", missing ) - call screen_to_single_nc_diag_metadata("Height",(data(izob,i)) ) - if(isnan(dtime) .or. isnan(time_offset)) then - call nc_diag_metadata("Time",sngl(real(r_missing))) - else - call nc_diag_metadata("Time",sngl(dtime-time_offset)) - endif - call screen_to_single_nc_diag_metadata("Prep_QC_Mark",(data(ipct,i)) ) - call screen_to_single_nc_diag_metadata("Prep_Use_Flag",(data(iuse,i)) ) + call nc_diag_metadata_to_single("Height",data(izob,i) ) + call nc_diag_metadata_to_single("Time",dtime,time_offset,'-') + call nc_diag_metadata_to_single("Prep_QC_Mark",data(ipct,i) ) + call nc_diag_metadata_to_single("Prep_Use_Flag",data(iuse,i) ) ! call nc_diag_metadata("Nonlinear_QC_Var_Jb", var_jb ) - call screen_to_single_nc_diag_metadata("Nonlinear_QC_Rel_Wgt",(rwgt) ) + call nc_diag_metadata_to_single("Nonlinear_QC_Rel_Wgt",rwgt ) if(muse(i)) then - call nc_diag_metadata("Analysis_Use_Flag", sngl(one) ) + call nc_diag_metadata("Analysis_Use_Flag", 1.0_r_single ) else - call nc_diag_metadata("Analysis_Use_Flag", sngl(-one) ) + call nc_diag_metadata("Analysis_Use_Flag", -1.0_r_single ) endif - call screen_to_single_nc_diag_metadata("Errinv_Input",(errinv_input) ) - call screen_to_single_nc_diag_metadata("Errinv_Adjust",(errinv_adjst) ) - call screen_to_single_nc_diag_metadata("Errinv_Final",(errinv_final) ) + call nc_diag_metadata_to_single("Errinv_Input",errinv_input ) + call nc_diag_metadata_to_single("Errinv_Adjust",errinv_adjst ) + call nc_diag_metadata_to_single("Errinv_Final",errinv_final ) - call screen_to_single_nc_diag_metadata("Observation",(data(isst,i)) ) - call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_adjusted",(ddiff) ) - if(isnan(data(isst,i)) .or. isnan(sstges)) then - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(real(r_missing))) - else - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(data(isst,i)-sstges)) - endif + call nc_diag_metadata_to_single("Observation",data(isst,i) ) + call nc_diag_metadata_to_single("Obs_Minus_Forecast_adjusted",ddiff ) + call nc_diag_metadata_to_single("Obs_Minus_Forecast_unadjusted",data(isst,i),sstges,'-') if (nst_gsi>0) then - call screen_to_single_nc_diag_metadata("FoundationTempBG",(data(itref,i)) ) - call screen_to_single_nc_diag_metadata("DiurnalWarming_at_zob",(data(idtw,i)) ) - call screen_to_single_nc_diag_metadata("SkinLayerCooling_at_zob",(data(idtw,i)) ) - call screen_to_single_nc_diag_metadata("Sensitivity_Tzob_Tr",(data(itz_tr,i)) ) + call nc_diag_metadata_to_single("FoundationTempBG",data(itref,i) ) + call nc_diag_metadata_to_single("DiurnalWarming_at_zob",data(idtw,i) ) + call nc_diag_metadata_to_single("SkinLayerCooling_at_zob",data(idtw,i) ) + call nc_diag_metadata_to_single("Sensitivity_Tzob_Tr",data(itz_tr,i) ) endif if (lobsdiagsave) then diff --git a/src/gsi/setupswcp.f90 b/src/gsi/setupswcp.f90 index 5e94f35dc4..6797357103 100644 --- a/src/gsi/setupswcp.f90 +++ b/src/gsi/setupswcp.f90 @@ -67,7 +67,7 @@ subroutine setupswcp(obsLL,odiagLL,lunin,mype,bwork,awork,nele,nobs,is,conv_diag use obsmod, only: netcdf_diag, binary_diag, dirname use nc_diag_write_mod, only: nc_diag_init, nc_diag_header,nc_diag_metadata, & - nc_diag_write, nc_diag_data2d + nc_diag_write, nc_diag_data2d, nc_diag_metadata_to_single use nc_diag_read_mod, only: nc_diag_read_init,nc_diag_read_get_dim,nc_diag_read_close use state_vectors, only: svars3d, levels @@ -882,8 +882,6 @@ subroutine contents_binary_diag_(odiag) end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_(odiag) - use constants, only: r_missing - use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' swcp' @@ -895,36 +893,28 @@ subroutine contents_netcdf_diag_(odiag) call nc_diag_metadata("Observation_Class", obsclass ) call nc_diag_metadata("Observation_Type", ictype(ikx) ) call nc_diag_metadata("Observation_Subtype", icsubtype(ikx) ) - call screen_to_single_nc_diag_metadata("Latitude",(data(ilate,i)) ) - call screen_to_single_nc_diag_metadata("Longitude",(data(ilone,i)) ) - call screen_to_single_nc_diag_metadata("Station_Elevation",(data(istnelv,i)) ) - call screen_to_single_nc_diag_metadata("Pressure",(data(iobsprs,i)) ) - call screen_to_single_nc_diag_metadata("Height",(data(iobshgt,i)) ) - if(isnan(dtime) .or. isnan(time_offset)) then - call nc_diag_metadata("Time",sngl(real(r_missing))) - else - call nc_diag_metadata("Time",sngl(dtime-time_offset)) - endif - call screen_to_single_nc_diag_metadata("Prep_QC_Mark",(data(iqc,i)) ) - call nc_diag_metadata("Setup_QC_Mark",(rmiss_single) ) - call screen_to_single_nc_diag_metadata("Prep_Use_Flag",(data(iuse,i)) ) + call nc_diag_metadata_to_single("Latitude",data(ilate,i) ) + call nc_diag_metadata_to_single("Longitude",data(ilone,i) ) + call nc_diag_metadata_to_single("Station_Elevation",data(istnelv,i) ) + call nc_diag_metadata_to_single("Pressure",data(iobsprs,i) ) + call nc_diag_metadata_to_single("Height",data(iobshgt,i) ) + call nc_diag_metadata_to_single("Time",dtime,time_offset,'-') + call nc_diag_metadata_to_single("Prep_QC_Mark",data(iqc,i) ) + call nc_diag_metadata("Setup_QC_Mark",rmiss_single ) + call nc_diag_metadata_to_single("Prep_Use_Flag",data(iuse,i) ) if(muse(i)) then call nc_diag_metadata("Analysis_Use_Flag", sngl(one) ) else call nc_diag_metadata("Analysis_Use_Flag", sngl(-one) ) endif - call screen_to_single_nc_diag_metadata("Nonlinear_QC_Rel_Wgt",(rwgt) ) - call screen_to_single_nc_diag_metadata("Errinv_Input",(errinv_input) ) - call screen_to_single_nc_diag_metadata("Errinv_Adjust",(errinv_adjst) ) - call screen_to_single_nc_diag_metadata("Errinv_Final",(errinv_final) ) - call screen_to_single_nc_diag_metadata("Observation",(dswcp) ) - call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_adjusted",(ddiff) ) - if(isnan(dswcp) .or. isnan(swcpges)) then - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(real(r_missing))) - else - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(dswcp-swcpges)) - endif + call nc_diag_metadata_to_single("Nonlinear_QC_Rel_Wgt",rwgt ) + call nc_diag_metadata_to_single("Errinv_Input",errinv_input ) + call nc_diag_metadata_to_single("Errinv_Adjust",errinv_adjst ) + call nc_diag_metadata_to_single("Errinv_Final",errinv_final ) + call nc_diag_metadata_to_single("Observation",dswcp ) + call nc_diag_metadata_to_single("Obs_Minus_Forecast_adjusted",ddiff ) + call nc_diag_metadata_to_single("Obs_Minus_Forecast_unadjusted", dswcp,swcpges,'-') if (lobsdiagsave) then do jj=1,miter diff --git a/src/gsi/setupt.f90 b/src/gsi/setupt.f90 index bb6dfcf569..f33dcf69df 100644 --- a/src/gsi/setupt.f90 +++ b/src/gsi/setupt.f90 @@ -42,7 +42,7 @@ subroutine setupt(obsLL,odiagLL,lunin,mype,bwork,awork,nele,nobs,is,conv_diagsav use obsmod, only: netcdf_diag, binary_diag, dirname use obsmod, only: l_obsprvdiag use nc_diag_write_mod, only: nc_diag_init, nc_diag_header, nc_diag_metadata, & - nc_diag_write, nc_diag_data2d + nc_diag_write, nc_diag_data2d, nc_diag_metadata_to_single use nc_diag_read_mod, only: nc_diag_read_init, nc_diag_read_get_dim, nc_diag_read_close use qcmod, only: npres_print,dfact,dfact1,ptop,pbot,buddycheck_t @@ -63,7 +63,7 @@ subroutine setupt(obsLL,odiagLL,lunin,mype,bwork,awork,nele,nobs,is,conv_diagsav use constants, only: zero, one, four,t0c,rd_over_cp,three,rd_over_cp_mass,ten use constants, only: tiny_r_kind,half,two use constants, only: huge_single,r1000,wgtlim,r10,fv - use constants, only: one_quad, r_missing + use constants, only: one_quad use convinfo, only: nconvtype,cermin,cermax,cgross,cvar_b,cvar_pg,ictype,icsubtype use convinfo, only: ibeta,ikapa use converr_t, only: ptabl_t @@ -1663,7 +1663,6 @@ subroutine contents_binary_diagp_(odiag) end subroutine contents_binary_diagp_ subroutine contents_netcdf_diag_(odiag) - use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' t' @@ -1675,44 +1674,36 @@ subroutine contents_netcdf_diag_(odiag) call nc_diag_metadata("Observation_Class", obsclass ) call nc_diag_metadata("Observation_Type", ictype(ikx) ) call nc_diag_metadata("Observation_Subtype", icsubtype(ikx) ) - call screen_to_single_nc_diag_metadata("Latitude",data(ilate,i)) - call screen_to_single_nc_diag_metadata("Longitude",data(ilone,i)) - call screen_to_single_nc_diag_metadata("Station_Elevation",data(istnelv,i)) - call screen_to_single_nc_diag_metadata("Pressure",prest) - call screen_to_single_nc_diag_metadata("Height",data(iobshgt,i)) - if(isnan(dtime) .or. isnan(time_offset)) then - call nc_diag_metadata("Time",sngl(real(r_missing))) - else - call nc_diag_metadata("Time",sngl(dtime-time_offset)) - endif - call screen_to_single_nc_diag_metadata("Prep_QC_Mark",data(iqc,i)) - call screen_to_single_nc_diag_metadata("Setup_QC_Mark",data(iqt,i)) - call screen_to_single_nc_diag_metadata("Prep_Use_Flag",data(iuse,i)) + call nc_diag_metadata_to_single("Latitude",data(ilate,i)) + call nc_diag_metadata_to_single("Longitude",data(ilone,i)) + call nc_diag_metadata_to_single("Station_Elevation",data(istnelv,i)) + call nc_diag_metadata_to_single("Pressure",prest) + call nc_diag_metadata_to_single("Height",data(iobshgt,i)) + call nc_diag_metadata_to_single("Time",dtime,time_offset,'-') + call nc_diag_metadata_to_single("Prep_QC_Mark",data(iqc,i)) + call nc_diag_metadata_to_single("Setup_QC_Mark",data(iqt,i)) + call nc_diag_metadata_to_single("Prep_Use_Flag",data(iuse,i)) if(muse(i)) then call nc_diag_metadata("Analysis_Use_Flag", sngl(one) ) else call nc_diag_metadata("Analysis_Use_Flag", sngl(-one) ) endif - call screen_to_single_nc_diag_metadata("Nonlinear_QC_Rel_Wgt",rwgt) - call screen_to_single_nc_diag_metadata("Errinv_Input",errinv_input ) - call screen_to_single_nc_diag_metadata("Errinv_Adjust",errinv_adjst ) - call screen_to_single_nc_diag_metadata("Errinv_Final",errinv_final ) - call screen_to_single_nc_diag_metadata("Observation",data(itob,i)) - call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_adjusted",ddiff ) - if(isnan(tob) .or. isnan(tges)) then - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(real(r_missing)) ) - else - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(tob-tges) ) - endif + call nc_diag_metadata_to_single("Nonlinear_QC_Rel_Wgt",rwgt) + call nc_diag_metadata_to_single("Errinv_Input",errinv_input ) + call nc_diag_metadata_to_single("Errinv_Adjust",errinv_adjst ) + call nc_diag_metadata_to_single("Errinv_Final",errinv_final ) + call nc_diag_metadata_to_single("Observation",data(itob,i)) + call nc_diag_metadata_to_single("Obs_Minus_Forecast_adjusted",ddiff ) + call nc_diag_metadata_to_single("Obs_Minus_Forecast_unadjusted",tob,tges,'-') if (aircraft_t_bc_pof .or. aircraft_t_bc .or. aircraft_t_bc_ext) then - call screen_to_single_nc_diag_metadata("Data_Pof",data(ipof,i)) - call screen_to_single_nc_diag_metadata("Data_Vertical_Velocity",data(ivvlc,i)) + call nc_diag_metadata_to_single("Data_Pof",data(ipof,i)) + call nc_diag_metadata_to_single("Data_Vertical_Velocity",data(ivvlc,i)) if (npredt .gt. one) then call nc_diag_data2d("Bias_Correction_Terms", sngl(predbias) ) else if (npredt .eq. one) then - call screen_to_single_nc_diag_metadata("Bias_Correction_Terms",predbias(1)) + call nc_diag_metadata_to_single("Bias_Correction_Terms",predbias(1)) endif else call nc_diag_metadata("Data_Pof", missing ) @@ -1760,48 +1751,41 @@ subroutine contents_netcdf_diag_(odiag) end subroutine contents_netcdf_diag_ subroutine contents_netcdf_diagp_(odiag) - use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' t' real(r_single),parameter:: missing = -9.99e9_r_single real(r_kind),dimension(miter) :: obsdiag_iuse + real(r_kind) :: var_jb_m call nc_diag_metadata("Station_ID", station_id ) call nc_diag_metadata("Observation_Class", obsclass ) call nc_diag_metadata("Observation_Type", ictype(ikx) ) call nc_diag_metadata("Observation_Subtype", -1 ) ! (-1 for pseudo obs sub-type) - call screen_to_single_nc_diag_metadata("Latitude",data(ilate,i)) - call screen_to_single_nc_diag_metadata("Longitude",data(ilone,i)) - call screen_to_single_nc_diag_metadata("Station_Elevation",data(istnelv,i)) - call screen_to_single_nc_diag_metadata("Pressure",prest) - call screen_to_single_nc_diag_metadata("Height",data(iobshgt,i)) - if(isnan(dtime) .or. isnan(time_offset)) then - call nc_diag_metadata("Time",sngl(real(r_missing))) - else - call nc_diag_metadata("Time",sngl(dtime-time_offset)) - endif - call screen_to_single_nc_diag_metadata("Prep_QC_Mark",data(iqc,i)) - call screen_to_single_nc_diag_metadata("Setup_QC_Mark",data(iqt,i)) - call screen_to_single_nc_diag_metadata("Prep_Use_Flag",data(iuse,i)) + call nc_diag_metadata_to_single("Latitude",data(ilate,i)) + call nc_diag_metadata_to_single("Longitude",data(ilone,i)) + call nc_diag_metadata_to_single("Station_Elevation",data(istnelv,i)) + call nc_diag_metadata_to_single("Pressure",prest) + call nc_diag_metadata_to_single("Height",data(iobshgt,i)) + call nc_diag_metadata_to_single("Time",dtime,time_offset,'-') + call nc_diag_metadata_to_single("Prep_QC_Mark",data(iqc,i)) + call nc_diag_metadata_to_single("Setup_QC_Mark",data(iqt,i)) + call nc_diag_metadata_to_single("Prep_Use_Flag",data(iuse,i)) if(muse(i)) then call nc_diag_metadata("Analysis_Use_Flag", sngl(one) ) else call nc_diag_metadata("Analysis_Use_Flag", sngl(-one) ) endif - if(isnan(var_jb) .or. isnan(rwgt)) then - call nc_diag_metadata("Nonlinear_QC_Rel_Wgt",sngl(real(r_missing))) - else - call nc_diag_metadata("Nonlinear_QC_Rel_Wgt",sngl(var_jb*1.0e+6+rwgt)) - endif - call screen_to_single_nc_diag_metadata("Errinv_Input",errinv_input ) - call screen_to_single_nc_diag_metadata("Errinv_Adjust",errinv_adjst ) - call screen_to_single_nc_diag_metadata("Errinv_Final",errinv_final ) - call screen_to_single_nc_diag_metadata("Observation",data(itob,i)) - call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_adjusted",ddiff ) - call screen_to_single_nc_diag_metadata("Obs_Minus_Forecast_unadjusted",ddiff ) + var_jb_m = var_jb * 1.0e+6 + call nc_diag_metadata_to_single("Nonlinear_QC_Rel_Wgt",var_jb_m,rwgt,'-') + call nc_diag_metadata_to_single("Errinv_Input",errinv_input ) + call nc_diag_metadata_to_single("Errinv_Adjust",errinv_adjst ) + call nc_diag_metadata_to_single("Errinv_Final",errinv_final ) + call nc_diag_metadata_to_single("Observation",data(itob,i)) + call nc_diag_metadata_to_single("Obs_Minus_Forecast_adjusted",ddiff ) + call nc_diag_metadata_to_single("Obs_Minus_Forecast_unadjusted",ddiff ) !---- if (lobsdiagsave) then diff --git a/src/gsi/setuptcp.f90 b/src/gsi/setuptcp.f90 index bdb79010bf..3d13c5fe8e 100644 --- a/src/gsi/setuptcp.f90 +++ b/src/gsi/setuptcp.f90 @@ -57,7 +57,7 @@ subroutine setuptcp(obsLL,odiagLL,lunin,mype,bwork,awork,nele,nobs,is,conv_diags time_offset,rmiss_single,lobsdiagsave,lobsdiag_forenkf,ianldate use obsmod, only: netcdf_diag, binary_diag, dirname use nc_diag_write_mod, only: nc_diag_init, nc_diag_header, nc_diag_metadata, & - nc_diag_write, nc_diag_data2d + nc_diag_write, nc_diag_data2d, nc_diag_metadata_to_single use nc_diag_read_mod, only: nc_diag_read_init, nc_diag_read_get_dim, nc_diag_read_close use m_obsNode, only: obsNode use m_tcpNode, only: tcpNode @@ -684,8 +684,6 @@ subroutine contents_binary_diag_(odiag) end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_(odiag) - use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata - use constants, only: r_missing type(obs_diag),pointer,intent(in):: odiag ! Observation class character(7),parameter :: obsclass = ' tcp' @@ -694,45 +692,29 @@ subroutine contents_netcdf_diag_(odiag) call nc_diag_metadata("Observation_Class", obsclass ) call nc_diag_metadata("Observation_Type", ictype(ikx) ) call nc_diag_metadata("Observation_Subtype", icsubtype(ikx) ) - call screen_to_single_nc_diag_metadata("Latitude",(data(ilate,i)) ) - call screen_to_single_nc_diag_metadata("Longitude",(data(ilone,i)) ) + call nc_diag_metadata_to_single("Latitude",data(ilate,i) ) + call nc_diag_metadata_to_single("Longitude",data(ilone,i) ) call nc_diag_metadata("Station_Elevation", sngl(zero) ) - if(isnan(data(ipres,i))) then - call nc_diag_metadata("Pressure",sngl(real(r_missing))) - else - call nc_diag_metadata("Pressure", sngl(data(ipres,i)*r10)) - endif - call screen_to_single_nc_diag_metadata("Height",(zero) ) - if(isnan(dtime) .or. isnan(time_offset)) then - call nc_diag_metadata("Time",sngl(real(r_missing))) - else - call nc_diag_metadata("Time",sngl(dtime-time_offset)) - endif + call nc_diag_metadata_to_single("Pressure", data(ipres,i),r10,'*') + call nc_diag_metadata_to_single("Height",zero ) + call nc_diag_metadata_to_single("Time",dtime,time_offset,'-') call nc_diag_metadata("Prep_QC_Mark", sngl(one) ) call nc_diag_metadata("Prep_Use_Flag", sngl(one) ) - call screen_to_single_nc_diag_metadata("Nonlinear_QC_Rel_Wgt",(rwgt) ) + call nc_diag_metadata_to_single("Nonlinear_QC_Rel_Wgt",(rwgt) ) if(muse(i)) then call nc_diag_metadata("Analysis_Use_Flag", sngl(one) ) else - call nc_diag_metadata("Analysis_Use_Flag", sngl(-one) ) + call nc_diag_metadata("Analysis_Use_Flag", sngl(-one) ) endif - call screen_to_single_nc_diag_metadata("Errinv_Input",(errinv_input) ) - call screen_to_single_nc_diag_metadata("Errinv_Adjust",(errinv_adjst) ) - call screen_to_single_nc_diag_metadata("Errinv_Final",(errinv_final) ) + call nc_diag_metadata_to_single("Errinv_Input",errinv_input ) + call nc_diag_metadata_to_single("Errinv_Adjust",errinv_adjst ) + call nc_diag_metadata_to_single("Errinv_Final",errinv_final ) - call screen_to_single_nc_diag_metadata("Observation",(pob) ) - if(isnan(pob) .or. isnan(pges)) then - call nc_diag_metadata("Obs_Minus_Forecast_adjusted", sngl(real(r_missing))) - else - call nc_diag_metadata("Obs_Minus_Forecast_adjusted", sngl(pob-pges) ) - endif + call nc_diag_metadata_to_single("Observation",pob ) + call nc_diag_metadata_to_single("Obs_Minus_Forecast_adjusted",pob,pges,'-') - if(isnan(pob) .or. isnan(pgesorig)) then - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(real(r_missing))) - else - call nc_diag_metadata("Obs_Minus_Forecast_unadjusted", sngl(pob-pgesorig)) - endif + call nc_diag_metadata_to_single("Obs_Minus_Forecast_unadjusted",pob,pgesorig,'-') if (lobsdiagsave) then do jj=1,miter diff --git a/src/gsi/setupw.f90 b/src/gsi/setupw.f90 index e094981754..63ff81dd30 100644 --- a/src/gsi/setupw.f90 +++ b/src/gsi/setupw.f90 @@ -44,7 +44,7 @@ subroutine setupw(obsLL,odiagLL,lunin,mype,bwork,awork,nele,nobs,is,conv_diagsav use obsmod, only: l_obsprvdiag use obsmod, only: neutral_stability_windfact_2dvar,use_similarity_2dvar use nc_diag_write_mod, only: nc_diag_init, nc_diag_header, nc_diag_metadata, & - nc_diag_write, nc_diag_data2d + nc_diag_write, nc_diag_data2d, nc_diag_metadata_to_single use nc_diag_read_mod, only: nc_diag_read_init, nc_diag_read_get_dim, nc_diag_read_close use gsi_4dvar, only: nobs_bins,hr_obsbin,min_offset use qcmod, only: npres_print,ptop,pbot,dfact,dfact1,qc_satwnds,njqc,vqc @@ -1779,8 +1779,6 @@ subroutine contents_binary_diag_(udiag,vdiag) end subroutine contents_binary_diag_ subroutine contents_netcdf_diag_(udiag,vdiag) - use constants, only: r_missing - use screen_to_ncdiag, only: screen_to_single_nc_diag_metadata type(obs_diag),pointer,intent(in):: udiag,vdiag ! Observation class character(7),parameter :: obsclass = ' uv' @@ -1790,49 +1788,37 @@ subroutine contents_netcdf_diag_(udiag,vdiag) call nc_diag_metadata("Observation_Class", obsclass ) call nc_diag_metadata("Observation_Type", ictype(ikx) ) call nc_diag_metadata("Observation_Subtype", icsubtype(ikx) ) - call screen_to_single_nc_diag_metadata("Latitude",(data(ilate,i)) ) - call screen_to_single_nc_diag_metadata("Longitude",(data(ilone,i)) ) - call screen_to_single_nc_diag_metadata("Station_Elevation",(data(ielev,i)) ) - call screen_to_single_nc_diag_metadata("Pressure",(presw) ) - call screen_to_single_nc_diag_metadata("Height",(data(ihgt,i)) ) - if(isnan(dtime) .or. isnan(time_offset)) then - call nc_diag_metadata("Time",sngl(real(r_missing))) - else - call nc_diag_metadata("Time",sngl(dtime-time_offset)) - endif - call screen_to_single_nc_diag_metadata("Prep_QC_Mark",(data(iqc,i)) ) + call nc_diag_metadata_to_single("Latitude",data(ilate,i) ) + call nc_diag_metadata_to_single("Longitude",data(ilone,i) ) + call nc_diag_metadata_to_single("Station_Elevation",data(ielev,i) ) + call nc_diag_metadata_to_single("Pressure",presw ) + call nc_diag_metadata_to_single("Height",data(ihgt,i) ) + call nc_diag_metadata_to_single("Time",dtime,time_offset,'-') + call nc_diag_metadata_to_single("Prep_QC_Mark",data(iqc,i) ) ! call nc_diag_metadata("Setup_QC_Mark", rmiss_single ) - call screen_to_single_nc_diag_metadata("Setup_QC_Mark",(bmiss) ) - call screen_to_single_nc_diag_metadata("Nonlinear_QC_Var_Jb",(var_jb) ) - call screen_to_single_nc_diag_metadata("Prep_Use_Flag",(data(iuse,i)) ) + call nc_diag_metadata_to_single("Setup_QC_Mark",bmiss ) + call nc_diag_metadata_to_single("Nonlinear_QC_Var_Jb",var_jb ) + call nc_diag_metadata_to_single("Prep_Use_Flag",data(iuse,i) ) if(muse(i)) then call nc_diag_metadata("Analysis_Use_Flag", sngl(one) ) else call nc_diag_metadata("Analysis_Use_Flag", sngl(-one) ) endif - call screen_to_single_nc_diag_metadata("Nonlinear_QC_Rel_Wgt",(rwgt) ) - call screen_to_single_nc_diag_metadata("Errinv_Input",(errinv_input) ) - call screen_to_single_nc_diag_metadata("Errinv_Adjust",(errinv_adjst) ) - call screen_to_single_nc_diag_metadata("Errinv_Final",(errinv_final) ) - call screen_to_single_nc_diag_metadata("Wind_Reduction_Factor_at_10m",(factw)) + call nc_diag_metadata_to_single("Nonlinear_QC_Rel_Wgt",rwgt ) + call nc_diag_metadata_to_single("Errinv_Input",errinv_input ) + call nc_diag_metadata_to_single("Errinv_Adjust",errinv_adjst ) + call nc_diag_metadata_to_single("Errinv_Final",errinv_final ) + call nc_diag_metadata_to_single("Wind_Reduction_Factor_at_10m",factw ) if (.not. regional .or. fv3_regional) then - call screen_to_single_nc_diag_metadata("u_Observation",(data(iuob,i)) ) - call screen_to_single_nc_diag_metadata("u_Obs_Minus_Forecast_adjusted",(dudiff) ) - if(isnan(uob) .or. isnan(ugesin)) then - call nc_diag_metadata("u_Obs_Minus_Forecast_unadjusted",sngl(real(r_missing))) - else - call nc_diag_metadata("u_Obs_Minus_Forecast_unadjusted",sngl(uob-ugesin)) - endif + call nc_diag_metadata_to_single("u_Observation",data(iuob,i) ) + call nc_diag_metadata_to_single("u_Obs_Minus_Forecast_adjusted",dudiff ) + call nc_diag_metadata_to_single("u_Obs_Minus_Forecast_unadjusted",uob,ugesin,'-') - call screen_to_single_nc_diag_metadata("v_Observation",(data(ivob,i)) ) - call screen_to_single_nc_diag_metadata("v_Obs_Minus_Forecast_adjusted",(dvdiff) ) - if(isnan(vob) .or. isnan(vgesin)) then - call nc_diag_metadata("v_Obs_Minus_Forecast_unadjusted",sngl(real(r_missing))) - else - call nc_diag_metadata("v_Obs_Minus_Forecast_unadjusted",sngl(vob-vgesin)) - endif + call nc_diag_metadata_to_single("v_Observation",data(ivob,i) ) + call nc_diag_metadata_to_single("v_Obs_Minus_Forecast_adjusted",dvdiff ) + call nc_diag_metadata_to_single("v_Obs_Minus_Forecast_unadjusted",vob,vgesin,'-') else ! (if regional) ! replace positions 17-22 with earth relative wind component information @@ -1843,21 +1829,13 @@ subroutine contents_netcdf_diag_(udiag,vdiag) call rotate_wind_xy2ll(ugesin,vgesin,uges_e,vges_e,dlon_e,dlon,dlat) call rotate_wind_xy2ll(dudiff,dvdiff,dudiff_e,dvdiff_e,dlon_e,dlon,dlat) - call screen_to_single_nc_diag_metadata("u_Observation",(uob_e) ) - call screen_to_single_nc_diag_metadata("u_Obs_Minus_Forecast_adjusted",(dudiff_e) ) - if(isnan(uob_e) .or. isnan(uges_e)) then - call nc_diag_metadata("u_Obs_Minus_Forecast_unadjusted",sngl(real(r_missing))) - else - call nc_diag_metadata("u_Obs_Minus_Forecast_unadjusted",sngl(uob_e-uges_e)) - endif + call nc_diag_metadata_to_single("u_Observation",uob_e ) + call nc_diag_metadata_to_single("u_Obs_Minus_Forecast_adjusted",dudiff_e ) + call nc_diag_metadata_to_single("u_Obs_Minus_Forecast_unadjusted",uob_e,uges_e,'-') - call screen_to_single_nc_diag_metadata("v_Observation",(vob_e) ) - call screen_to_single_nc_diag_metadata("v_Obs_Minus_Forecast_adjusted",(dvdiff_e) ) - if(isnan(vob_e) .or. isnan(vges_e)) then - call nc_diag_metadata("v_Obs_Minus_Forecast_unadjusted",sngl(real(r_missing))) - else - call nc_diag_metadata("v_Obs_Minus_Forecast_unadjusted",sngl(vob_e-vges_e)) - endif + call nc_diag_metadata_to_single("v_Observation",vob_e ) + call nc_diag_metadata_to_single("v_Obs_Minus_Forecast_adjusted",dvdiff_e ) + call nc_diag_metadata_to_single("v_Obs_Minus_Forecast_unadjusted",vob_e,vges_e,'-') endif if (lobsdiagsave) then From f5b0b2349afaef2305740bfdec1247e6eced985a Mon Sep 17 00:00:00 2001 From: "[David Huber]" <[david.huber@noaa.gov]> Date: Fri, 2 Jun 2023 00:23:57 +0000 Subject: [PATCH 11/44] Let one PE create directories #447 --- src/gsi/obsmod.F90 | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/src/gsi/obsmod.F90 b/src/gsi/obsmod.F90 index 0bd3983fa2..e81c4c0dec 100644 --- a/src/gsi/obsmod.F90 +++ b/src/gsi/obsmod.F90 @@ -980,7 +980,7 @@ subroutine init_obsmod_dflts return end subroutine init_obsmod_dflts - subroutine init_directories(mype) + subroutine init_directories(in_pe) !$$$ subprogram documentation block ! . . . . ! subprogram: create sub-directories @@ -1010,14 +1010,14 @@ subroutine init_directories(mype) #endif implicit none - integer(i_kind),intent(in ) :: mype + integer(i_kind),intent(in ) :: in_pe logical :: l_mkdir_stat character(len=144):: command character(len=8):: pe_name if (lrun_subdirs) then - write(pe_name,'(i4.4)') mype + write(pe_name,'(i4.4)') in_pe dirname = 'dir.'//trim(pe_name)//'/' command = 'mkdir -p -m 755 ' // trim(dirname) #ifdef __INTEL_COMPILER @@ -1030,7 +1030,7 @@ subroutine init_directories(mype) call system(command) #endif else - write(pe_name,100) mype + write(pe_name,100) in_pe 100 format('pe',i4.4,'.') dirname= trim(pe_name) end if From d134822283256de15ded98609134a5f8020f3727 Mon Sep 17 00:00:00 2001 From: "[David Huber]" <[david.huber@noaa.gov]> Date: Mon, 5 Jun 2023 15:55:30 +0000 Subject: [PATCH 12/44] Add ncdiag v1.1.0, update Cheyenne Intel location. #447 --- modulefiles/gsi_cheyenne.intel.lua | 2 +- modulefiles/gsi_common.lua | 9 ++------- 2 files changed, 3 insertions(+), 8 deletions(-) diff --git a/modulefiles/gsi_cheyenne.intel.lua b/modulefiles/gsi_cheyenne.intel.lua index 72bf458516..cafc1973be 100644 --- a/modulefiles/gsi_cheyenne.intel.lua +++ b/modulefiles/gsi_cheyenne.intel.lua @@ -8,7 +8,7 @@ load("intel/2022.1") load("mpt/2.25") load("ncarcompilers/0.5.0") -prepend_path("MODULEPATH", "/glade/work/epicufsrt/GMTB/tools/intel/2022.1/hpc-stack-v1.2.0_6eb6/modulefiles/stack") +prepend_path("MODULEPATH", "/glade/work/epicufsrt/contrib/hpc-stack/intel2022.1") load("hpc/1.2.0") load("hpc-intel/2022.1") diff --git a/modulefiles/gsi_common.lua b/modulefiles/gsi_common.lua index 0dda5ce333..b2929bcdf8 100644 --- a/modulefiles/gsi_common.lua +++ b/modulefiles/gsi_common.lua @@ -16,7 +16,7 @@ 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" -local ncdiag_ver=os.getenv("ncdiag_ver") or "1.0.0" +local ncdiag_ver=os.getenv("ncdiag_ver") or "1.1.0" load(pathJoin("netcdf", netcdf_ver)) @@ -32,9 +32,4 @@ load(pathJoin("nemsio", nemsio_ver)) load(pathJoin("wrf_io", wrf_io_ver)) load(pathJoin("ncio", ncio_ver)) load(pathJoin("crtm", crtm_ver)) ---load(pathJoin("ncdiag",ncdiag_ver)) -setenv("ncdiag_ROOT", "/work2/noaa/nesdis-rdo2/dhuber/GSI/ncdiag/1.0.1") -setenv("ncdiag_VERSION", "1.0.1") - -prepend_path("PATH", pathJoin("/work2/noaa/nesdis-rdo2/dhuber/GSI/ncdiag/1.0.1/","bin")) - +load(pathJoin("ncdiag",ncdiag_ver)) From bac7531dbbeeb4d3c8819ac59f392424f07ccc35 Mon Sep 17 00:00:00 2001 From: "[David Huber]" <[david.huber@noaa.gov]> Date: Mon, 5 Jun 2023 19:10:41 +0000 Subject: [PATCH 13/44] Updated ncdiag version in ci/spack.yaml #447 --- ci/spack.yaml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/ci/spack.yaml b/ci/spack.yaml index a831de16ad..4374d8dd85 100644 --- a/ci/spack.yaml +++ b/ci/spack.yaml @@ -19,7 +19,7 @@ spack: - wrf-io@1.2.0 - ncio@1.1.2 - crtm@2.4.0 - - gsi-ncdiag@1.0.0 + - gsi-ncdiag@1.1.0 view: true concretizer: unify: true From b601e59871ec5fcfc7956bae6ae0a1e0744ea1fd Mon Sep 17 00:00:00 2001 From: "[David Huber]" <[david.huber@noaa.gov]> Date: Tue, 6 Jun 2023 01:09:33 +0000 Subject: [PATCH 14/44] Stop if allocations fail. #571 --- src/gsi/guess_grids.F90 | 27 +++++++++++++-------------- 1 file changed, 13 insertions(+), 14 deletions(-) diff --git a/src/gsi/guess_grids.F90 b/src/gsi/guess_grids.F90 index b8cb188d01..bf493a0628 100644 --- a/src/gsi/guess_grids.F90 +++ b/src/gsi/guess_grids.F90 @@ -981,26 +981,25 @@ subroutine create_gesfinfo hrdifsig_all(nfldsig_all), & stat=istatus) if (istatus/=0) & - write(6,*)'CREATE_GESFINFO(hrdifsig,..): allocate error, istatus=',& - istatus + call die('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 + call die('CREATE_GESFINFO', '(hrdifsfc,..): allocate error, istatus=',& + istatus) if(nfldnst>0) allocate(hrdifnst(nfldnst),ifilenst(nfldnst), & hrdifnst_all(nfldnst_all), & - stat=istatus) + stat=istatus) if (istatus/=0) & - write(6,*)'CREATE_GESFINFO(hrdifnst,..): allocate error, istatus=',& - istatus + call die('CREATE_GESFINFO', '(hrdifnst,..): allocate error, istatus=',& + istatus) if(nfldnst>0) allocate(hrdifaer(nfldaer),ifileaer(nfldaer), & hrdifaer_all(nfldaer_all), & - stat=istatus) + stat=istatus) if (istatus/=0) & - write(6,*)'CREATE_GESFINFO(hrdifaer,..): allocate error, istatus=',& - istatus + call die('CREATE_GESFINFO', '(hrdifaer,..): allocate error, istatus=',& + istatus) #endif /* HAVE_ESMF */ return @@ -1044,16 +1043,16 @@ subroutine destroy_gesfinfo #ifndef HAVE_ESMF if(nfldsig>0) deallocate(hrdifsig,ifilesig,hrdifsig_all,stat=istatus) if (istatus/=0) & - write(6,*)'DESTROY_GESFINFO: deallocate error, istatus=',istatus + call die('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 + call die('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 + call die('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 + call die('DESTROY_GESFINFO', 'deallocate error, istatus=',istatus) nfldsfc_all=0 nfldnst_all=0 From f01cca6606aebcc765328e79f8a63433bee4c4e1 Mon Sep 17 00:00:00 2001 From: Natalie Perlin Date: Wed, 14 Jun 2023 10:37:01 -0400 Subject: [PATCH 15/44] Gaea modulefile update, fix files location update on Jet,Hera,Orion,Gaea,Cheyenne --- modulefiles/gsi_cheyenne.intel.lua | 4 +- modulefiles/gsi_gaea | 62 ------------------------------ modulefiles/gsi_gaea.lua | 31 +++++++++++++++ modulefiles/gsi_hera.intel.lua | 2 +- modulefiles/gsi_jet.lua | 2 +- modulefiles/gsi_orion.lua | 2 +- ush/module-setup.sh | 26 +------------ 7 files changed, 37 insertions(+), 92 deletions(-) delete mode 100644 modulefiles/gsi_gaea create mode 100644 modulefiles/gsi_gaea.lua diff --git a/modulefiles/gsi_cheyenne.intel.lua b/modulefiles/gsi_cheyenne.intel.lua index cafc1973be..d02a0c3885 100644 --- a/modulefiles/gsi_cheyenne.intel.lua +++ b/modulefiles/gsi_cheyenne.intel.lua @@ -17,8 +17,8 @@ load("mkl/2022.1") load("gsi_common") -local prod_util_ver=os.getenv("prod_util_ver") or "1.2.2" -load(pathJoin("prod_util", prod_util_ver)) +load(pathJoin("prod_util", os.getenv("prod_util_ver") or "1.2.2")) +pushenv("GSI_BINARY_SOURCE_DIR", "/glade/work/epicufsrt/contrib/GSI_data/fix") pushenv("CFLAGS", "-xHOST") pushenv("FFLAGS", "-xHOST") diff --git a/modulefiles/gsi_gaea b/modulefiles/gsi_gaea deleted file mode 100644 index 641f3d0fcf..0000000000 --- a/modulefiles/gsi_gaea +++ /dev/null @@ -1,62 +0,0 @@ -#%Module1.0 -###################################################################### -## NOAA-EMC/GSI -##_____________________________________________________ -proc ModulesHelp { } { -puts stderr "Set environment variables for NOAA-EMC/GSI" -puts stderr "This module initializes the environment " -puts stderr "for the Intel Compiler Suite $version\n" -} -module-whatis " NOAA-EMC/GSI whatis description" - -set COMPILER intel - -setenv FFLAGS_COM "-fp-model strict" -setenv LDFLAGS_COM " " - -#set WRF_SHARED_VER v1.1.0 -#set WRF_SHARED_ROOT /gpfs/hps/nco/ops/nwprod/wrf_shared -#set WRF_SHARED_ROOT /lustre/f1/pdata/ncep_shared/NCEPLIBS/lib/EXTERNAL/wrf_shared -#setenv WRF_SHARED_PATH ${WRF_SHARED_ROOT}.${WRF_SHARED_VER} - -setenv NCEPLIBS /lustre/f1/pdata/ncep_shared/NCEPLIBS/lib - -# Loading ncep environment -##module load ncep/1.0 -module use /opt/cray/pe/craype/2.5.5/modulefiles - -# Loading Intel Compiler Suite -module load PrgEnv-intel - -# Loading pe environment -module load cray-mpich -module load cray-libsci -module unload craype-broadwell -module load craype-haswell - -module use /sw/gaea/modulefiles -module load cmake - -# Loading nceplibs modules -module use /lustre/f1/pdata/ncep_shared/NCEPLIBS/lib/modulefiles -#module load HDF5-serial-intel-haswell/1.8.9 -#module load NetCDF-intel-haswell/4.2 -module load cray-hdf5 -module load cray-netcdf - -#module use /gpfs/hps/nco/ops/nwprod/lib/modulefiles -module load bufr-intel-sandybridge/11.0.1 -module load nemsio-intel-sandybridge/2.2.2 -module load sfcio-intel-sandybridge/1.0.0 -module load sigio-intel-sandybridge/2.0.1 -module load sp-intel-sandybridge/2.0.2 -module load w3nco-intel-sandybridge/2.0.6 -module load w3emc-intel-sandybridge/2.2.0 -module load bacio-intel-sandybridge/2.0.2 -setenv CRAYOS_VERSION $::env(CRAYPE_VERSION) -#setenv CRAYOS_VERSION ${CRAYPE_VERSION} - -# Compiler flags specific to this platform -setenv CFLAGS "-xCORE-AVX2" -setenv FFLAGS "-xCORE-AVX2" - diff --git a/modulefiles/gsi_gaea.lua b/modulefiles/gsi_gaea.lua new file mode 100644 index 0000000000..9ea375d72e --- /dev/null +++ b/modulefiles/gsi_gaea.lua @@ -0,0 +1,31 @@ +help([[ +]]) + +load("cmake/3.20.1") + +prepend_path("MODULEPATH","/lustre/f2/dev/role.epic/contrib/hpc-stack/intel-classic-2022.0.2/modulefiles/stack") +load(pathJoin("hpc", os.getenv("hpc_ver") or "1.2.0")) + +load(pathJoin("intel-classic", os.getenv("intel_classic_ver") or "2022.0.2")) +load(pathJoin("cray-mpich", os.getenv("cray_mpich_ver") or "7.7.20")) +load(pathJoin("hpc-intel-classic", os.getenv("hpc_intel_classic_ver") or "2022.0.2")) +load(pathJoin("hpc-cray-mpich", os.getenv("hpc_cray_mpich_ver") or "7.7.20")) + +load("gsi_common") + +local prod_util_ver=os.getenv("prod_util_ver") or "1.2.2" +load(pathJoin("prod_util", prod_util_ver)) + +local MKLROOT="/opt/intel/oneapi/mkl/2022.0.2/" +prepend_path("LD_LIBRARY_PATH",pathJoin(MKLROOT,"lib/intel64")) +pushenv("MKLROOT", MKLROOT) + +pushenv("GSI_BINARY_SOURCE_DIR", "/lustre/f2/dev/role.epic/contrib/GSI_data/fix") +setenv("CC","cc") +setenv("FC","ftn") +setenv("CXX","CC") +unsetenv("CRAYPE_LINK_TYPE") +pushenv("CRAYPE_LINK_TYPE","dynamic") + +whatis("Description: GSI environment on Gaea with Intel Compilers") + diff --git a/modulefiles/gsi_hera.intel.lua b/modulefiles/gsi_hera.intel.lua index 7c98d48ad9..866af02d50 100644 --- a/modulefiles/gsi_hera.intel.lua +++ b/modulefiles/gsi_hera.intel.lua @@ -25,6 +25,6 @@ load(pathJoin("prod_util", prod_util_ver)) pushenv("CFLAGS", "-xHOST") pushenv("FFLAGS", "-xHOST") -pushenv("GSI_BINARY_SOURCE_DIR", "/scratch1/NCEPDEV/global/glopara/fix/gsi/20221128") +pushenv("GSI_BINARY_SOURCE_DIR", "/scratch1/NCEPDEV/global/glopara/fix/gsi/20230601") whatis("Description: GSI environment on Hera with Intel Compilers") diff --git a/modulefiles/gsi_jet.lua b/modulefiles/gsi_jet.lua index 2f8cacff8a..e2ea2ef1d0 100644 --- a/modulefiles/gsi_jet.lua +++ b/modulefiles/gsi_jet.lua @@ -26,6 +26,6 @@ pushenv("CFLAGS", "-axSSE4.2,AVX,CORE-AVX2") pushenv("FFLAGS", "-axSSE4.2,AVX,CORE-AVX2") -pushenv("GSI_BINARY_SOURCE_DIR", "/mnt/lfs4/HFIP/hfv3gfs/glopara/git/fv3gfs/fix/gsi/20221128") +pushenv("GSI_BINARY_SOURCE_DIR", "/mnt/lfs4/HFIP/hfv3gfs/glopara/git/fv3gfs/fix/gsi/20230601") whatis("Description: GSI environment on Jet with Intel Compilers") diff --git a/modulefiles/gsi_orion.lua b/modulefiles/gsi_orion.lua index 1f0787be50..43276b7cbe 100644 --- a/modulefiles/gsi_orion.lua +++ b/modulefiles/gsi_orion.lua @@ -25,6 +25,6 @@ load(pathJoin("prod_util", prod_util_ver)) pushenv("CFLAGS", "-xHOST") pushenv("FFLAGS", "-xHOST") -pushenv("GSI_BINARY_SOURCE_DIR", "/work/noaa/global/glopara/fix/gsi/20221128") +pushenv("GSI_BINARY_SOURCE_DIR", "/work/noaa/global/glopara/fix/gsi/20230601") whatis("Description: GSI environment on Orion with Intel Compilers") diff --git a/ush/module-setup.sh b/ush/module-setup.sh index 469fd4a3c5..207dbba925 100755 --- a/ush/module-setup.sh +++ b/ush/module-setup.sh @@ -57,32 +57,8 @@ elif [[ $MACHINE_ID = gaea* ]] ; then # /etc/profile here. source /etc/profile __ms_source_etc_profile=yes - else - __ms_source_etc_profile=no - fi - module purge - # clean up after purge - unset _LMFILES_ - unset _LMFILES_000 - unset _LMFILES_001 - unset LOADEDMODULES - module load modules - if [[ -d /opt/cray/ari/modulefiles ]] ; then - module use -a /opt/cray/ari/modulefiles - fi - if [[ -d /opt/cray/pe/ari/modulefiles ]] ; then - module use -a /opt/cray/pe/ari/modulefiles - fi - if [[ -d /opt/cray/pe/craype/default/modulefiles ]] ; then - module use -a /opt/cray/pe/craype/default/modulefiles - fi - if [[ -s /etc/opt/cray/pe/admin-pe/site-config ]] ; then - source /etc/opt/cray/pe/admin-pe/site-config - fi - if [[ "$__ms_source_etc_profile" == yes ]] ; then - source /etc/profile - unset __ms_source_etc_profile fi + source /lustre/f2/dev/role.epic/contrib/Lmod_init.sh elif [[ $MACHINE_ID = expanse* ]]; then # We are on SDSC Expanse From aace46e7f47630027a49da1588d70724b9913698 Mon Sep 17 00:00:00 2001 From: Natalie Perlin Date: Wed, 14 Jun 2023 10:56:04 -0400 Subject: [PATCH 16/44] Gaea modulefile update --- modulefiles/gsi_gaea.lua | 1 - 1 file changed, 1 deletion(-) diff --git a/modulefiles/gsi_gaea.lua b/modulefiles/gsi_gaea.lua index 9ea375d72e..ea1826fde9 100644 --- a/modulefiles/gsi_gaea.lua +++ b/modulefiles/gsi_gaea.lua @@ -24,7 +24,6 @@ pushenv("GSI_BINARY_SOURCE_DIR", "/lustre/f2/dev/role.epic/contrib/GSI_data/fix" setenv("CC","cc") setenv("FC","ftn") setenv("CXX","CC") -unsetenv("CRAYPE_LINK_TYPE") pushenv("CRAYPE_LINK_TYPE","dynamic") whatis("Description: GSI environment on Gaea with Intel Compilers") From 56a22caeaff48ea70ea151f9bc5622561a2243f2 Mon Sep 17 00:00:00 2001 From: "[David Huber]" <[david.huber@noaa.gov]> Date: Thu, 22 Jun 2023 12:41:18 +0000 Subject: [PATCH 17/44] Fixed directory creation. #571 --- modulefiles/gsi_common.lua | 6 ++++-- regression/regression_var.sh | 16 +++------------- src/gsi/gsimod.F90 | 2 +- src/gsi/obsmod.F90 | 28 +++++++++++++++++++--------- 4 files changed, 27 insertions(+), 25 deletions(-) diff --git a/modulefiles/gsi_common.lua b/modulefiles/gsi_common.lua index b2929bcdf8..585572a049 100644 --- a/modulefiles/gsi_common.lua +++ b/modulefiles/gsi_common.lua @@ -7,7 +7,6 @@ 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.2" -local w3nco_ver=os.getenv("w3nco_ver") or "2.4.1" 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" @@ -32,4 +31,7 @@ load(pathJoin("nemsio", nemsio_ver)) load(pathJoin("wrf_io", wrf_io_ver)) load(pathJoin("ncio", ncio_ver)) load(pathJoin("crtm", crtm_ver)) -load(pathJoin("ncdiag",ncdiag_ver)) +--load(pathJoin("ncdiag",ncdiag_ver)) + +setenv("ncdiag_ROOT", "/scratch1/NESDIS/nesdis-rdo2/David.Huber/GSI/ncdiag/1.1.1") +setenv("ncdiag_VERSION", "1.1.1") diff --git a/regression/regression_var.sh b/regression/regression_var.sh index 05b5563ef1..8f6d950bfa 100755 --- a/regression/regression_var.sh +++ b/regression/regression_var.sh @@ -105,27 +105,17 @@ case $machine in ;; Hera) - export local_or_default="${local_or_default:-/scratch1/NCEPDEV/da/$LOGNAME}" - if [ -d $local_or_default ]; then - export noscrub="$local_or_default/noscrub" - elif [ -d /scratch1/NCEPDEV/global/$LOGNAME ]; then - export noscrub="/scratch1/NCEPDEV/global/$LOGNAME/noscrub" - elif [ -d /scratch2/BMC/gsienkf/$LOGNAME ]; then - export noscrub="/scratch2/BMC/gsienkf/$LOGNAME" - fi + export noscrub="/scratch1/NESDIS/nesdis-rdo2/David.Huber/noscrub" export group="${group:-global}" export queue="${queue:-batch}" - if [[ "$cmaketest" = "false" ]]; then - export basedir="/scratch1/NCEPDEV/da/$LOGNAME/git/gsi" - fi - export ptmp="${ptmp:-/scratch1/NCEPDEV/stmp2/$LOGNAME/$ptmpName}" + export ptmp="/scratch1/NESDIS/nesdis-rdo2/David.Huber/para/ptmp_intel" export casesdir="/scratch1/NCEPDEV/da/Russ.Treadon/CASES/regtest" export check_resource="no" - export accnt="${accnt:-da-cpu}" + export accnt="epic" # On Hera, there are no scrubbers to remove old contents from stmp* directories. # After completion of regression tests, will remove the regression test subdirecories diff --git a/src/gsi/gsimod.F90 b/src/gsi/gsimod.F90 index cf885c2b64..9360d9225f 100644 --- a/src/gsi/gsimod.F90 +++ b/src/gsi/gsimod.F90 @@ -2213,7 +2213,7 @@ subroutine gsimain_initialize endif ! Set up directories (or pe specific filenames) - call init_directories(mype) + call init_directories(mype,npe) ! Initialize space for qc call create_qcvars diff --git a/src/gsi/obsmod.F90 b/src/gsi/obsmod.F90 index b755bdf1cc..f32aa8ae68 100644 --- a/src/gsi/obsmod.F90 +++ b/src/gsi/obsmod.F90 @@ -981,7 +981,7 @@ subroutine init_obsmod_dflts return end subroutine init_obsmod_dflts - subroutine init_directories(in_pe) + subroutine init_directories(in_pe,num_pe) !$$$ subprogram documentation block ! . . . . ! subprogram: create sub-directories @@ -1012,24 +1012,34 @@ subroutine init_directories(in_pe) implicit none integer(i_kind),intent(in ) :: in_pe + integer(i_kind),intent(in ) :: num_pe logical :: l_mkdir_stat character(len=144):: command - character(len=8):: pe_name + character(len=8):: pe_name, loc_pe_name + character(len=128):: loc_dirname + integer(i_kind) :: i if (lrun_subdirs) then write(pe_name,'(i4.4)') in_pe dirname = 'dir.'//trim(pe_name)//'/' - command = 'mkdir -p -m 755 ' // trim(dirname) +! Only create directories on one PE + if(in_pe == 0) then + do i = 0, num_pe + write(loc_pe_name,'(i4.4)') i + loc_dirname = 'dir.'//trim(loc_pe_name) #ifdef __INTEL_COMPILER - l_mkdir_stat = MAKEDIRQQ(trim(dirname)) - if(.not. l_mkdir_stat) then - write(6, *) "Failed to create directory ", trim(dirname), " for PE ", pe_name - call stop2(678) - endif + l_mkdir_stat = MAKEDIRQQ(trim(loc_dirname)) + if(.not. l_mkdir_stat) then + write(6, *) "Failed to create directory ", trim(loc_dirname), " for PE ", loc_pe_name + call stop2(678) + endif #else - call system(command) + command = 'mkdir -p -m 755 ' // trim(loc_dirname) + call system(command) #endif + enddo + endif else write(pe_name,100) in_pe 100 format('pe',i4.4,'.') From ea336c685887ec7277f40448799b601f97daa2fb Mon Sep 17 00:00:00 2001 From: "[David Huber]" <[david.huber@noaa.gov]> Date: Thu, 22 Jun 2023 13:22:22 +0000 Subject: [PATCH 18/44] Reverted regression_var.sh. --- regression/regression_var.sh | 16 +++++++++++++--- 1 file changed, 13 insertions(+), 3 deletions(-) diff --git a/regression/regression_var.sh b/regression/regression_var.sh index 8f6d950bfa..05b5563ef1 100755 --- a/regression/regression_var.sh +++ b/regression/regression_var.sh @@ -105,17 +105,27 @@ case $machine in ;; Hera) - export noscrub="/scratch1/NESDIS/nesdis-rdo2/David.Huber/noscrub" + export local_or_default="${local_or_default:-/scratch1/NCEPDEV/da/$LOGNAME}" + if [ -d $local_or_default ]; then + export noscrub="$local_or_default/noscrub" + elif [ -d /scratch1/NCEPDEV/global/$LOGNAME ]; then + export noscrub="/scratch1/NCEPDEV/global/$LOGNAME/noscrub" + elif [ -d /scratch2/BMC/gsienkf/$LOGNAME ]; then + export noscrub="/scratch2/BMC/gsienkf/$LOGNAME" + fi export group="${group:-global}" export queue="${queue:-batch}" + if [[ "$cmaketest" = "false" ]]; then + export basedir="/scratch1/NCEPDEV/da/$LOGNAME/git/gsi" + fi - export ptmp="/scratch1/NESDIS/nesdis-rdo2/David.Huber/para/ptmp_intel" + export ptmp="${ptmp:-/scratch1/NCEPDEV/stmp2/$LOGNAME/$ptmpName}" export casesdir="/scratch1/NCEPDEV/da/Russ.Treadon/CASES/regtest" export check_resource="no" - export accnt="epic" + export accnt="${accnt:-da-cpu}" # On Hera, there are no scrubbers to remove old contents from stmp* directories. # After completion of regression tests, will remove the regression test subdirecories From e5d89c34cc2d2cf7e66512d270904836a7ade04c Mon Sep 17 00:00:00 2001 From: "[David Huber]" <[david.huber@noaa.gov]> Date: Thu, 22 Jun 2023 13:47:21 +0000 Subject: [PATCH 19/44] Update Gaea and Cheyenne modulefiles. --- modulefiles/gsi_cheyenne.gnu.lua | 2 +- modulefiles/gsi_cheyenne.intel.lua | 4 +- modulefiles/gsi_gaea | 62 ------------------------------ modulefiles/gsi_gaea.lua | 29 ++++++++++++++ ush/module-setup.sh | 27 +------------ 5 files changed, 34 insertions(+), 90 deletions(-) delete mode 100644 modulefiles/gsi_gaea create mode 100644 modulefiles/gsi_gaea.lua diff --git a/modulefiles/gsi_cheyenne.gnu.lua b/modulefiles/gsi_cheyenne.gnu.lua index 494ec6fb18..a4e7452e96 100644 --- a/modulefiles/gsi_cheyenne.gnu.lua +++ b/modulefiles/gsi_cheyenne.gnu.lua @@ -9,7 +9,7 @@ load("mpt/2.22") load("ncarcompilers/0.5.0") unload("netcdf") -prepend_path("MODULEPATH", "/glade/work/epicufsrt/GMTB/tools/gnu/10.1.0/hpc-stack-v1.2.0/modulefiles/stack") +prepend_path("MODULEPATH", "/glade/work/epicufsrt/contrib/hpc-stack/gnu10.1.0/modulefiles/stack") load("hpc/1.2.0") load("hpc-gnu/10.1.0") diff --git a/modulefiles/gsi_cheyenne.intel.lua b/modulefiles/gsi_cheyenne.intel.lua index cafc1973be..d02a0c3885 100644 --- a/modulefiles/gsi_cheyenne.intel.lua +++ b/modulefiles/gsi_cheyenne.intel.lua @@ -17,8 +17,8 @@ load("mkl/2022.1") load("gsi_common") -local prod_util_ver=os.getenv("prod_util_ver") or "1.2.2" -load(pathJoin("prod_util", prod_util_ver)) +load(pathJoin("prod_util", os.getenv("prod_util_ver") or "1.2.2")) +pushenv("GSI_BINARY_SOURCE_DIR", "/glade/work/epicufsrt/contrib/GSI_data/fix") pushenv("CFLAGS", "-xHOST") pushenv("FFLAGS", "-xHOST") diff --git a/modulefiles/gsi_gaea b/modulefiles/gsi_gaea deleted file mode 100644 index 641f3d0fcf..0000000000 --- a/modulefiles/gsi_gaea +++ /dev/null @@ -1,62 +0,0 @@ -#%Module1.0 -###################################################################### -## NOAA-EMC/GSI -##_____________________________________________________ -proc ModulesHelp { } { -puts stderr "Set environment variables for NOAA-EMC/GSI" -puts stderr "This module initializes the environment " -puts stderr "for the Intel Compiler Suite $version\n" -} -module-whatis " NOAA-EMC/GSI whatis description" - -set COMPILER intel - -setenv FFLAGS_COM "-fp-model strict" -setenv LDFLAGS_COM " " - -#set WRF_SHARED_VER v1.1.0 -#set WRF_SHARED_ROOT /gpfs/hps/nco/ops/nwprod/wrf_shared -#set WRF_SHARED_ROOT /lustre/f1/pdata/ncep_shared/NCEPLIBS/lib/EXTERNAL/wrf_shared -#setenv WRF_SHARED_PATH ${WRF_SHARED_ROOT}.${WRF_SHARED_VER} - -setenv NCEPLIBS /lustre/f1/pdata/ncep_shared/NCEPLIBS/lib - -# Loading ncep environment -##module load ncep/1.0 -module use /opt/cray/pe/craype/2.5.5/modulefiles - -# Loading Intel Compiler Suite -module load PrgEnv-intel - -# Loading pe environment -module load cray-mpich -module load cray-libsci -module unload craype-broadwell -module load craype-haswell - -module use /sw/gaea/modulefiles -module load cmake - -# Loading nceplibs modules -module use /lustre/f1/pdata/ncep_shared/NCEPLIBS/lib/modulefiles -#module load HDF5-serial-intel-haswell/1.8.9 -#module load NetCDF-intel-haswell/4.2 -module load cray-hdf5 -module load cray-netcdf - -#module use /gpfs/hps/nco/ops/nwprod/lib/modulefiles -module load bufr-intel-sandybridge/11.0.1 -module load nemsio-intel-sandybridge/2.2.2 -module load sfcio-intel-sandybridge/1.0.0 -module load sigio-intel-sandybridge/2.0.1 -module load sp-intel-sandybridge/2.0.2 -module load w3nco-intel-sandybridge/2.0.6 -module load w3emc-intel-sandybridge/2.2.0 -module load bacio-intel-sandybridge/2.0.2 -setenv CRAYOS_VERSION $::env(CRAYPE_VERSION) -#setenv CRAYOS_VERSION ${CRAYPE_VERSION} - -# Compiler flags specific to this platform -setenv CFLAGS "-xCORE-AVX2" -setenv FFLAGS "-xCORE-AVX2" - diff --git a/modulefiles/gsi_gaea.lua b/modulefiles/gsi_gaea.lua new file mode 100644 index 0000000000..dc008dcdbe --- /dev/null +++ b/modulefiles/gsi_gaea.lua @@ -0,0 +1,29 @@ +help([[ +]]) + +load("cmake/3.20.1") + +prepend_path("MODULEPATH","/lustre/f2/dev/role.epic/contrib/hpc-stack/intel-classic-2022.0.2/modulefiles/stack") +load(pathJoin("hpc", os.getenv("hpc_ver") or "1.2.0")) + +load(pathJoin("intel-classic", os.getenv("intel_classic_ver") or "2022.0.2")) +load(pathJoin("cray-mpich", os.getenv("cray_mpich_ver") or "7.7.20")) +load(pathJoin("hpc-intel-classic", os.getenv("hpc_intel_classic_ver") or "2022.0.2")) +load(pathJoin("hpc-cray-mpich", os.getenv("hpc_cray_mpich_ver") or "7.7.20")) + +load("gsi_common") + +local prod_util_ver=os.getenv("prod_util_ver") or "1.2.2" +load(pathJoin("prod_util", prod_util_ver)) + +local MKLROOT="/opt/intel/oneapi/mkl/2022.0.2/" +prepend_path("LD_LIBRARY_PATH",pathJoin(MKLROOT,"lib/intel64")) +pushenv("MKLROOT", MKLROOT) + +pushenv("GSI_BINARY_SOURCE_DIR", "/lustre/f2/dev/role.epic/contrib/GSI_data/fix") +setenv("CC","cc") +setenv("FC","ftn") +setenv("CXX","CC") +pushenv("CRAYPE_LINK_TYPE","dynamic") + +whatis("Description: GSI environment on Gaea with Intel Compilers") diff --git a/ush/module-setup.sh b/ush/module-setup.sh index 469fd4a3c5..d32846f316 100755 --- a/ush/module-setup.sh +++ b/ush/module-setup.sh @@ -57,33 +57,10 @@ elif [[ $MACHINE_ID = gaea* ]] ; then # /etc/profile here. source /etc/profile __ms_source_etc_profile=yes - else - __ms_source_etc_profile=no - fi - module purge - # clean up after purge - unset _LMFILES_ - unset _LMFILES_000 - unset _LMFILES_001 - unset LOADEDMODULES - module load modules - if [[ -d /opt/cray/ari/modulefiles ]] ; then - module use -a /opt/cray/ari/modulefiles - fi - if [[ -d /opt/cray/pe/ari/modulefiles ]] ; then - module use -a /opt/cray/pe/ari/modulefiles - fi - if [[ -d /opt/cray/pe/craype/default/modulefiles ]] ; then - module use -a /opt/cray/pe/craype/default/modulefiles - fi - if [[ -s /etc/opt/cray/pe/admin-pe/site-config ]] ; then - source /etc/opt/cray/pe/admin-pe/site-config - fi - if [[ "$__ms_source_etc_profile" == yes ]] ; then - source /etc/profile - unset __ms_source_etc_profile fi + source /lustre/f2/dev/role.epic/contrib/Lmod_init.sh + elif [[ $MACHINE_ID = expanse* ]]; then # We are on SDSC Expanse if ( ! eval module help > /dev/null 2>&1 ) ; then From 3bf5e013c3bead65286e41b2b613af315659ed93 Mon Sep 17 00:00:00 2001 From: Natalie Perlin Date: Fri, 23 Jun 2023 08:17:51 -0400 Subject: [PATCH 20/44] Modulefile for Gaea and regression tests configuration --- modulefiles/gsi_common.lua | 2 +- modulefiles/gsi_gaea | 62 ------------ modulefiles/gsi_gaea.lua | 33 +++++++ regression/regression_driver.sh | 3 +- regression/regression_param.sh | 37 +++++++ regression/regression_var.sh | 14 +++ ush/build.sh | 7 +- ush/module-setup.sh | 26 +---- ush/sub_gaea | 166 ++++++++++++++++++++++++++++++++ 9 files changed, 258 insertions(+), 92 deletions(-) delete mode 100644 modulefiles/gsi_gaea create mode 100644 modulefiles/gsi_gaea.lua create mode 100755 ush/sub_gaea diff --git a/modulefiles/gsi_common.lua b/modulefiles/gsi_common.lua index b2929bcdf8..ba2eea3241 100644 --- a/modulefiles/gsi_common.lua +++ b/modulefiles/gsi_common.lua @@ -16,7 +16,7 @@ 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" -local ncdiag_ver=os.getenv("ncdiag_ver") or "1.1.0" +local ncdiag_ver=os.getenv("ncdiag_ver") or "1.1.1" load(pathJoin("netcdf", netcdf_ver)) diff --git a/modulefiles/gsi_gaea b/modulefiles/gsi_gaea deleted file mode 100644 index 641f3d0fcf..0000000000 --- a/modulefiles/gsi_gaea +++ /dev/null @@ -1,62 +0,0 @@ -#%Module1.0 -###################################################################### -## NOAA-EMC/GSI -##_____________________________________________________ -proc ModulesHelp { } { -puts stderr "Set environment variables for NOAA-EMC/GSI" -puts stderr "This module initializes the environment " -puts stderr "for the Intel Compiler Suite $version\n" -} -module-whatis " NOAA-EMC/GSI whatis description" - -set COMPILER intel - -setenv FFLAGS_COM "-fp-model strict" -setenv LDFLAGS_COM " " - -#set WRF_SHARED_VER v1.1.0 -#set WRF_SHARED_ROOT /gpfs/hps/nco/ops/nwprod/wrf_shared -#set WRF_SHARED_ROOT /lustre/f1/pdata/ncep_shared/NCEPLIBS/lib/EXTERNAL/wrf_shared -#setenv WRF_SHARED_PATH ${WRF_SHARED_ROOT}.${WRF_SHARED_VER} - -setenv NCEPLIBS /lustre/f1/pdata/ncep_shared/NCEPLIBS/lib - -# Loading ncep environment -##module load ncep/1.0 -module use /opt/cray/pe/craype/2.5.5/modulefiles - -# Loading Intel Compiler Suite -module load PrgEnv-intel - -# Loading pe environment -module load cray-mpich -module load cray-libsci -module unload craype-broadwell -module load craype-haswell - -module use /sw/gaea/modulefiles -module load cmake - -# Loading nceplibs modules -module use /lustre/f1/pdata/ncep_shared/NCEPLIBS/lib/modulefiles -#module load HDF5-serial-intel-haswell/1.8.9 -#module load NetCDF-intel-haswell/4.2 -module load cray-hdf5 -module load cray-netcdf - -#module use /gpfs/hps/nco/ops/nwprod/lib/modulefiles -module load bufr-intel-sandybridge/11.0.1 -module load nemsio-intel-sandybridge/2.2.2 -module load sfcio-intel-sandybridge/1.0.0 -module load sigio-intel-sandybridge/2.0.1 -module load sp-intel-sandybridge/2.0.2 -module load w3nco-intel-sandybridge/2.0.6 -module load w3emc-intel-sandybridge/2.2.0 -module load bacio-intel-sandybridge/2.0.2 -setenv CRAYOS_VERSION $::env(CRAYPE_VERSION) -#setenv CRAYOS_VERSION ${CRAYPE_VERSION} - -# Compiler flags specific to this platform -setenv CFLAGS "-xCORE-AVX2" -setenv FFLAGS "-xCORE-AVX2" - diff --git a/modulefiles/gsi_gaea.lua b/modulefiles/gsi_gaea.lua new file mode 100644 index 0000000000..23fa6edf7d --- /dev/null +++ b/modulefiles/gsi_gaea.lua @@ -0,0 +1,33 @@ +help([[ +]]) + +load("cmake/3.20.1") + +prepend_path("MODULEPATH","/lustre/f2/dev/role.epic/contrib/hpc-stack/intel-classic-2022.0.2/modulefiles/stack") +load(pathJoin("hpc", os.getenv("hpc_ver") or "1.2.0")) + +load(pathJoin("intel-classic", os.getenv("intel_classic_ver") or "2022.0.2")) +load(pathJoin("cray-mpich", os.getenv("cray_mpich_ver") or "7.7.20")) +load(pathJoin("hpc-intel-classic", os.getenv("hpc_intel_classic_ver") or "2022.0.2")) +load(pathJoin("hpc-cray-mpich", os.getenv("hpc_cray_mpich_ver") or "7.7.20")) + +load("gsi_common") + +local prod_util_ver=os.getenv("prod_util_ver") or "1.2.2" +load(pathJoin("prod_util", prod_util_ver)) + +-- Needed at runtime: +load("alps") + +local MKLROOT="/opt/intel/oneapi/mkl/2022.0.2/" +prepend_path("LD_LIBRARY_PATH",pathJoin(MKLROOT,"lib/intel64")) +pushenv("MKLROOT", MKLROOT) + +pushenv("GSI_BINARY_SOURCE_DIR", "/lustre/f2/dev/role.epic/contrib/GSI_data/fix/20230601") +setenv("CC","cc") +setenv("FC","ftn") +setenv("CXX","CC") +pushenv("CRAYPE_LINK_TYPE","dynamic") + +whatis("Description: GSI environment on Gaea with Intel Compilers") + diff --git a/regression/regression_driver.sh b/regression/regression_driver.sh index e1d3b18dc7..58ebf64e85 100755 --- a/regression/regression_driver.sh +++ b/regression/regression_driver.sh @@ -10,6 +10,7 @@ if [ -d "$config_path" ]; then source $config_path/local_vars.sh fi + # source the necessary files to setup if [ "$#" -eq 2 ]; then export regdir=$2 @@ -41,7 +42,7 @@ for jn in `seq ${RSTART} ${REND}`; do fi rm -f ${job[$jn]}.out - /bin/sh $ush/$sub_cmd -q $queue -j ${job[$jn]} -t ${topts[$jn]} -p ${popts[$jn]} -r ${ropts[$jn]} $scripts/${regtest}.sh + /bin/sh $ush/$sub_cmd -q $queue -j ${job[$jn]} -t ${topts[$jn]} -p ${popts[$jn]} -r ${ropts[$jn]} $scripts/${regtest}.sh >& $ush/sub_cmd.${job[$jn]}.out if [ $debug == ".true." ]; then break; fi $scripts/regression_wait.sh ${job[$jn]} ${rcname} $check_resource diff --git a/regression/regression_param.sh b/regression/regression_param.sh index 6024dbdb54..ea597fe0ae 100755 --- a/regression/regression_param.sh +++ b/regression/regression_param.sh @@ -18,6 +18,11 @@ case $machine in sub_cmd="sub_jet" memnode=96 numcore=40 + ;; + Gaea) + sub_cmd="sub_gaea" + memnode=64 + numcore=36 ;; wcoss2) sub_cmd="sub_wcoss2" @@ -58,6 +63,9 @@ case $regtest in elif [[ "$machine" = "Cheyenne" ]]; then topts[1]="0:30:00" ; popts[1]="16/2/" ; ropts[1]="/1" topts[2]="0:30:00" ; popts[2]="16/4/" ; ropts[2]="/2" + elif [[ "$machine" = "Gaea" ]]; then + topts[1]="0:30:00" ; popts[1]="18/2/" ; ropts[1]="/1" + topts[2]="0:30:00" ; popts[2]="18/4/" ; ropts[2]="/2" elif [[ "$machine" = "wcoss2" ]]; then topts[1]="0:15:00" ; popts[1]="12/5/" ; ropts[1]="/1" topts[2]="0:15:00" ; popts[2]="12/9/" ; ropts[2]="/2" @@ -88,6 +96,9 @@ case $regtest in elif [[ "$machine" = "Cheyenne" ]]; then topts[1]="0:35:00" ; popts[1]="16/2/" ; ropts[1]="/1" topts[2]="0:25:00" ; popts[2]="16/4/" ; ropts[2]="/2" + elif [[ "$machine" = "Gaea" ]]; then + topts[1]="0:35:00" ; popts[1]="18/2/" ; ropts[1]="/1" + topts[2]="0:25:00" ; popts[2]="18/4/" ; ropts[2]="/2" elif [[ "$machine" = "wcoss2" ]]; then topts[1]="0:15:00" ; popts[1]="28/2/" ; ropts[1]="/1" topts[2]="0:15:00" ; popts[2]="28/4/" ; ropts[2]="/2" @@ -104,6 +115,8 @@ case $regtest in popts[1]="12/5/" elif [[ "$machine" = "Jet" ]]; then popts[1]="12/5/" + elif [[ "$machine" = "Gaea" ]]; then + popts[1]="18/5/" elif [[ "$machine" = "wcoss2" ]]; then popts[1]="28/4/" topts[1]="3:00:00" @@ -131,6 +144,9 @@ case $regtest in elif [[ "$machine" = "Cheyenne" ]]; then topts[1]="1:59:00" ; popts[1]="6/8/" ; ropts[1]="/1" topts[2]="0:35:00" ; popts[2]="6/10/" ; ropts[2]="/2" + elif [[ "$machine" = "Gaea" ]]; then + topts[1]="0:10:00" ; popts[1]="18/8/" ; ropts[1]="/1" + topts[2]="0:10:00" ; popts[2]="18/10/" ; ropts[2]="/2" elif [[ "$machine" = "wcoss2" ]]; then topts[1]="0:10:00" ; popts[1]="12/8/" ; ropts[1]="/1" topts[2]="0:10:00" ; popts[2]="12/10/" ; ropts[2]="/2" @@ -155,6 +171,9 @@ case $regtest in elif [[ "$machine" = "Jet" ]]; then topts[1]="0:15:00" ; popts[1]="20/1/" ; ropts[1]="/1" topts[2]="0:15:00" ; popts[2]="20/2/" ; ropts[2]="/1" + elif [[ "$machine" = "Gaea" ]]; then + topts[1]="0:15:00" ; popts[1]="18/1/" ; ropts[1]="/1" + topts[2]="0:15:00" ; popts[2]="18/2/" ; ropts[2]="/1" elif [[ "$machine" = "wcoss2" ]]; then topts[1]="0:15:00" ; popts[1]="64/1/" ; ropts[1]="/1" topts[2]="0:15:00" ; popts[2]="128/2/" ; ropts[2]="/1" @@ -179,6 +198,9 @@ case $regtest in elif [[ "$machine" = "Jet" ]]; then topts[1]="0:15:00" ; popts[1]="4/4/" ; ropts[1]="/1" topts[2]="0:15:00" ; popts[2]="6/6/" ; ropts[2]="/1" + elif [[ "$machine" = "Gaea" ]]; then + topts[1]="0:15:00" ; popts[1]="4/4/" ; ropts[1]="/1" + topts[2]="0:15:00" ; popts[2]="6/6/" ; ropts[2]="/1" elif [[ "$machine" = "wcoss2" ]]; then topts[1]="0:15:00" ; popts[1]="28/1/" ; ropts[1]="/1" topts[2]="0:15:00" ; popts[2]="28/2/" ; ropts[2]="/1" @@ -206,6 +228,9 @@ case $regtest in elif [[ "$machine" = "Cheyenne" ]]; then topts[1]="0:15:00" ; popts[1]="8/6/" ; ropts[1]="/1" topts[2]="0:15:00" ; popts[2]="8/8/" ; ropts[2]="/1" + elif [[ "$machine" = "Gaea" ]]; then + topts[1]="0:30:00" ; popts[1]="8/6/" ; ropts[1]="/1" + topts[2]="0:30:00" ; popts[2]="8/8/" ; ropts[2]="/1" elif [[ "$machine" = "wcoss2" ]]; then topts[1]="0:30:00" ; popts[1]="14/8/" ; ropts[1]="/1" topts[2]="0:30:00" ; popts[2]="14/14/" ; ropts[2]="/2" @@ -233,6 +258,9 @@ case $regtest in elif [[ "$machine" = "Cheyenne" ]]; then topts[1]="0:20:00" ; popts[1]="6/6/" ; ropts[1]="/1" topts[2]="0:20:00" ; popts[2]="8/8/" ; ropts[2]="/1" + elif [[ "$machine" = "Gaea" ]]; then + topts[1]="0:20:00" ; popts[1]="6/6/" ; ropts[1]="/1" + topts[2]="0:20:00" ; popts[2]="8/8/" ; ropts[2]="/1" elif [[ "$machine" = "wcoss2" ]]; then topts[1]="0:15:00" ; popts[1]="10/10/" ; ropts[1]="/1" topts[2]="0:15:00" ; popts[2]="14/14/" ; ropts[2]="/2" @@ -260,6 +288,9 @@ case $regtest in elif [[ "$machine" = "Cheyenne" ]]; then topts[1]="0:15:00" ; popts[1]="16/2/" ; ropts[1]="/1" topts[2]="0:15:00" ; popts[2]="16/4/" ; ropts[2]="/2" + elif [[ "$machine" = "Gaea" ]]; then + topts[1]="0:10:00" ; popts[1]="12/3/" ; ropts[1]="/1" + topts[2]="0:10:00" ; popts[2]="12/5/" ; ropts[2]="/2" elif [[ "$machine" = "wcoss2" ]]; then topts[1]="0:10:00" ; popts[1]="16/2/" ; ropts[1]="/1" topts[2]="0:10:00" ; popts[2]="16/4/" ; ropts[2]="/2" @@ -317,6 +348,12 @@ elif [[ "$machine" = "Jet" ]]; then export MPI_BUFS_PER_HOST=256 export MPI_GROUP_MAX=256 export APRUN="srun" +elif [[ "$machine" = "Gaea" ]]; then + export OMP_STACKSIZE=1024M + export MPI_BUFS_PER_PROC=256 + export MPI_BUFS_PER_HOST=256 + export MPI_GROUP_MAX=256 + export APRUN="srun --export=ALL --mpi=pmi2 -n \$size" elif [[ "$machine" = "Cheyenne" ]]; then export OMP_STACKSIZE=1024M export MPI_BUFS_PER_PROC=256 diff --git a/regression/regression_var.sh b/regression/regression_var.sh index 05b5563ef1..e883a5b1c8 100755 --- a/regression/regression_var.sh +++ b/regression/regression_var.sh @@ -49,6 +49,20 @@ fi echo "Running Regression Tests on '$machine'"; case $machine in + Gaea) + export queue="batch" + export noscrub="/lustre/f2/scratch/$LOGNAME/gsi_tmp/noscrub" + export ptmp="/lustre/f2/scratch/$LOGNAME/gsi_tmp/ptmp" + export casesdir="/lustre/f2/dev/role.epic/contrib/GSI_data/CASES/regtest" + + export group="global" + if [[ "$cmaketest" = "false" ]]; then + export basedir="/lustre/f2/dev/$LOGNAME/sandbox/GSI" + fi + + export check_resource="no" + export accnt="nggps_emc" + ;; Cheyenne) export queue="economy" export noscrub="/glade/scratch/$LOGNAME" diff --git a/ush/build.sh b/ush/build.sh index 71674c4f4c..f706f413c1 100755 --- a/ush/build.sh +++ b/ush/build.sh @@ -30,12 +30,13 @@ set -x # Set CONTROLPATH variable to user develop installation CONTROLPATH="$DIR_ROOT/../develop/install/bin" - +CMAKELIBS=".so .a" +CMAKE_OPTS+=" -DCMAKE_FIND_LIBRARY_SUFFIXES=${CMAKELIBS}" # Collect BUILD Options CMAKE_OPTS+=" -DCMAKE_BUILD_TYPE=$BUILD_TYPE" # Install destination for built executables, libraries, CMake Package config -CMAKE_OPTS+=" -DCMAKE_INSTALL_PREFIX=$INSTALL_PREFIX" +CMAKE_OPTS+=" -DCMAKE_INSTALL_PREFIX=${INSTALL_PREFIX}" # Configure for GSI and EnKF CMAKE_OPTS+=" -DGSI_MODE=$GSI_MODE -DENKF_MODE=${ENKF_MODE}" @@ -44,7 +45,7 @@ CMAKE_OPTS+=" -DGSI_MODE=$GSI_MODE -DENKF_MODE=${ENKF_MODE}" [[ ${REGRESSION_TESTS} =~ [yYtT] ]] && CMAKE_OPTS+=" -DBUILD_REG_TESTING=ON -DCONTROLPATH=${CONTROLPATH:-}" # Re-use or create a new BUILD_DIR (Default: create new BUILD_DIR) -[[ ${BUILD_CLEAN:-"YES"} =~ [yYtT] ]] && rm -rf $BUILD_DIR +[[ ${BUILD_CLEAN:-"YES"} =~ [yYtT] ]] && rm -rf $BUILD_DIR && echo "Removing $BUILD_DIR" mkdir -p $BUILD_DIR && cd $BUILD_DIR # Configure, build, install diff --git a/ush/module-setup.sh b/ush/module-setup.sh index 469fd4a3c5..207dbba925 100755 --- a/ush/module-setup.sh +++ b/ush/module-setup.sh @@ -57,32 +57,8 @@ elif [[ $MACHINE_ID = gaea* ]] ; then # /etc/profile here. source /etc/profile __ms_source_etc_profile=yes - else - __ms_source_etc_profile=no - fi - module purge - # clean up after purge - unset _LMFILES_ - unset _LMFILES_000 - unset _LMFILES_001 - unset LOADEDMODULES - module load modules - if [[ -d /opt/cray/ari/modulefiles ]] ; then - module use -a /opt/cray/ari/modulefiles - fi - if [[ -d /opt/cray/pe/ari/modulefiles ]] ; then - module use -a /opt/cray/pe/ari/modulefiles - fi - if [[ -d /opt/cray/pe/craype/default/modulefiles ]] ; then - module use -a /opt/cray/pe/craype/default/modulefiles - fi - if [[ -s /etc/opt/cray/pe/admin-pe/site-config ]] ; then - source /etc/opt/cray/pe/admin-pe/site-config - fi - if [[ "$__ms_source_etc_profile" == yes ]] ; then - source /etc/profile - unset __ms_source_etc_profile fi + source /lustre/f2/dev/role.epic/contrib/Lmod_init.sh elif [[ $MACHINE_ID = expanse* ]]; then # We are on SDSC Expanse diff --git a/ush/sub_gaea b/ush/sub_gaea new file mode 100755 index 0000000000..5c755e6930 --- /dev/null +++ b/ush/sub_gaea @@ -0,0 +1,166 @@ +#!/bin/sh --login +set -x +usage="\ +Usage: $0 [options] executable [args] + where the options are: + -a account account (default: none) + -b binding run smt binding or not (default:NO) + -d dirin initial directory (default: cwd) + -e envars copy comma-separated environment variables + -g group group name + -i append standard input to command file + -j jobname specify jobname (default: executable basename) + -m machine machine on which to run (default: current) + -n write command file to stdout rather than submitting it + -o output specify output file (default: jobname.out) + -p procs[/nodes[/ppreq] + number of MPI tasks and optional nodes or Bblocking and + ppreq option (N or S) (defaults: serial, Bunlimited, S) + -q queue[/qpreq] queue name and optional requirement, e.g. dev/P + (defaults: 1 if serial or dev if parallel and none) + (queue 3 or 4 is dev or prod with twice tasks over ip) + (options: P=parallel, B=bigmem, b=batch) + -r rmem[/rcpu] resources memory and cpus/task (default: '1024 mb', 1) + -t timew wall time limit in [[hh:]mm:]ss format (default: 900) + -u userid userid to run under (default: self) + -v verbose mode + -w when when to run, in yyyymmddhh[mm], +hh[mm], thh[mm], or + Thh[mm] (full, incremental, today or tomorrow) format + (default: now) +Function: This command submits a job to the batch queue." +subcmd="$*" +stdin=NO +nosub=NO +account="" +binding="NO" +dirin="" +envars="" +group="" +jobname="" +machine="" +output="" +procs=0 +nodes="" +ppreq="" +queue="" +qpreq="" +rmem="1024" +rcpu="1" +timew="900" +userid="" +verbose=NO +when="" +while getopts a:b:d:e:g:ij:m:no:p:q:r:t:u:vw: opt;do + case $opt in + a) account="$OPTARG";; + b) binding="$OPTARG";; + d) dirin="$OPTARG";; + e) envars="$OPTARG";; + g) group="$OPTARG";; + i) stdin=YES;; + j) jobname=$OPTARG;; + m) machine="$OPTARG";; + n) nosub=YES;; + o) output=$OPTARG;; + p) procs=$(echo $OPTARG/|cut -d/ -f1);nodes=$(echo $OPTARG/|cut -d/ -f2);ppreq=$(echo $OPTARG/|cut -d/ -f3);; + q) queue=$(echo $OPTARG/|cut -d/ -f1);qpreq=$(echo $OPTARG/|cut -d/ -f2);; + r) rmem=$(echo $OPTARG/|cut -d/ -f1);rcpu=$(echo $OPTARG/|cut -d/ -f2);; + t) timew=$OPTARG;; + u) userid=$OPTARG;; + v) verbose=YES;; + w) when=$OPTARG;; + \?) echo $0: invalid option >&2;echo "$usage" >&2;exit 1;; + esac +done +shift $(($OPTIND-1)) +if [[ $# -eq 0 ]];then + echo $0: missing executable name >&2;echo "$usage" >&2;exit 1 +fi +exec=$1 +if [[ ! -s $exec ]]&&which $exec >/dev/null 2>&1;then + exec=$(which $exec) +fi +shift +args="$*" +bn=$(basename $exec) +export jobname=${jobname:-$bn} +output=${output:-$jobname.out} +myuser=$LOGNAME +myhost=$(hostname) + +if [ -d /lustre/f2/scratch/$LOGNAME ]; then + DATA=/lustre/f2/scratch/$LOGNAME/tmp +fi +DATA=${DATA:-$ptmp/tmp} + +mkdir -p $DATA + +queue=${queue:-batch} +timew=${timew:-01:20:00} +task_node=${task_node:-$procs} +export size=$((nodes*task_node)) +echo "In sub_gaea: task_node, nodes, size=",$task_node,$nodes,$size +envars=$envars +threads=${rcpu:-1} + +export TZ=GMT +cfile=$DATA/sub$$ +> $cfile +echo "#!/bin/bash -l" >> $cfile +echo "" >> $cfile +echo "#SBATCH --output=$output" >> $cfile +echo "#SBATCH --job-name=$jobname" >> $cfile +echo "#SBATCH --qos=normal" >> $cfile +echo "#SBATCH --clusters=c4" >> $cfile +echo "#SBATCH --time=$timew" >> $cfile +echo "#SBATCH --nodes=$nodes --ntasks-per-node=$procs --cpus-per-task=$threads" >> $cfile +echo "#SBATCH --account=nggps_emc" >> $cfile +echo "#SBATCH --mem=0" >> $cfile + +echo "" >>$cfile +echo "export OMP_NUM_THREADS=$threads" >> $cfile +echo "" >>$cfile +echo ". "$(awk '{ print $1, $2, $3, $4, $5, $6, $7, $8, $9 }' $regdir/regression_var.out) >>$cfile +echo "" >>$cfile + +echo "source /lustre/f2/dev/role.epic/contrib/Lmod_init.sh" >> $cfile +echo "module use $gsisrc/modulefiles" >> $cfile +echo "module load gsi_gaea" >> $cfile +echo "module list" >> $cfile +echo "" >>$cfile + +cat $exec >> $cfile + +if [[ $nosub = YES ]];then + cat $cfile + exit +elif [[ $verbose = YES ]];then + set -x + cat $cfile +fi + +if [[ $stdin = YES ]];then + cat +fi >>$cfile +if [[ $nosub = YES ]];then + cat $cfile + exit +elif [[ $verbose = YES ]];then + set -x + cat $cfile +fi +sbatch=${sbatch:-sbatch} + +ofile=$DATA/subout$$ +>$ofile +chmod 777 $ofile +$sbatch $cfile >$ofile +rc=$? +cat $ofile +if [[ -w $SUBLOG ]];then + jobn=$(grep -i submitted $ofile|head -n1|cut -d\" -f2) + date -u +"%Y%m%d%H%M%S : $subcmd : $jobn" >>$SUBLOG +fi +#rm $cfile $ofile +#[[ $MKDATA = YES ]] && rmdir $DATA +exit $rc From fe42c85e7e32785429bf69fcbc53fd1e3b70645e Mon Sep 17 00:00:00 2001 From: Natalie Perlin Date: Mon, 26 Jun 2023 12:19:22 -0400 Subject: [PATCH 21/44] Intel 2022 for Gaea,update tests scripts for Gaea, Cheyenne, Orion, Jet --- regression/regression_driver.sh | 2 +- regression/regression_param.sh | 46 +++++---- regression/regression_var.sh | 20 ++-- ush/build.sh | 4 +- ush/sub_cheyenne | 169 ++++++++++++++++++++++++++++++++ ush/sub_gaea | 16 +-- ush/sub_jet | 52 ++-------- 7 files changed, 224 insertions(+), 85 deletions(-) create mode 100644 ush/sub_cheyenne diff --git a/regression/regression_driver.sh b/regression/regression_driver.sh index 58ebf64e85..96200c0363 100755 --- a/regression/regression_driver.sh +++ b/regression/regression_driver.sh @@ -42,7 +42,7 @@ for jn in `seq ${RSTART} ${REND}`; do fi rm -f ${job[$jn]}.out - /bin/sh $ush/$sub_cmd -q $queue -j ${job[$jn]} -t ${topts[$jn]} -p ${popts[$jn]} -r ${ropts[$jn]} $scripts/${regtest}.sh >& $ush/sub_cmd.${job[$jn]}.out + /bin/sh $ush/$sub_cmd -q $queue -j ${job[$jn]} -t ${topts[$jn]} -p ${popts[$jn]} -r ${ropts[$jn]} $scripts/${regtest}.sh if [ $debug == ".true." ]; then break; fi $scripts/regression_wait.sh ${job[$jn]} ${rcname} $check_resource diff --git a/regression/regression_param.sh b/regression/regression_param.sh index ea597fe0ae..79a91bde8e 100755 --- a/regression/regression_param.sh +++ b/regression/regression_param.sh @@ -33,7 +33,9 @@ case $machine in sub_cmd="sub_discover" ;; Cheyenne) - sub_cmd="sub_ncar -a p48503002 -q economy -d $PWD" + sub_cmd="sub_cheyenne" + memnode=128 + numcore=36 ;; *) # EXIT out for unresolved machine echo "unknown $machine" @@ -61,11 +63,11 @@ case $regtest in topts[1]="0:15:00" ; popts[1]="12/5/" ; ropts[1]="/1" topts[2]="0:15:00" ; popts[2]="12/9/" ; ropts[2]="/2" elif [[ "$machine" = "Cheyenne" ]]; then - topts[1]="0:30:00" ; popts[1]="16/2/" ; ropts[1]="/1" - topts[2]="0:30:00" ; popts[2]="16/4/" ; ropts[2]="/2" + topts[1]="0:15:00" ; popts[1]="16/2/" ; ropts[1]="/1" + topts[2]="0:15:00" ; popts[2]="16/4/" ; ropts[2]="/2" elif [[ "$machine" = "Gaea" ]]; then - topts[1]="0:30:00" ; popts[1]="18/2/" ; ropts[1]="/1" - topts[2]="0:30:00" ; popts[2]="18/4/" ; ropts[2]="/2" + topts[1]="0:15:00" ; popts[1]="18/2/" ; ropts[1]="/1" + topts[2]="0:15:00" ; popts[2]="18/4/" ; ropts[2]="/2" elif [[ "$machine" = "wcoss2" ]]; then topts[1]="0:15:00" ; popts[1]="12/5/" ; ropts[1]="/1" topts[2]="0:15:00" ; popts[2]="12/9/" ; ropts[2]="/2" @@ -94,11 +96,11 @@ case $regtest in topts[1]="0:15:00" ; popts[1]="12/3/" ; ropts[1]="/1" topts[2]="0:15:00" ; popts[2]="12/5/" ; ropts[2]="/2" elif [[ "$machine" = "Cheyenne" ]]; then - topts[1]="0:35:00" ; popts[1]="16/2/" ; ropts[1]="/1" - topts[2]="0:25:00" ; popts[2]="16/4/" ; ropts[2]="/2" + topts[1]="0:15:00" ; popts[1]="12/3/" ; ropts[1]="/1" + topts[2]="0:15:00" ; popts[2]="12/5/" ; ropts[2]="/2" elif [[ "$machine" = "Gaea" ]]; then - topts[1]="0:35:00" ; popts[1]="18/2/" ; ropts[1]="/1" - topts[2]="0:25:00" ; popts[2]="18/4/" ; ropts[2]="/2" + topts[1]="0:15:00" ; popts[1]="18/2/" ; ropts[1]="/1" + topts[2]="0:15:00" ; popts[2]="18/4/" ; ropts[2]="/2" elif [[ "$machine" = "wcoss2" ]]; then topts[1]="0:15:00" ; popts[1]="28/2/" ; ropts[1]="/1" topts[2]="0:15:00" ; popts[2]="28/4/" ; ropts[2]="/2" @@ -142,8 +144,8 @@ case $regtest in topts[1]="0:30:00" ; popts[1]="48/2" ; ropts[1]="/1" topts[2]="0:30:00" ; popts[2]="60/3" ; ropts[2]="/2" elif [[ "$machine" = "Cheyenne" ]]; then - topts[1]="1:59:00" ; popts[1]="6/8/" ; ropts[1]="/1" - topts[2]="0:35:00" ; popts[2]="6/10/" ; ropts[2]="/2" + topts[1]="0:10:00" ; popts[1]="12/8/" ; ropts[1]="/1" + topts[2]="0:10:00" ; popts[2]="12/10/" ; ropts[2]="/2" elif [[ "$machine" = "Gaea" ]]; then topts[1]="0:10:00" ; popts[1]="18/8/" ; ropts[1]="/1" topts[2]="0:10:00" ; popts[2]="18/10/" ; ropts[2]="/2" @@ -171,6 +173,9 @@ case $regtest in elif [[ "$machine" = "Jet" ]]; then topts[1]="0:15:00" ; popts[1]="20/1/" ; ropts[1]="/1" topts[2]="0:15:00" ; popts[2]="20/2/" ; ropts[2]="/1" + elif [[ "$machine" = "Cheyenne" ]]; then + topts[1]="0:15:00" ; popts[1]="20/1/" ; ropts[1]="/1" + topts[2]="0:15:00" ; popts[2]="20/2/" ; ropts[2]="/2" elif [[ "$machine" = "Gaea" ]]; then topts[1]="0:15:00" ; popts[1]="18/1/" ; ropts[1]="/1" topts[2]="0:15:00" ; popts[2]="18/2/" ; ropts[2]="/1" @@ -198,6 +203,9 @@ case $regtest in elif [[ "$machine" = "Jet" ]]; then topts[1]="0:15:00" ; popts[1]="4/4/" ; ropts[1]="/1" topts[2]="0:15:00" ; popts[2]="6/6/" ; ropts[2]="/1" + elif [[ "$machine" = "Cheyenne" ]]; then + topts[1]="0:15:00" ; popts[1]="4/4/" ; ropts[1]="/1" + topts[2]="0:15:00" ; popts[2]="6/6/" ; ropts[2]="/2" elif [[ "$machine" = "Gaea" ]]; then topts[1]="0:15:00" ; popts[1]="4/4/" ; ropts[1]="/1" topts[2]="0:15:00" ; popts[2]="6/6/" ; ropts[2]="/1" @@ -226,8 +234,8 @@ case $regtest in topts[1]="0:30:00" ; popts[1]="6/12/" ; ropts[1]="/1" topts[2]="0:30:00" ; popts[2]="8/12/" ; ropts[2]="/1" elif [[ "$machine" = "Cheyenne" ]]; then - topts[1]="0:15:00" ; popts[1]="8/6/" ; ropts[1]="/1" - topts[2]="0:15:00" ; popts[2]="8/8/" ; ropts[2]="/1" + topts[1]="0:30:00" ; popts[1]="6/12/" ; ropts[1]="/1" + topts[2]="0:30:00" ; popts[2]="8/12/" ; ropts[2]="/1" elif [[ "$machine" = "Gaea" ]]; then topts[1]="0:30:00" ; popts[1]="8/6/" ; ropts[1]="/1" topts[2]="0:30:00" ; popts[2]="8/8/" ; ropts[2]="/1" @@ -286,8 +294,8 @@ case $regtest in topts[1]="0:10:00" ; popts[1]="12/3/" ; ropts[1]="/1" topts[2]="0:10:00" ; popts[2]="12/5/" ; ropts[2]="/2" elif [[ "$machine" = "Cheyenne" ]]; then - topts[1]="0:15:00" ; popts[1]="16/2/" ; ropts[1]="/1" - topts[2]="0:15:00" ; popts[2]="16/4/" ; ropts[2]="/2" + topts[1]="0:15:00" ; popts[1]="12/3/" ; ropts[1]="/1" + topts[2]="0:15:00" ; popts[2]="12/5/" ; ropts[2]="/2" elif [[ "$machine" = "Gaea" ]]; then topts[1]="0:10:00" ; popts[1]="12/3/" ; ropts[1]="/1" topts[2]="0:10:00" ; popts[2]="12/5/" ; ropts[2]="/2" @@ -341,25 +349,25 @@ if [[ "$machine" = "Hera" ]]; then export APRUN="srun" elif [[ "$machine" = "Orion" ]]; then export OMP_STACKSIZE=2048M - export APRUN="srun -n \$ntasks" + export APRUN="srun --label -n \$ntasks" elif [[ "$machine" = "Jet" ]]; then export OMP_STACKSIZE=1024M export MPI_BUFS_PER_PROC=256 export MPI_BUFS_PER_HOST=256 export MPI_GROUP_MAX=256 - export APRUN="srun" + export APRUN="srun --label -n \$ntasks --cpus-per-task=\$threads" elif [[ "$machine" = "Gaea" ]]; then export OMP_STACKSIZE=1024M export MPI_BUFS_PER_PROC=256 export MPI_BUFS_PER_HOST=256 export MPI_GROUP_MAX=256 - export APRUN="srun --export=ALL --mpi=pmi2 -n \$size" + export APRUN="srun --export=ALL --mpi=pmi2 -n \$ntasks" elif [[ "$machine" = "Cheyenne" ]]; then export OMP_STACKSIZE=1024M export MPI_BUFS_PER_PROC=256 export MPI_BUFS_PER_HOST=256 export MPI_GROUP_MAX=256 - export APRUN="mpirun -v -np \$NCPUS" + export APRUN="mpirun -v -np \$ntasks" elif [[ "$machine" = "wcoss2" ]]; then export OMP_PLACES=cores export OMP_STACKSIZE=2G diff --git a/regression/regression_var.sh b/regression/regression_var.sh index e883a5b1c8..ed80739ae6 100755 --- a/regression/regression_var.sh +++ b/regression/regression_var.sh @@ -64,18 +64,18 @@ case $machine in export accnt="nggps_emc" ;; Cheyenne) - export queue="economy" - export noscrub="/glade/scratch/$LOGNAME" + export queue="regular" + export noscrub="/glade/scratch/$LOGNAME/tmp_gsi/noscrub" export group="global" if [[ "$cmaketest" = "false" ]]; then - export basedir="/glade/scratch/$LOGNAME/gsi" + export basedir="/glade/scratch/$LOGNAME/tmp_gsi" fi - export ptmp="/glade/scratch/$LOGNAME/$ptmpName" + export ptmp="/glade/scratch/$LOGNAME/tmp_gsi/ptmp" - export casesdir="/glade/p/ral/jntp/tools/CASES" + export casesdir="/glade/work/epicufsrt/contrib/GSI_data/CASES/regtest" export check_resource="no" - export accnt="p48503002" + export accnt="NRAL0032" ;; wcoss2) export local_or_default="${local_or_default:-/lfs/h2/emc/da/noscrub/$LOGNAME}" @@ -98,7 +98,7 @@ case $machine in export accnt="${accnt:-GFS-DEV}" ;; Orion) - export local_or_default="${local_or_default:-/work/noaa/da/$LOGNAME}" + export local_or_default="${local_or_default:-/work/noaa/epic-ps/$LOGNAME}" if [ -d $local_or_default ]; then export noscrub="$local_or_default/noscrub" elif [ -d /work/noaa/global/$LOGNAME ]; then @@ -108,14 +108,14 @@ case $machine in export queue="${queue:-batch}" export group="${group:-global}" if [[ "$cmaketest" = "false" ]]; then - export basedir="/work/noaa/da/$LOGNAME/gsi" + export basedir="/work/noaa/epic-ps/$LOGNAME/gsi" fi - export ptmp="${ptmp:-/work/noaa/stmp/$LOGNAME/$ptmpName}" + export ptmp="${ptmp:-/work/noaa/epic-ps/$LOGNAME/ptmp}" export casesdir="/work/noaa/da/rtreadon/CASES/regtest" export check_resource="no" - export accnt="${accnt:-da-cpu}" + export accnt="${accnt:-epic}" ;; Hera) diff --git a/ush/build.sh b/ush/build.sh index f706f413c1..c7f27b61e2 100755 --- a/ush/build.sh +++ b/ush/build.sh @@ -30,8 +30,6 @@ set -x # Set CONTROLPATH variable to user develop installation CONTROLPATH="$DIR_ROOT/../develop/install/bin" -CMAKELIBS=".so .a" -CMAKE_OPTS+=" -DCMAKE_FIND_LIBRARY_SUFFIXES=${CMAKELIBS}" # Collect BUILD Options CMAKE_OPTS+=" -DCMAKE_BUILD_TYPE=$BUILD_TYPE" @@ -45,7 +43,7 @@ CMAKE_OPTS+=" -DGSI_MODE=$GSI_MODE -DENKF_MODE=${ENKF_MODE}" [[ ${REGRESSION_TESTS} =~ [yYtT] ]] && CMAKE_OPTS+=" -DBUILD_REG_TESTING=ON -DCONTROLPATH=${CONTROLPATH:-}" # Re-use or create a new BUILD_DIR (Default: create new BUILD_DIR) -[[ ${BUILD_CLEAN:-"YES"} =~ [yYtT] ]] && rm -rf $BUILD_DIR && echo "Removing $BUILD_DIR" +[[ ${BUILD_CLEAN:-"YES"} =~ [yYtT] ]] && rm -rf $BUILD_DIR mkdir -p $BUILD_DIR && cd $BUILD_DIR # Configure, build, install diff --git a/ush/sub_cheyenne b/ush/sub_cheyenne new file mode 100644 index 0000000000..cb671ce8c1 --- /dev/null +++ b/ush/sub_cheyenne @@ -0,0 +1,169 @@ +#!/bin/sh --login +set -x +echo "starting sub_cheyenne" +usage="\ +Usage: $0 [options] executable [args] + where the options are: + -a account account (default: none) + -b binding run smt binding or not (default:NO) + -d dirin initial directory (default: cwd) + -e envars copy comma-separated environment variables + -g group group name + -i append standard input to command file + -j jobname specify jobname (default: executable basename) + -m machine machine on which to run (default: current) + -n write command file to stdout rather than submitting it + -o output specify output file (default: jobname.out) + -p procs[/nodes[/ppreq] + number of MPI tasks and optional nodes or Bblocking and + ppreq option (N or S) (defaults: serial, Bunlimited, S) + -q queue[/qpreq] queue name and optional requirement, e.g. dev/P + (defaults: 1 if serial or dev if parallel and none) + (queue 3 or 4 is dev or prod with twice tasks over ip) + (options: P=parallel, B=bigmem, b=batch) + -r rmem[/rcpu] resources memory and cpus/task (default: '1024 mb', 1) + -t timew wall time limit in [[hh:]mm:]ss format (default: 900) + -u userid userid to run under (default: self) + -v verbose mode + -w when when to run, in yyyymmddhh[mm], +hh[mm], thh[mm], or + Thh[mm] (full, incremental, today or tomorrow) format + (default: now) +Function: This command submits a job to the batch queue." +subcmd="$*" +stdin=NO +nosub=NO +account="" +binding="NO" +dirin="" +envars="" +group="" +jobname="" +machine="" +output="" +procs=0 +nodes="" +ppreq="" +queue="" +qpreq="" +rmem="1024" +rcpu="1" +timew="900" +userid="" +verbose=NO +when="" +while getopts a:b:d:e:g:ij:m:no:p:q:r:t:u:vw: opt;do + case $opt in + a) account="$OPTARG";; + b) binding="$OPTARG";; + d) dirin="$OPTARG";; + e) envars="$OPTARG";; + g) group="$OPTARG";; + i) stdin=YES;; + j) jobname=$OPTARG;; + m) machine="$OPTARG";; + n) nosub=YES;; + o) output=$OPTARG;; + p) procs=$(echo $OPTARG/|cut -d/ -f1);nodes=$(echo $OPTARG/|cut -d/ -f2);ppreq=$(echo $OPTARG/|cut -d/ -f3);; + q) queue=$(echo $OPTARG/|cut -d/ -f1);qpreq=$(echo $OPTARG/|cut -d/ -f2);; + r) rmem=$(echo $OPTARG/|cut -d/ -f1);rcpu=$(echo $OPTARG/|cut -d/ -f2);; + t) timew=$OPTARG;; + u) userid=$OPTARG;; + v) verbose=YES;; + w) when=$OPTARG;; + \?) echo $0: invalid option >&2;echo "$usage" >&2;exit 1;; + esac +done +shift $(($OPTIND-1)) +if [[ $# -eq 0 ]];then + echo $0: missing executable name >&2;echo "$usage" >&2;exit 1 +fi +exec=$1 +if [[ ! -s $exec ]]&&which $exec >/dev/null 2>&1;then + exec=$(which $exec) +fi +shift +args="$*" +bn=$(basename $exec) +export jobname=${jobname:-$bn} +output=${output:-$jobname.out} +myuser=$LOGNAME +myhost=$(hostname) + +DATA=/glade/scratch/$LOGNAME/tmp +mkdir -p $DATA + +timew=${timew:-01:20:00} +task_node=${task_node:-$procs} +size=$((nodes*task_node)) +envars=$envars +threads=${rcpu:-1} + +export TZ=GMT +cfile=$DATA/sub$$ +> $cfile +echo "#!/bin/sh --login" >> $cfile +echo "" >> $cfile +echo "#PBS -o $output" >> $cfile +echo "#PBS -N $jobname" >> $cfile +echo "#PBS -q $queue" >> $cfile +echo "#PBS -l walltime=$timew" >> $cfile +echo "#PBS -l select=$nodes:ncpus=$procs:mpiprocs=$procs" >> $cfile +echo "#PBS -j oe" >> $cfile +echo "#PBS -A $accnt" >> $cfile +echo "#PBS -V" >> $cfile + +echo "" >>$cfile +echo "export ntasks=$(( $nodes * $procs ))" >> $cfile +echo "export ppn=$procs" >> $cfile +echo "export threads=$threads" >> $cfile +echo "export OMP_NUM_THREADS=$threads" >> $cfile +echo "ulimit -s unlimited" >> $cfile +echo "" >>$cfile +echo ". "$(awk '{ print $1, $2, $3, $4, $5, $6, $7, $8, $9 }' $regdir/regression_var.out) >>$cfile +echo "" >>$cfile + +echo "cfile = $cfile" +echo "source /glade/u/apps/ch/modulefiles/default/localinit/localinit.sh >> $cfile" +echo "module purge" >> $cfile +echo "module use $gsisrc/modulefiles" >> $cfile +echo "module load gsi_cheyenne.intel" >> $cfile +echo "module list" >> $cfile + +cat $exec >> $cfile + +if [[ $nosub = YES ]];then + cat $cfile + exit +elif [[ $verbose = YES ]];then + set -x + cat $cfile +fi + + +if [[ $stdin = YES ]];then + cat +fi >>$cfile +if [[ $nosub = YES ]];then + cat $cfile + exit +elif [[ $verbose = YES ]];then + set -x + cat $cfile +fi +qsub=${qsub:-qsub} + +ofile=$DATA/subout$$ +>$ofile +chmod 777 $ofile +$qsub $cfile >$ofile +rc=$? +cat $ofile +if [[ -w $SUBLOG ]];then + jobn=$(grep -i submitted $ofile|head -n1|cut -d\" -f2) + date -u +"%Y%m%d%H%M%S : $subcmd : $jobn" >>$SUBLOG +fi +rm $cfile $ofile +[[ $MKDATA = YES ]] && rmdir $DATA +echo "ending sub_cheyenne" +exit $rc + diff --git a/ush/sub_gaea b/ush/sub_gaea index 5c755e6930..3a9526b0d1 100755 --- a/ush/sub_gaea +++ b/ush/sub_gaea @@ -98,8 +98,7 @@ mkdir -p $DATA queue=${queue:-batch} timew=${timew:-01:20:00} task_node=${task_node:-$procs} -export size=$((nodes*task_node)) -echo "In sub_gaea: task_node, nodes, size=",$task_node,$nodes,$size +size=$((nodes*task_node)) envars=$envars threads=${rcpu:-1} @@ -114,11 +113,16 @@ echo "#SBATCH --qos=normal" echo "#SBATCH --clusters=c4" >> $cfile echo "#SBATCH --time=$timew" >> $cfile echo "#SBATCH --nodes=$nodes --ntasks-per-node=$procs --cpus-per-task=$threads" >> $cfile -echo "#SBATCH --account=nggps_emc" >> $cfile +echo "#SBATCH --account=$accnt" >> $cfile echo "#SBATCH --mem=0" >> $cfile echo "" >>$cfile +echo "export ntasks=$(( $nodes * $procs ))" >> $cfile +echo "export ppn=$procs" >> $cfile +echo "export threads=$threads" >> $cfile echo "export OMP_NUM_THREADS=$threads" >> $cfile +echo "ulimit -s unlimited" >> $cfile + echo "" >>$cfile echo ". "$(awk '{ print $1, $2, $3, $4, $5, $6, $7, $8, $9 }' $regdir/regression_var.out) >>$cfile echo "" >>$cfile @@ -154,13 +158,13 @@ sbatch=${sbatch:-sbatch} ofile=$DATA/subout$$ >$ofile chmod 777 $ofile -$sbatch $cfile >$ofile +$sbatch --export=ALL $cfile >$ofile rc=$? cat $ofile if [[ -w $SUBLOG ]];then jobn=$(grep -i submitted $ofile|head -n1|cut -d\" -f2) date -u +"%Y%m%d%H%M%S : $subcmd : $jobn" >>$SUBLOG fi -#rm $cfile $ofile -#[[ $MKDATA = YES ]] && rmdir $DATA +rm $cfile $ofile +[[ $MKDATA = YES ]] && rmdir $DATA exit $rc diff --git a/ush/sub_jet b/ush/sub_jet index e11be1280c..e394a0c09e 100755 --- a/ush/sub_jet +++ b/ush/sub_jet @@ -98,16 +98,10 @@ task_node=${task_node:-$procs} size=$((nodes*task_node)) envars=$envars threads=${rcpu:-1} -#envars=$envars,mpi_tasks=$procs -#Options -###PBS -l partition=c1ms,size=0528,walltime=01:20:00 -##PBS -l partition=$queue,size=$size,walltime=$timew -##PBS -S /bin/sh export TZ=GMT cfile=$DATA/sub$$ > $cfile -#echo "#PBS -S /bin/sh" >> $cfile echo "#!/bin/sh --login" >> $cfile echo "" >> $cfile echo "#SBATCH --output=$output" >> $cfile @@ -115,17 +109,17 @@ echo "#SBATCH --job-name=$jobname" echo "#SBATCH --qos=$queue" >> $cfile echo "#SBATCH --time=$timew" >> $cfile echo "#SBATCH --nodes=$nodes --ntasks-per-node=$procs --cpus-per-task=$threads" >> $cfile -#echo "#SBATCH -j oe" >> $cfile echo "#SBATCH --account=$accnt" >> $cfile echo "#SBATCH --mem=0" >> $cfile -echo "#SBATCH --partition=kjet" >> $cfile -#echo "#SBATCH -V" >> $cfile -#echo "#PBS -d" >> $cfile -#. $exec >> $cfile -#echo "/bin/sh -x $exec" >> $cfile +echo "#SBATCH --partition=xjet" >> $cfile echo "" >>$cfile +echo "export ntasks=$(( $nodes * $procs ))" >> $cfile +echo "export ppn=$procs" >> $cfile +echo "export threads=$threads" >> $cfile echo "export OMP_NUM_THREADS=$threads" >> $cfile +echo "ulimit -s unlimited" >> $cfile + echo "" >>$cfile echo ". "$(awk '{ print $1, $2, $3, $4, $5, $6, $7, $8, $9 }' $regdir/regression_var.out) >>$cfile echo "" >>$cfile @@ -146,40 +140,6 @@ elif [[ $verbose = YES ]];then set -x cat $cfile fi -#msub -I partition=$partition,size=$procs,walltime=$walltime $cfile - -#if [[ -n $when ]];then -# whena=$when -# if [[ $when = +* ]];then -# hr=$(echo $when|cut -c2-3) -# mn=$(echo $when|cut -c4-5) -# [[ -n $mn ]] || mn=00 -# now=$(date -u +"%Y%m%d%H%M") -# ((mn+=$(echo $now|cut -c11-12))) -# [[ $mn -ge 60 ]] && ((hr+=1)) && ((mn-=60)) -# [[ $mn -lt 10 ]] && mn=0$mn -# whena=$(/nwprod/util/exec/ndate +$hr $(echo $now|cut -c1-10))$mn -# elif [[ $when = t* ]];then -# hr=$(echo $when|cut -c2-3) -# mn=$(echo $when|cut -c4-5) -# [[ -n $mn ]] || mn=00 -# now=$(date -u +"%Y%m%d") -# whena=$now$hr$mn -# elif [[ $when = T* ]];then -# hr=$(echo $when|cut -c2-3) -# mn=$(echo $when|cut -c4-5) -# [[ -n $mn ]] || mn=00 -# now=$(date -u +"%Y%m%d%H") -# whena=$(/nwprod/util/exec/ndate +24 $now|cut -c1-8)$hr$mn -# fi -# yr=$(echo $whena|cut -c1-4) -# mo=$(echo $whena|cut -c5-6) -# dy=$(echo $whena|cut -c7-8) -# hr=$(echo $whena|cut -c9-10) -# mn=$(echo $whena|cut -c11-12) -# [[ -n $mn ]] || mn=00 -# echo "#@ startdate = $mo/$dy/$yr $hr:$mn" -#fi >>$cfile if [[ $stdin = YES ]];then From 3baf6c795ce776f9bf3b2a73a9be66e30fba0928 Mon Sep 17 00:00:00 2001 From: Natalie Perlin Date: Mon, 26 Jun 2023 12:51:23 -0400 Subject: [PATCH 22/44] update Cheyenne modulefile --- modulefiles/gsi_cheyenne.intel.lua | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/modulefiles/gsi_cheyenne.intel.lua b/modulefiles/gsi_cheyenne.intel.lua index d02a0c3885..4a3525bca1 100644 --- a/modulefiles/gsi_cheyenne.intel.lua +++ b/modulefiles/gsi_cheyenne.intel.lua @@ -8,7 +8,7 @@ load("intel/2022.1") load("mpt/2.25") load("ncarcompilers/0.5.0") -prepend_path("MODULEPATH", "/glade/work/epicufsrt/contrib/hpc-stack/intel2022.1") +prepend_path("MODULEPATH", "/glade/work/epicufsrt/contrib/hpc-stack/intel2022.1/modulefiles/stack") load("hpc/1.2.0") load("hpc-intel/2022.1") @@ -18,7 +18,7 @@ load("mkl/2022.1") load("gsi_common") load(pathJoin("prod_util", os.getenv("prod_util_ver") or "1.2.2")) -pushenv("GSI_BINARY_SOURCE_DIR", "/glade/work/epicufsrt/contrib/GSI_data/fix") +pushenv("GSI_BINARY_SOURCE_DIR", "/glade/work/epicufsrt/contrib/GSI_data/fix/20230601") pushenv("CFLAGS", "-xHOST") pushenv("FFLAGS", "-xHOST") From d3fe9a273f75990bc9514c701bed4883d35a2328 Mon Sep 17 00:00:00 2001 From: Natalie Perlin Date: Mon, 26 Jun 2023 13:45:24 -0400 Subject: [PATCH 23/44] updatesto scripts to address comments --- regression/regression_var.sh | 14 +++++++------- ush/sub_jet | 2 +- 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/regression/regression_var.sh b/regression/regression_var.sh index ed80739ae6..a3fe9e4e9d 100755 --- a/regression/regression_var.sh +++ b/regression/regression_var.sh @@ -65,12 +65,12 @@ case $machine in ;; Cheyenne) export queue="regular" - export noscrub="/glade/scratch/$LOGNAME/tmp_gsi/noscrub" + export noscrub="/glade/scratch/$LOGNAME/noscrub" export group="global" if [[ "$cmaketest" = "false" ]]; then - export basedir="/glade/scratch/$LOGNAME/tmp_gsi" + export basedir="/glade/scratch/$LOGNAME" fi - export ptmp="/glade/scratch/$LOGNAME/tmp_gsi/ptmp" + export ptmp="/glade/scratch/$LOGNAME/$ptmpName" export casesdir="/glade/work/epicufsrt/contrib/GSI_data/CASES/regtest" @@ -98,7 +98,7 @@ case $machine in export accnt="${accnt:-GFS-DEV}" ;; Orion) - export local_or_default="${local_or_default:-/work/noaa/epic-ps/$LOGNAME}" + export local_or_default="${local_or_default:-/work/noaa/da/$LOGNAME}" if [ -d $local_or_default ]; then export noscrub="$local_or_default/noscrub" elif [ -d /work/noaa/global/$LOGNAME ]; then @@ -108,14 +108,14 @@ case $machine in export queue="${queue:-batch}" export group="${group:-global}" if [[ "$cmaketest" = "false" ]]; then - export basedir="/work/noaa/epic-ps/$LOGNAME/gsi" + export basedir="/work/noaa/da/$LOGNAME/gsi" fi - export ptmp="${ptmp:-/work/noaa/epic-ps/$LOGNAME/ptmp}" + export ptmp="${ptmp:-/work/noaa/stmp/$LOGNAME/$ptmpName}" export casesdir="/work/noaa/da/rtreadon/CASES/regtest" export check_resource="no" - export accnt="${accnt:-epic}" + export accnt="${accnt:-da-cpu}" ;; Hera) diff --git a/ush/sub_jet b/ush/sub_jet index e394a0c09e..e45dcc0b3c 100755 --- a/ush/sub_jet +++ b/ush/sub_jet @@ -111,7 +111,7 @@ echo "#SBATCH --time=$timew" echo "#SBATCH --nodes=$nodes --ntasks-per-node=$procs --cpus-per-task=$threads" >> $cfile echo "#SBATCH --account=$accnt" >> $cfile echo "#SBATCH --mem=0" >> $cfile -echo "#SBATCH --partition=xjet" >> $cfile +echo "#SBATCH --partition=kjet" >> $cfile echo "" >>$cfile echo "export ntasks=$(( $nodes * $procs ))" >> $cfile From 7bd5f95f278deceea3c7b7118c5293c591a059fe Mon Sep 17 00:00:00 2001 From: Natalie Perlin Date: Mon, 26 Jun 2023 13:48:09 -0400 Subject: [PATCH 24/44] update regression/regression_driver.sh --- regression/regression_driver.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/regression/regression_driver.sh b/regression/regression_driver.sh index 96200c0363..b818089cad 100755 --- a/regression/regression_driver.sh +++ b/regression/regression_driver.sh @@ -42,7 +42,7 @@ for jn in `seq ${RSTART} ${REND}`; do fi rm -f ${job[$jn]}.out - /bin/sh $ush/$sub_cmd -q $queue -j ${job[$jn]} -t ${topts[$jn]} -p ${popts[$jn]} -r ${ropts[$jn]} $scripts/${regtest}.sh + /bin/sh $ush/$sub_cmd -q $queue -j ${job[$jn]} -t ${topts[$jn]} -p ${popts[$jn]} -r ${ropts[$jn]} $scripts/${regtest}.sh if [ $debug == ".true." ]; then break; fi $scripts/regression_wait.sh ${job[$jn]} ${rcname} $check_resource From e50cf96f927ead5ff5cc58f6186e26a6a9dec904 Mon Sep 17 00:00:00 2001 From: Natalie Perlin Date: Mon, 26 Jun 2023 13:49:22 -0400 Subject: [PATCH 25/44] update regression/regression_driver.sh --- regression/regression_driver.sh | 1 - 1 file changed, 1 deletion(-) diff --git a/regression/regression_driver.sh b/regression/regression_driver.sh index b818089cad..e1d3b18dc7 100755 --- a/regression/regression_driver.sh +++ b/regression/regression_driver.sh @@ -10,7 +10,6 @@ if [ -d "$config_path" ]; then source $config_path/local_vars.sh fi - # source the necessary files to setup if [ "$#" -eq 2 ]; then export regdir=$2 From a0e48e2183bf08d5622eb3bbaf7b5e17c5c9eb26 Mon Sep 17 00:00:00 2001 From: Natalie Perlin Date: Mon, 26 Jun 2023 13:52:49 -0400 Subject: [PATCH 26/44] update ush/build.sh --- ush/build.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/ush/build.sh b/ush/build.sh index c7f27b61e2..9a280c4e55 100755 --- a/ush/build.sh +++ b/ush/build.sh @@ -34,7 +34,7 @@ CONTROLPATH="$DIR_ROOT/../develop/install/bin" CMAKE_OPTS+=" -DCMAKE_BUILD_TYPE=$BUILD_TYPE" # Install destination for built executables, libraries, CMake Package config -CMAKE_OPTS+=" -DCMAKE_INSTALL_PREFIX=${INSTALL_PREFIX}" +CMAKE_OPTS+=" -DCMAKE_INSTALL_PREFIX=$INSTALL_PREFIX" # Configure for GSI and EnKF CMAKE_OPTS+=" -DGSI_MODE=$GSI_MODE -DENKF_MODE=${ENKF_MODE}" From 1d8beed1b8d55cb88c723267a58df191a812a141 Mon Sep 17 00:00:00 2001 From: Natalie Perlin Date: Tue, 27 Jun 2023 10:23:01 -0400 Subject: [PATCH 27/44] fixed typ inmodulefile for gaea --- modulefiles/gsi_gaea.lua | 3 --- 1 file changed, 3 deletions(-) diff --git a/modulefiles/gsi_gaea.lua b/modulefiles/gsi_gaea.lua index 4744e55c73..f76c8f3ad9 100644 --- a/modulefiles/gsi_gaea.lua +++ b/modulefiles/gsi_gaea.lua @@ -31,7 +31,4 @@ setenv("CXX","CC") pushenv("CRAYPE_LINK_TYPE","dynamic") whatis("Description: GSI environment on Gaea with Intel Compilers") -<<<<<<< HEAD -======= ->>>>>>> ming/intel2022 From e2398c7d542b5014311bf5792a0be6c25b8690b5 Mon Sep 17 00:00:00 2001 From: Natalie Perlin Date: Wed, 28 Jun 2023 00:12:12 -0400 Subject: [PATCH 28/44] ncdiag/1.1.1 for spack build --- ci/spack.yaml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/ci/spack.yaml b/ci/spack.yaml index 4374d8dd85..5d97fd48a0 100644 --- a/ci/spack.yaml +++ b/ci/spack.yaml @@ -19,7 +19,7 @@ spack: - wrf-io@1.2.0 - ncio@1.1.2 - crtm@2.4.0 - - gsi-ncdiag@1.1.0 + - gsi-ncdiag@1.1.1 view: true concretizer: unify: true From 164126b779a9e6af300af8110aa2e81152bd0106 Mon Sep 17 00:00:00 2001 From: Natalie Perlin Date: Wed, 28 Jun 2023 08:24:59 -0400 Subject: [PATCH 29/44] update ncdiag/1.1.1 --- modulefiles/gsi_gaea.lua | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/modulefiles/gsi_gaea.lua b/modulefiles/gsi_gaea.lua index f76c8f3ad9..25c765cab1 100644 --- a/modulefiles/gsi_gaea.lua +++ b/modulefiles/gsi_gaea.lua @@ -3,7 +3,7 @@ help([[ load("cmake/3.20.1") -prepend_path("MODULEPATH","/lustre/f2/dev/role.epic/contrib/hpc-stack/intel-classic-2022.0.2/modulefiles/stack") +prepend_path("MODULEPATH","/lustre/f2/dev/role.epic/contrib/hpc-stack/intel-classic-2022.0.2_ncdf492/modulefiles/stack") load(pathJoin("hpc", os.getenv("hpc_ver") or "1.2.0")) load(pathJoin("intel-classic", os.getenv("intel_classic_ver") or "2022.0.2")) From 8d6009b15b3bac7129a0c9402c37e382f9b0cb49 Mon Sep 17 00:00:00 2001 From: Natalie Perlin Date: Wed, 28 Jun 2023 09:39:20 -0400 Subject: [PATCH 30/44] gaea modulefile update --- modulefiles/gsi_gaea.lua | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/modulefiles/gsi_gaea.lua b/modulefiles/gsi_gaea.lua index 25c765cab1..f76c8f3ad9 100644 --- a/modulefiles/gsi_gaea.lua +++ b/modulefiles/gsi_gaea.lua @@ -3,7 +3,7 @@ help([[ load("cmake/3.20.1") -prepend_path("MODULEPATH","/lustre/f2/dev/role.epic/contrib/hpc-stack/intel-classic-2022.0.2_ncdf492/modulefiles/stack") +prepend_path("MODULEPATH","/lustre/f2/dev/role.epic/contrib/hpc-stack/intel-classic-2022.0.2/modulefiles/stack") load(pathJoin("hpc", os.getenv("hpc_ver") or "1.2.0")) load(pathJoin("intel-classic", os.getenv("intel_classic_ver") or "2022.0.2")) From 29a1bb66d4c6de186e2a9031c789214963df4a71 Mon Sep 17 00:00:00 2001 From: Natalie Perlin Date: Wed, 28 Jun 2023 09:45:31 -0400 Subject: [PATCH 31/44] updated test scripts for gaea --- regression/regression_var.sh | 2 +- ush/sub_gaea | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/regression/regression_var.sh b/regression/regression_var.sh index a3fe9e4e9d..d94e53a04d 100755 --- a/regression/regression_var.sh +++ b/regression/regression_var.sh @@ -50,7 +50,7 @@ echo "Running Regression Tests on '$machine'"; case $machine in Gaea) - export queue="batch" + export queue="normal" export noscrub="/lustre/f2/scratch/$LOGNAME/gsi_tmp/noscrub" export ptmp="/lustre/f2/scratch/$LOGNAME/gsi_tmp/ptmp" export casesdir="/lustre/f2/dev/role.epic/contrib/GSI_data/CASES/regtest" diff --git a/ush/sub_gaea b/ush/sub_gaea index 3a9526b0d1..b00e547a6a 100755 --- a/ush/sub_gaea +++ b/ush/sub_gaea @@ -109,7 +109,7 @@ echo "#!/bin/bash -l" echo "" >> $cfile echo "#SBATCH --output=$output" >> $cfile echo "#SBATCH --job-name=$jobname" >> $cfile -echo "#SBATCH --qos=normal" >> $cfile +echo "#SBATCH --qos=$queue" >> $cfile echo "#SBATCH --clusters=c4" >> $cfile echo "#SBATCH --time=$timew" >> $cfile echo "#SBATCH --nodes=$nodes --ntasks-per-node=$procs --cpus-per-task=$threads" >> $cfile From 44feb8a527ffd7e817b9d135f534a592e2a04b77 Mon Sep 17 00:00:00 2001 From: RussTreadon-NOAA Date: Sat, 1 Jul 2023 23:46:17 +0000 Subject: [PATCH 32/44] update hera.gnu modulefile to use epic hpc-stack, load ncdiag from machine stacks --- modulefiles/gsi_common.lua | 5 +---- modulefiles/gsi_hera.gnu.lua | 4 ++-- 2 files changed, 3 insertions(+), 6 deletions(-) diff --git a/modulefiles/gsi_common.lua b/modulefiles/gsi_common.lua index 8a8d7e927d..5cb429451f 100644 --- a/modulefiles/gsi_common.lua +++ b/modulefiles/gsi_common.lua @@ -31,7 +31,4 @@ load(pathJoin("nemsio", nemsio_ver)) load(pathJoin("wrf_io", wrf_io_ver)) load(pathJoin("ncio", ncio_ver)) load(pathJoin("crtm", crtm_ver)) ---load(pathJoin("ncdiag",ncdiag_ver)) - -setenv("ncdiag_ROOT", "/scratch1/NESDIS/nesdis-rdo2/David.Huber/GSI/ncdiag/1.1.1") -setenv("ncdiag_VERSION", "1.1.1") +load(pathJoin("ncdiag",ncdiag_ver)) diff --git a/modulefiles/gsi_hera.gnu.lua b/modulefiles/gsi_hera.gnu.lua index 4f0253ba4d..f1d1640df1 100644 --- a/modulefiles/gsi_hera.gnu.lua +++ b/modulefiles/gsi_hera.gnu.lua @@ -1,9 +1,9 @@ help([[ ]]) -prepend_path("MODULEPATH", "/scratch2/NCEPDEV/nwprod/hpc-stack/libs/hpc-stack/modulefiles/stack") +prepend_path("MODULEPATH", "/scratch1/NCEPDEV/nems/role.epic/hpc-stack/libs/gnu-9.2/modulefiles/stack") -local hpc_ver=os.getenv("hpc_ver") or "1.1.0" +local hpc_ver=os.getenv("hpc_ver") or "1.2.0" local hpc_gnu_ver=os.getenv("hpc_gnu_ver") or "9.2.0" local hpc_mpich_ver=os.getenv("hpc_mpich_ver") or "3.3.2" local cmake_ver=os.getenv("cmake_ver") or "3.20.1" From 3d4723105b111855d4d252e701f3a376e787d30b Mon Sep 17 00:00:00 2001 From: RussTreadon-NOAA Date: Mon, 10 Jul 2023 12:24:19 +0000 Subject: [PATCH 33/44] remove w3nco from gsi_common.lua and gsi_cheyenne.gnu.lua --- modulefiles/gsi_cheyenne.gnu.lua | 3 --- modulefiles/gsi_common.lua | 1 - 2 files changed, 4 deletions(-) diff --git a/modulefiles/gsi_cheyenne.gnu.lua b/modulefiles/gsi_cheyenne.gnu.lua index a4e7452e96..cb433f07f7 100644 --- a/modulefiles/gsi_cheyenne.gnu.lua +++ b/modulefiles/gsi_cheyenne.gnu.lua @@ -15,9 +15,6 @@ load("hpc/1.2.0") load("hpc-gnu/10.1.0") load("hpc-mpt/2.22") --- Preload w3nco to work around nemsio "find_dependency(w3nco)" hpc-stack bug -load("w3nco/2.4.1") - load("gsi_common") local prod_util_ver=os.getenv("prod_util_ver") or "1.2.2" diff --git a/modulefiles/gsi_common.lua b/modulefiles/gsi_common.lua index 5cb429451f..c54f6ddb92 100644 --- a/modulefiles/gsi_common.lua +++ b/modulefiles/gsi_common.lua @@ -22,7 +22,6 @@ 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)) From d0fdffcd664c04a0aadbb0a04a8322e9c94a0efa Mon Sep 17 00:00:00 2001 From: RussTreadon-NOAA Date: Mon, 10 Jul 2023 19:12:27 +0000 Subject: [PATCH 34/44] update gsi_wcoss2.lua to ncdiag/1.1.1 and nemsio/2.5.4, update gnu compilers from PR #584 --- modulefiles/gsi_cheyenne.gnu.lua | 17 +++++++++-------- modulefiles/gsi_hera.gnu.lua | 8 +++++--- modulefiles/gsi_wcoss2.lua | 11 ++++++++++- 3 files changed, 24 insertions(+), 12 deletions(-) diff --git a/modulefiles/gsi_cheyenne.gnu.lua b/modulefiles/gsi_cheyenne.gnu.lua index cb433f07f7..43e6aaf02c 100644 --- a/modulefiles/gsi_cheyenne.gnu.lua +++ b/modulefiles/gsi_cheyenne.gnu.lua @@ -4,23 +4,24 @@ help([[ load("cmake/3.22.0") load("python/3.7.9") load("ncarenv/1.3") -load("gnu/10.1.0") -load("mpt/2.22") +load("gnu/11.2.0") +load("mpt/2.25") load("ncarcompilers/0.5.0") +unload("intel") unload("netcdf") -prepend_path("MODULEPATH", "/glade/work/epicufsrt/contrib/hpc-stack/gnu10.1.0/modulefiles/stack") +prepend_path("MODULEPATH", "/glade/work/epicufsrt/contrib/hpc-stack/gnu11.2.0/modulefiles/stack") load("hpc/1.2.0") -load("hpc-gnu/10.1.0") -load("hpc-mpt/2.22") +load("hpc-gnu/11.2.0") +load("hpc-mpt/2.25") load("gsi_common") -local prod_util_ver=os.getenv("prod_util_ver") or "1.2.2" -load(pathJoin("prod_util", prod_util_ver)) +load(pathJoin("prod_util", os.getenv("prod_util_ver") or "1.2.2")) +load(pathJoin("openblas", os.getenv("openblas_ver") or "0.3.23")) -pushenv("MKLROOT", "/glade/u/apps/opt/intel/2022.1/mkl/latest") +pushenv("GSI_BINARY_SOURCE_DIR", "/glade/work/epicufsrt/contrib/GSI_fix/fix") pushenv("CC", "mpicc") pushenv("FC", "mpif90") diff --git a/modulefiles/gsi_hera.gnu.lua b/modulefiles/gsi_hera.gnu.lua index f1d1640df1..c309e67fe0 100644 --- a/modulefiles/gsi_hera.gnu.lua +++ b/modulefiles/gsi_hera.gnu.lua @@ -4,12 +4,15 @@ help([[ prepend_path("MODULEPATH", "/scratch1/NCEPDEV/nems/role.epic/hpc-stack/libs/gnu-9.2/modulefiles/stack") local hpc_ver=os.getenv("hpc_ver") or "1.2.0" -local hpc_gnu_ver=os.getenv("hpc_gnu_ver") or "9.2.0" +local gnu_ver=os.getenv("gnu_ver") or "9.2.0" +local hpc_gnu_ver=os.getenv("hpc_gnu_ver") or "9.2" local hpc_mpich_ver=os.getenv("hpc_mpich_ver") or "3.3.2" local cmake_ver=os.getenv("cmake_ver") or "3.20.1" local prod_util_ver=os.getenv("prod_util_ver") or "1.2.2" +local openblas_ver=os.getenv("openblas_ver") or "0.3.23" load(pathJoin("hpc", hpc_ver)) +load(pathJoin("gnu", gnu_ver)) load(pathJoin("hpc-gnu", hpc_gnu_ver)) load(pathJoin("hpc-mpich", hpc_mpich_ver)) load(pathJoin("cmake", cmake_ver)) @@ -17,8 +20,7 @@ load(pathJoin("cmake", cmake_ver)) load("gsi_common") load(pathJoin("prod_util", prod_util_ver)) - -pushenv("MKLROOT", "/apps/oneapi/mkl/2022.0.2") +load(pathJoin("openblas", openblas_ver)) pushenv("GSI_BINARY_SOURCE_DIR", "/scratch1/NCEPDEV/global/glopara/fix/gsi/20230601") diff --git a/modulefiles/gsi_wcoss2.lua b/modulefiles/gsi_wcoss2.lua index 1872f89d17..652e0de1db 100644 --- a/modulefiles/gsi_wcoss2.lua +++ b/modulefiles/gsi_wcoss2.lua @@ -4,11 +4,16 @@ help([[ local PrgEnv_intel_ver=os.getenv("PrgEnv_intel_ver") or "8.1.0" local intel_ver=os.getenv("intel_ver") or "19.1.3.304" local craype_ver=os.getenv("craype_ver") or "2.7.8" -local cray_mpich_ver=os.getenv("cray_mpich_ver") or "8.1.7" +local cray_mpich_ver=os.getenv("cray_mpich_ver") or "8.1.9" local cmake_ver= os.getenv("cmake_ver") or "3.20.2" local python_ver=os.getenv("python_ver") or "3.8.6" local prod_util_ver=os.getenv("prod_util_ver") or "2.0.10" +prepend_path("MODULEPATH", "/lfs/h1/emc/nceplibs/noscrub/hpc-stack/libs/hpc-stack/modulefiles/stack") +local hpc_ver=os.getenv("hpc_ver") or "1.2.0" +local hpc_intel_ver=os.getenv("hpc_intel_ver") or "19.1.3.304" +local hpc_cray_mpich_ver=os.getenv("hpc_cray_mpich_ver") or "8.1.9" + load(pathJoin("PrgEnv-intel", PrgEnv_intel_ver)) load(pathJoin("intel", intel_ver)) load(pathJoin("craype", craype_ver)) @@ -18,6 +23,10 @@ load(pathJoin("python", python_ver)) load(pathJoin("prod_util", prod_util_ver)) +load(pathJoin("hpc", hpc_ver)) +load(pathJoin("hpc-intel", hpc_intel_ver)) +load(pathJoin("hpc-cray-mpich", hpc_cray_mpich_ver)) + load("gsi_common") pushenv("GSI_BINARY_SOURCE_DIR", "/lfs/h2/emc/global/noscrub/emc.global/FIX/fix/gsi/20230601") From fb580f173db202d20cf8848ca38a41ba37a927b3 Mon Sep 17 00:00:00 2001 From: David Huber <69919478+DavidHuber-NOAA@users.noreply.github.com> Date: Tue, 1 Aug 2023 06:04:12 -0400 Subject: [PATCH 35/44] Remove labels to fix RT on Orion and Jet #447 (#14) --- regression/regression_param.sh | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/regression/regression_param.sh b/regression/regression_param.sh index 79a91bde8e..ea27521251 100755 --- a/regression/regression_param.sh +++ b/regression/regression_param.sh @@ -349,13 +349,13 @@ if [[ "$machine" = "Hera" ]]; then export APRUN="srun" elif [[ "$machine" = "Orion" ]]; then export OMP_STACKSIZE=2048M - export APRUN="srun --label -n \$ntasks" + export APRUN="srun -n \$ntasks" elif [[ "$machine" = "Jet" ]]; then export OMP_STACKSIZE=1024M export MPI_BUFS_PER_PROC=256 export MPI_BUFS_PER_HOST=256 export MPI_GROUP_MAX=256 - export APRUN="srun --label -n \$ntasks --cpus-per-task=\$threads" + export APRUN="srun -n \$ntasks --cpus-per-task=\$threads" elif [[ "$machine" = "Gaea" ]]; then export OMP_STACKSIZE=1024M export MPI_BUFS_PER_PROC=256 From 1e819ea2f2064dbe9e78f2cbba63b48957f8b5b4 Mon Sep 17 00:00:00 2001 From: Natalie Perlin <68030316+natalie-perlin@users.noreply.github.com> Date: Tue, 1 Aug 2023 04:06:18 -0600 Subject: [PATCH 36/44] Update Orion stack location for the new role-epic account (#15) * corrections to module-setup.sh * update to Orion software stack in a new role-epic location * updated regression/regression_param.sh srun command for Orion --------- Co-authored-by: Natalie Perlin Co-authored-by: Natalie Perlin --- modulefiles/gsi_orion.lua | 4 ++-- ush/module-setup.sh | 3 +-- 2 files changed, 3 insertions(+), 4 deletions(-) diff --git a/modulefiles/gsi_orion.lua b/modulefiles/gsi_orion.lua index 43276b7cbe..a7ea874fb2 100644 --- a/modulefiles/gsi_orion.lua +++ b/modulefiles/gsi_orion.lua @@ -1,11 +1,11 @@ help([[ ]]) -prepend_path("MODULEPATH", "/work/noaa/epic-ps/role-epic-ps/miniconda3/modulefiles") +prepend_path("MODULEPATH", "/work/noaa/epic/role-epic/contrib/orion/miniconda3/modulefiles") miniconda3_ver=os.getenv("miniconda3_ver") or "4.12.0" load(pathJoin("miniconda3", miniconda3_ver)) -prepend_path("MODULEPATH", "/work/noaa/epic-ps/role-epic-ps/hpc-stack/libs/intel-2022.1.2/modulefiles/stack") +prepend_path("MODULEPATH", "/work/noaa/epic/role-epic/contrib/orion/hpc-stack/intel-2022.1.2/modulefiles/stack") local hpc_ver=os.getenv("hpc_ver") or "1.2.0" local hpc_intel_ver=os.getenv("hpc_intel_ver") or "2022.1.2" diff --git a/ush/module-setup.sh b/ush/module-setup.sh index 8f16306efe..ab92477a56 100755 --- a/ush/module-setup.sh +++ b/ush/module-setup.sh @@ -18,7 +18,7 @@ elif [[ $MACHINE_ID = hera* ]] ; then elif [[ $MACHINE_ID = orion* ]] ; then # We are on Orion if ( ! eval module help > /dev/null 2>&1 ) ; then - source /apps/lmod/init/bash + source /apps/lmod/lmod/init/bash fi module purge @@ -58,7 +58,6 @@ elif [[ $MACHINE_ID = gaea* ]] ; then source /etc/profile __ms_source_etc_profile=yes fi - source /lustre/f2/dev/role.epic/contrib/Lmod_init.sh source /lustre/f2/dev/role.epic/contrib/Lmod_init.sh From e9b24d6bc17a1d7eb6b913f0ed47c34e90bf5d20 Mon Sep 17 00:00:00 2001 From: David Huber <69919478+DavidHuber-NOAA@users.noreply.github.com> Date: Mon, 7 Aug 2023 14:11:54 -0400 Subject: [PATCH 37/44] Added a new chadmin template to detect_machine.sh #595 (#16) --- ush/detect_machine.sh | 1 + 1 file changed, 1 insertion(+) diff --git a/ush/detect_machine.sh b/ush/detect_machine.sh index ecd1ad536e..776f7a0b86 100755 --- a/ush/detect_machine.sh +++ b/ush/detect_machine.sh @@ -28,6 +28,7 @@ case $(hostname -f) in cheyenne[1-6].cheyenne.ucar.edu) MACHINE_ID=cheyenne ;; ### cheyenne1-6 cheyenne[1-6].ib0.cheyenne.ucar.edu) MACHINE_ID=cheyenne ;; ### cheyenne1-6 chadmin[1-6].ib0.cheyenne.ucar.edu) MACHINE_ID=cheyenne ;; ### cheyenne1-6 + chadmin[1-6].ucar.edu) MACHINE_ID=cheyenne ;; ### cheyenne1-6 login[1-4].stampede2.tacc.utexas.edu) MACHINE_ID=stampede ;; ### stampede1-4 From e4fc1987bf566febe7197cef3b319f655d535f22 Mon Sep 17 00:00:00 2001 From: Russ-Treadon-NOAA Date: Fri, 18 Aug 2023 14:15:19 +0000 Subject: [PATCH 38/44] use sub-communicator for parallel netcdf io in gsi_rfv3io_mod.f90 (#447) --- src/gsi/gsi_rfv3io_mod.f90 | 932 +++++++++++++++++++++---------------- 1 file changed, 526 insertions(+), 406 deletions(-) diff --git a/src/gsi/gsi_rfv3io_mod.f90 b/src/gsi/gsi_rfv3io_mod.f90 index 4fcb2aba1d..5578df4ee3 100644 --- a/src/gsi/gsi_rfv3io_mod.f90 +++ b/src/gsi/gsi_rfv3io_mod.f90 @@ -2188,7 +2188,7 @@ subroutine gsi_fv3ncdf_read(grd_ionouv,cstate_nouv,filenamein,fv3filenamegin) use kinds, only: r_kind,i_kind - use mpimod, only: mpi_comm_world,mpi_rtype,mype + use mpimod, only: mpi_comm_world,mpi_rtype,mype,npe,setcomm,mpi_integer,mpi_max use mpimod, only: MPI_INFO_NULL use netcdf, only: nf90_open,nf90_close,nf90_get_var,nf90_noerr use netcdf, only: nf90_nowrite,nf90_inquire,nf90_inquire_dimension @@ -2217,6 +2217,11 @@ subroutine gsi_fv3ncdf_read(grd_ionouv,cstate_nouv,filenamein,fv3filenamegin) logical :: phy_smaller_domain integer(i_kind) gfile_loc,iret,var_id integer(i_kind) nz,nzp1,mm1,nx_phy + + integer(i_kind):: iworld,iworld_group,nread,mpi_comm_read,i,ierror + integer(i_kind),dimension(npe):: members,members_read,mype_read,mype_read_rank + logical:: procuse + ! for io_layout > 1 real(r_kind),allocatable,dimension(:,:):: uu2d_layout integer(i_kind) :: nio @@ -2232,108 +2237,132 @@ subroutine gsi_fv3ncdf_read(grd_ionouv,cstate_nouv,filenamein,fv3filenamegin) kend=grd_ionouv%kend_loc allocate(uu2d(nxcase,nycase)) - if(fv3_io_layout_y > 1) then - allocate(gfile_loc_layout(0:fv3_io_layout_y-1)) - do nio=0,fv3_io_layout_y-1 - write(filename_layout,'(a,a,I4.4)') trim(filenamein),'.',nio - iret=nf90_open(filename_layout,nf90_nowrite,gfile_loc_layout(nio),comm=mpi_comm_world,info=MPI_INFO_NULL) !clt - if(iret/=nf90_noerr) then - write(6,*)' gsi_fv3ncdf_read: problem opening ',trim(filename_layout),gfile_loc_layout(nio),', Status = ',iret - call flush(6) - call stop2(333) - endif - enddo - else - iret=nf90_open(filenamein,nf90_nowrite,gfile_loc,comm=mpi_comm_world,info=MPI_INFO_NULL) !clt - if(iret/=nf90_noerr) then - write(6,*)' gsi_fv3ncdf_read: problem opening ',trim(filenamein),gfile_loc,', Status = ',iret - call flush(6) - call stop2(333) - endif + procuse = .false. + members=-1 + members_read=-1 + if (kbgn<=kend) then + procuse = .true. + members(mm1) = mype endif - do ilevtot=kbgn,kend - vgsiname=grd_ionouv%names(1,ilevtot) - if(trim(vgsiname)=='delzinc') cycle !delzinc is not read from DZ ,it's started from hydrostatic height - if(trim(vgsiname)=='amassi') cycle - if(trim(vgsiname)=='amassj') cycle - if(trim(vgsiname)=='amassk') cycle - if(trim(vgsiname)=='pm2_5') cycle - call getfv3lamfilevname(vgsiname,fv3filenamegin,filenamein2,varname) - name=trim(varname) - if(trim(filenamein) /= trim(filenamein2)) then - write(6,*)'filenamein and filenamein2 are not the same as expected, stop' - call flush(6) - call stop2(333) - endif - ilev=grd_ionouv%lnames(1,ilevtot) - nz=grd_ionouv%nsig - nzp1=nz+1 - inative=nzp1-ilev - startloc=(/1,1,inative/) - countloc=(/nxcase,nycase,1/) - ! Variable ref_f3d in phy_data.nc has a smaller domain size than - ! dynvariables and tracers as well as a reversed order in vertical - if ( trim(adjustl(varname)) == 'ref_f3d' )then - iret=nf90_inquire_dimension(gfile_loc,1,name,len) - if(trim(name)=='xaxis_1') nx_phy=len - if( nx_phy == nxcase )then - allocate(uu2d_tmp(nxcase,nycase)) - countloc_tmp=(/nxcase,nycase,1/) - phy_smaller_domain = .false. - else - allocate(uu2d_tmp(nxcase-6,nycase-6)) - countloc_tmp=(/nxcase-6,nycase-6,1/) - phy_smaller_domain = .true. - end if - startloc_tmp=(/1,1,ilev/) - end if + call mpi_allreduce(members,members_read,npe,mpi_integer,mpi_max,mpi_comm_world,ierror) - if(fv3_io_layout_y > 1) then - do nio=0,fv3_io_layout_y-1 - countloc=(/nxcase,ny_layout_len(nio),1/) - allocate(uu2d_layout(nxcase,ny_layout_len(nio))) - iret=nf90_inq_varid(gfile_loc_layout(nio),trim(adjustl(varname)),var_id) - iret=nf90_get_var(gfile_loc_layout(nio),var_id,uu2d_layout,start=startloc,count=countloc) - uu2d(:,ny_layout_b(nio):ny_layout_e(nio))=uu2d_layout - deallocate(uu2d_layout) - enddo - else - iret=nf90_inq_varid(gfile_loc,trim(adjustl(varname)),var_id) - if ( trim(adjustl(varname)) == 'ref_f3d' )then - uu2d = 0.0_r_kind - iret=nf90_get_var(gfile_loc,var_id,uu2d_tmp,start=startloc_tmp,count=countloc_tmp) - where(uu2d_tmp < 0.0_r_kind) - uu2d_tmp = 0.0_r_kind - endwhere - - if( phy_smaller_domain )then - uu2d(4:nxcase-3,4:nycase-3) = uu2d_tmp - else - uu2d(1:nxcase,1:nycase) = uu2d_tmp - end if - deallocate(uu2d_tmp) - else - iret=nf90_get_var(gfile_loc,var_id,uu2d,start=startloc,count=countloc) - end if - endif + nread=0 + mype_read_rank=-1 + do i=1,npe + if (members_read(i) >= 0) then + nread=nread+1 + mype_read_rank(nread) = members_read(i) + endif + enddo + + call setcomm(iworld,iworld_group,nread,mype_read_rank,mpi_comm_read,ierror) - call fv3_h_to_ll(uu2d,hwork(1,:,:,ilevtot),nxcase,nycase,nloncase,nlatcase,grid_reverse_flag) - enddo ! ilevtot + if (procuse) then - if(fv3_io_layout_y > 1) then - do nio=1,fv3_io_layout_y-1 - iret=nf90_close(gfile_loc_layout(nio)) - enddo - deallocate(gfile_loc_layout) - else - iret=nf90_close(gfile_loc) + if(fv3_io_layout_y > 1) then + allocate(gfile_loc_layout(0:fv3_io_layout_y-1)) + do nio=0,fv3_io_layout_y-1 + write(filename_layout,'(a,a,I4.4)') trim(filenamein),'.',nio + iret=nf90_open(filename_layout,nf90_nowrite,gfile_loc_layout(nio),comm=mpi_comm_read,info=MPI_INFO_NULL) !clt + if(iret/=nf90_noerr) then + write(6,*)' gsi_fv3ncdf_read: problem opening ',trim(filename_layout),gfile_loc_layout(nio),', Status = ',iret + call flush(6) + call stop2(333) + endif + enddo + else + iret=nf90_open(filenamein,nf90_nowrite,gfile_loc,comm=mpi_comm_read,info=MPI_INFO_NULL) !clt + if(iret/=nf90_noerr) then + write(6,*)' gsi_fv3ncdf_read: problem opening ',trim(filenamein),gfile_loc,', Status = ',iret + call flush(6) + call stop2(333) + endif + endif + do ilevtot=kbgn,kend + vgsiname=grd_ionouv%names(1,ilevtot) + if(trim(vgsiname)=='delzinc') cycle !delzinc is not read from DZ ,it's started from hydrostatic height + if(trim(vgsiname)=='amassi') cycle + if(trim(vgsiname)=='amassj') cycle + if(trim(vgsiname)=='amassk') cycle + if(trim(vgsiname)=='pm2_5') cycle + call getfv3lamfilevname(vgsiname,fv3filenamegin,filenamein2,varname) + name=trim(varname) + if(trim(filenamein) /= trim(filenamein2)) then + write(6,*)'filenamein and filenamein2 are not the same as expected, stop' + call flush(6) + call stop2(333) + endif + ilev=grd_ionouv%lnames(1,ilevtot) + nz=grd_ionouv%nsig + nzp1=nz+1 + inative=nzp1-ilev + startloc=(/1,1,inative/) + countloc=(/nxcase,nycase,1/) + ! Variable ref_f3d in phy_data.nc has a smaller domain size than + ! dynvariables and tracers as well as a reversed order in vertical + if ( trim(adjustl(varname)) == 'ref_f3d' )then + iret=nf90_inquire_dimension(gfile_loc,1,name,len) + if(trim(name)=='xaxis_1') nx_phy=len + if( nx_phy == nxcase )then + allocate(uu2d_tmp(nxcase,nycase)) + countloc_tmp=(/nxcase,nycase,1/) + phy_smaller_domain = .false. + else + allocate(uu2d_tmp(nxcase-6,nycase-6)) + countloc_tmp=(/nxcase-6,nycase-6,1/) + phy_smaller_domain = .true. + end if + startloc_tmp=(/1,1,ilev/) + end if + + if(fv3_io_layout_y > 1) then + do nio=0,fv3_io_layout_y-1 + countloc=(/nxcase,ny_layout_len(nio),1/) + allocate(uu2d_layout(nxcase,ny_layout_len(nio))) + iret=nf90_inq_varid(gfile_loc_layout(nio),trim(adjustl(varname)),var_id) + iret=nf90_get_var(gfile_loc_layout(nio),var_id,uu2d_layout,start=startloc,count=countloc) + uu2d(:,ny_layout_b(nio):ny_layout_e(nio))=uu2d_layout + deallocate(uu2d_layout) + enddo + else + iret=nf90_inq_varid(gfile_loc,trim(adjustl(varname)),var_id) + if ( trim(adjustl(varname)) == 'ref_f3d' )then + uu2d = 0.0_r_kind + iret=nf90_get_var(gfile_loc,var_id,uu2d_tmp,start=startloc_tmp,count=countloc_tmp) + where(uu2d_tmp < 0.0_r_kind) + uu2d_tmp = 0.0_r_kind + endwhere + + if( phy_smaller_domain )then + uu2d(4:nxcase-3,4:nycase-3) = uu2d_tmp + else + uu2d(1:nxcase,1:nycase) = uu2d_tmp + end if + deallocate(uu2d_tmp) + else + iret=nf90_get_var(gfile_loc,var_id,uu2d,start=startloc,count=countloc) + end if + endif + + call fv3_h_to_ll(uu2d,hwork(1,:,:,ilevtot),nxcase,nycase,nloncase,nlatcase,grid_reverse_flag) + enddo ! ilevtot + + if(fv3_io_layout_y > 1) then + do nio=1,fv3_io_layout_y-1 + iret=nf90_close(gfile_loc_layout(nio)) + enddo + deallocate(gfile_loc_layout) + else + iret=nf90_close(gfile_loc) + endif endif - + call mpi_barrier(mpi_comm_world,ierror) + deallocate (uu2d) call general_grid2sub(grd_ionouv,hwork,cstate_nouv%values) return -end subroutine gsi_fv3ncdf_read + end subroutine gsi_fv3ncdf_read subroutine gsi_fv3ncdf_read_v1(grd_ionouv,cstate_nouv,filenamein,fv3filenamegin) @@ -2465,7 +2494,7 @@ subroutine gsi_fv3ncdf_readuv(grd_uv,ges_u,ges_v,fv3filenamegin) ! !$$$ end documentation block use kinds, only: r_kind,i_kind - use mpimod, only: mpi_comm_world,mpi_rtype,mype,mpi_info_null + use mpimod, only: mpi_comm_world,mpi_rtype,mype,mpi_info_null,npe,setcomm,mpi_integer,mpi_max use netcdf, only: nf90_open,nf90_close,nf90_get_var,nf90_noerr use netcdf, only: nf90_nowrite,nf90_inquire,nf90_inquire_dimension use netcdf, only: nf90_inquire_variable @@ -2495,6 +2524,10 @@ subroutine gsi_fv3ncdf_readuv(grd_uv,ges_u,ges_v,fv3filenamegin) integer(i_kind) gfile_loc,iret integer(i_kind) nz,nzp1,mm1 + integer(i_kind):: iworld,iworld_group,nread,mpi_comm_read,i,ierror + integer(i_kind),dimension(npe):: members,members_read,mype_read,mype_read_rank + logical:: procuse + ! for fv3_io_layout_y > 1 real(r_kind),allocatable,dimension(:,:):: u2d_layout,v2d_layout integer(i_kind) :: nio @@ -2515,102 +2548,130 @@ subroutine gsi_fv3ncdf_readuv(grd_uv,ges_u,ges_v,fv3filenamegin) allocate (worksub(2,grd_uv%lat2,grd_uv%lon2,grd_uv%nsig)) filenamein=fv3filenamegin%dynvars - if(fv3_io_layout_y > 1) then - allocate(gfile_loc_layout(0:fv3_io_layout_y-1)) - do nio=0,fv3_io_layout_y-1 - write(filename_layout,'(a,a,I4.4)') trim(filenamein),".",nio - iret=nf90_open(filename_layout,nf90_nowrite,gfile_loc_layout(nio),comm=mpi_comm_world,info=MPI_INFO_NULL) - if(iret/=nf90_noerr) then - write(6,*)'problem opening6 ',trim(filename_layout),gfile_loc_layout(nio),', Status = ',iret - call flush(6) - call stop2(333) - endif - enddo - else - iret=nf90_open(filenamein,nf90_nowrite,gfile_loc,comm=mpi_comm_world,info=MPI_INFO_NULL) !clt - if(iret/=nf90_noerr) then - write(6,*)' problem opening6 ',trim(filenamein),', Status = ',iret - call flush(6) - call stop2(333) - endif + procuse = .false. + members=-1 + members_read=-1 + if (kbgn<=kend) then + procuse = .true. + members(mm1) = mype endif - do ilevtot=kbgn,kend - vgsiname=grd_uv%names(1,ilevtot) - call getfv3lamfilevname(vgsiname,fv3filenamegin,filenamein2,varname) - if(trim(filenamein) /= trim(filenamein2)) then - write(6,*)'filenamein and filenamein2 are not the same as expected, stop' - call flush(6) - call stop2(333) - endif - ilev=grd_uv%lnames(1,ilevtot) - nz=grd_uv%nsig - nzp1=nz+1 - inative=nzp1-ilev - u_countloc=(/nxcase,nycase+1,1/) - v_countloc=(/nxcase+1,nycase,1/) - u_startloc=(/1,1,inative/) - v_startloc=(/1,1,inative/) - - if(fv3_io_layout_y > 1) then - do nio=0,fv3_io_layout_y-1 - u_countloc=(/nxcase,ny_layout_len(nio)+1,1/) - allocate(u2d_layout(nxcase,ny_layout_len(nio)+1)) - call check( nf90_inq_varid(gfile_loc_layout(nio),'u',u_grd_VarId) ) - iret=nf90_get_var(gfile_loc_layout(nio),u_grd_VarId,u2d_layout,start=u_startloc,count=u_countloc) - u2d(:,ny_layout_b(nio):ny_layout_e(nio))=u2d_layout(:,1:ny_layout_len(nio)) - if(nio==fv3_io_layout_y-1) u2d(:,ny_layout_e(nio)+1)=u2d_layout(:,ny_layout_len(nio)+1) - deallocate(u2d_layout) - - v_countloc=(/nxcase+1,ny_layout_len(nio),1/) - allocate(v2d_layout(nxcase+1,ny_layout_len(nio))) - call check( nf90_inq_varid(gfile_loc_layout(nio),'v',v_grd_VarId) ) - iret=nf90_get_var(gfile_loc_layout(nio),v_grd_VarId,v2d_layout,start=v_startloc,count=v_countloc) - v2d(:,ny_layout_b(nio):ny_layout_e(nio))=v2d_layout - deallocate(v2d_layout) - enddo - else - call check( nf90_inq_varid(gfile_loc,'u',u_grd_VarId) ) - iret=nf90_get_var(gfile_loc,u_grd_VarId,u2d,start=u_startloc,count=u_countloc) - call check( nf90_inq_varid(gfile_loc,'v',v_grd_VarId) ) - iret=nf90_get_var(gfile_loc,v_grd_VarId,v2d,start=v_startloc,count=v_countloc) - endif - if(.not.grid_reverse_flag) then - call reverse_grid_r_uv (u2d,nxcase,nycase+1,1) - call reverse_grid_r_uv (v2d,nxcase+1,nycase,1) - endif - call fv3uv2earth(u2d(:,:),v2d(:,:),nxcase,nycase,uc2d,vc2d) + write(6,115)mype,kbgn,kend,procuse +115 format('gsi_fv3ncdf_readuv: mype ',i6,' has kbgn,kend= ',2(i6,1x),' set procuse ',l7) -! NOTE on transfor to earth u/v: -! The u and v before transferring need to be in E-W/N-S grid, which is -! defined as reversed grid here because it is revered from map view. -! -! Have set the following flag for grid orientation -! grid_reverse_flag=true: E-W/N-S grid -! grid_reverse_flag=false: W-E/S-N grid -! -! So for preparing the wind transferring, need to reverse the grid from -! W-E/S-N grid to E-W/N-S grid when grid_reverse_flag=false: -! -! if(.not.grid_reverse_flag) call reverse_grid_r_uv -! -! and the last input parameter for fv3_h_to_ll is alway true: -! -! - call fv3_h_to_ll(uc2d,hwork(1,:,:,ilevtot),nxcase,nycase,nloncase,nlatcase,.true.) - call fv3_h_to_ll(vc2d,hwork(2,:,:,ilevtot),nxcase,nycase,nloncase,nlatcase,.true.) - enddo ! i + call mpi_allreduce(members,members_read,npe,mpi_integer,mpi_max,mpi_comm_world,ierror) - if(fv3_io_layout_y > 1) then - do nio=0,fv3_io_layout_y-1 - iret=nf90_close(gfile_loc_layout(nio)) - enddo - deallocate(gfile_loc_layout) - else - iret=nf90_close(gfile_loc) + nread=0 + mype_read_rank=-1 + do i=1,npe + if (members_read(i) >= 0) then + nread=nread+1 + mype_read_rank(nread) = members_read(i) + endif + enddo + + call setcomm(iworld,iworld_group,nread,mype_read_rank,mpi_comm_read,ierror) + + if (procuse) then + if(fv3_io_layout_y > 1) then + allocate(gfile_loc_layout(0:fv3_io_layout_y-1)) + do nio=0,fv3_io_layout_y-1 + write(filename_layout,'(a,a,I4.4)') trim(filenamein),".",nio + iret=nf90_open(filename_layout,nf90_nowrite,gfile_loc_layout(nio),comm=mpi_comm_read,info=MPI_INFO_NULL) + if(iret/=nf90_noerr) then + write(6,*)'problem opening6 ',trim(filename_layout),gfile_loc_layout(nio),', Status = ',iret + call flush(6) + call stop2(333) + endif + enddo + else + iret=nf90_open(filenamein,nf90_nowrite,gfile_loc,comm=mpi_comm_read,info=MPI_INFO_NULL) !clt + if(iret/=nf90_noerr) then + write(6,*)' problem opening6 ',trim(filenamein),', Status = ',iret + call flush(6) + call stop2(333) + endif + endif + + do ilevtot=kbgn,kend + vgsiname=grd_uv%names(1,ilevtot) + call getfv3lamfilevname(vgsiname,fv3filenamegin,filenamein2,varname) + if(trim(filenamein) /= trim(filenamein2)) then + write(6,*)'filenamein and filenamein2 are not the same as expected, stop' + call flush(6) + call stop2(333) + endif + ilev=grd_uv%lnames(1,ilevtot) + nz=grd_uv%nsig + nzp1=nz+1 + inative=nzp1-ilev + u_countloc=(/nxcase,nycase+1,1/) + v_countloc=(/nxcase+1,nycase,1/) + u_startloc=(/1,1,inative/) + v_startloc=(/1,1,inative/) + if(fv3_io_layout_y > 1) then + do nio=0,fv3_io_layout_y-1 + u_countloc=(/nxcase,ny_layout_len(nio)+1,1/) + allocate(u2d_layout(nxcase,ny_layout_len(nio)+1)) + call check( nf90_inq_varid(gfile_loc_layout(nio),'u',u_grd_VarId) ) + iret=nf90_get_var(gfile_loc_layout(nio),u_grd_VarId,u2d_layout,start=u_startloc,count=u_countloc) + u2d(:,ny_layout_b(nio):ny_layout_e(nio))=u2d_layout(:,1:ny_layout_len(nio)) + if(nio==fv3_io_layout_y-1) u2d(:,ny_layout_e(nio)+1)=u2d_layout(:,ny_layout_len(nio)+1) + deallocate(u2d_layout) + + v_countloc=(/nxcase+1,ny_layout_len(nio),1/) + allocate(v2d_layout(nxcase+1,ny_layout_len(nio))) + call check( nf90_inq_varid(gfile_loc_layout(nio),'v',v_grd_VarId) ) + iret=nf90_get_var(gfile_loc_layout(nio),v_grd_VarId,v2d_layout,start=v_startloc,count=v_countloc) + v2d(:,ny_layout_b(nio):ny_layout_e(nio))=v2d_layout + deallocate(v2d_layout) + enddo + else + call check( nf90_inq_varid(gfile_loc,'u',u_grd_VarId) ) + iret=nf90_get_var(gfile_loc,u_grd_VarId,u2d,start=u_startloc,count=u_countloc) + call check( nf90_inq_varid(gfile_loc,'v',v_grd_VarId) ) + iret=nf90_get_var(gfile_loc,v_grd_VarId,v2d,start=v_startloc,count=v_countloc) + endif + + if(.not.grid_reverse_flag) then + call reverse_grid_r_uv (u2d,nxcase,nycase+1,1) + call reverse_grid_r_uv (v2d,nxcase+1,nycase,1) + endif + call fv3uv2earth(u2d(:,:),v2d(:,:),nxcase,nycase,uc2d,vc2d) + + ! NOTE on transfor to earth u/v: + ! The u and v before transferring need to be in E-W/N-S grid, which is + ! defined as reversed grid here because it is revered from map view. + ! + ! Have set the following flag for grid orientation + ! grid_reverse_flag=true: E-W/N-S grid + ! grid_reverse_flag=false: W-E/S-N grid + ! + ! So for preparing the wind transferring, need to reverse the grid from + ! W-E/S-N grid to E-W/N-S grid when grid_reverse_flag=false: + ! + ! if(.not.grid_reverse_flag) call reverse_grid_r_uv + ! + ! and the last input parameter for fv3_h_to_ll is alway true: + ! + ! + call fv3_h_to_ll(uc2d,hwork(1,:,:,ilevtot),nxcase,nycase,nloncase,nlatcase,.true.) + call fv3_h_to_ll(vc2d,hwork(2,:,:,ilevtot),nxcase,nycase,nloncase,nlatcase,.true.) + enddo ! i + + if(fv3_io_layout_y > 1) then + do nio=0,fv3_io_layout_y-1 + iret=nf90_close(gfile_loc_layout(nio)) + enddo + deallocate(gfile_loc_layout) + else + iret=nf90_close(gfile_loc) + endif endif - deallocate(u2d,v2d,uc2d,vc2d) + call mpi_barrier(mpi_comm_world,ierror) + deallocate(u2d,v2d,uc2d,vc2d) + call general_grid2sub(grd_uv,hwork,worksub) ges_u=worksub(1,:,:,:) ges_v=worksub(2,:,:,:) @@ -3533,7 +3594,7 @@ subroutine gsi_fv3ncdf_writeuv(grd_uv,ges_u,ges_v,add_saved,fv3filenamegin) ! !$$$ end documentation block - use mpimod, only: mpi_rtype,mpi_comm_world,mype,mpi_info_null + use mpimod, only: mpi_rtype,mpi_comm_world,mype,mpi_info_null,npe,setcomm,mpi_integer,mpi_max use netcdf, only: nf90_nowrite,nf90_inquire,nf90_inquire_dimension use gridmod, only: nlon_regional,nlat_regional use mod_fv3_lola, only: fv3_ll_to_h,fv3_h_to_ll, & @@ -3566,6 +3627,10 @@ subroutine gsi_fv3ncdf_writeuv(grd_uv,ges_u,ges_v,add_saved,fv3filenamegin) real(r_kind),allocatable,dimension(:,:):: u2d,v2d,workau2,workav2 real(r_kind),allocatable,dimension(:,:):: workbu2,workbv2 + integer(i_kind):: iworld,iworld_group,nread,mpi_comm_read,ierror + integer(i_kind),dimension(npe):: members,members_read,mype_read,mype_read_rank + logical:: procuse + ! for fv3_io_layout_y > 1 real(r_kind),allocatable,dimension(:,:):: u2d_layout,v2d_layout integer(i_kind) :: nio @@ -3597,117 +3662,143 @@ subroutine gsi_fv3ncdf_writeuv(grd_uv,ges_u,ges_v,add_saved,fv3filenamegin) call general_sub2grid(grd_uv,worksub,hwork) filenamein=fv3filenamegin%dynvars - if(fv3_io_layout_y > 1) then - allocate(gfile_loc_layout(0:fv3_io_layout_y-1)) - do nio=0,fv3_io_layout_y-1 - write(filename_layout,'(a,a,I4.4)') trim(filenamein),".",nio - call check( nf90_open(filename_layout,nf90_write,gfile_loc_layout(nio),comm=mpi_comm_world,info=MPI_INFO_NULL) ) - enddo - gfile_loc=gfile_loc_layout(0) - else - call check( nf90_open(filenamein,nf90_write,gfile_loc,comm=mpi_comm_world,info=MPI_INFO_NULL) ) + + procuse = .false. + members=-1 + members_read=-1 + if (kbgn<=kend) then + procuse = .true. + members(mm1) = mype endif - do ilevtot=kbgn,kend - varname=grd_uv%names(1,ilevtot) - ilev=grd_uv%lnames(1,ilevtot) - nz=grd_uv%nsig - nzp1=nz+1 - inative=nzp1-ilev - u_countloc=(/nxcase,nycase+1,1/) - v_countloc=(/nxcase+1,nycase,1/) - u_startloc=(/1,1,inative/) - v_startloc=(/1,1,inative/) + call mpi_allreduce(members,members_read,npe,mpi_integer,mpi_max,mpi_comm_world,ierror) - work_au=hwork(1,:,:,ilevtot) - work_av=hwork(2,:,:,ilevtot) + nread=0 + mype_read_rank=-1 + do i=1,npe + if (members_read(i) >= 0) then + nread=nread+1 + mype_read_rank(nread) = members_read(i) + endif + enddo - call check( nf90_inq_varid(gfile_loc,'u',ugrd_VarId) ) - call check( nf90_inq_varid(gfile_loc,'v',vgrd_VarId) ) + call setcomm(iworld,iworld_group,nread,mype_read_rank,mpi_comm_read,ierror) - if(add_saved)then - allocate( workau2(nlatcase,nloncase),workav2(nlatcase,nloncase)) - allocate( workbu2(nlon_regional,nlat_regional+1)) - allocate( workbv2(nlon_regional+1,nlat_regional)) -!!!!!!!! readin work_b !!!!!!!!!!!!!!!! - if(fv3_io_layout_y > 1) then + if (procuse) then + if(fv3_io_layout_y > 1) then + allocate(gfile_loc_layout(0:fv3_io_layout_y-1)) do nio=0,fv3_io_layout_y-1 - allocate(u2d_layout(nxcase,ny_layout_len(nio)+1)) - u_countloc=(/nxcase,ny_layout_len(nio)+1,1/) - call check( nf90_get_var(gfile_loc_layout(nio),ugrd_VarId,u2d_layout,start=u_startloc,count=u_countloc) ) - work_bu(:,ny_layout_b(nio):ny_layout_e(nio))=u2d_layout(:,1:ny_layout_len(nio)) - if(nio==fv3_io_layout_y-1) work_bu(:,ny_layout_e(nio)+1)=u2d_layout(:,ny_layout_len(nio)+1) - deallocate(u2d_layout) - - allocate(v2d_layout(nxcase+1,ny_layout_len(nio))) - v_countloc=(/nxcase+1,ny_layout_len(nio),1/) - call check( nf90_get_var(gfile_loc_layout(nio),vgrd_VarId,v2d_layout,start=v_startloc,count=v_countloc) ) - work_bv(:,ny_layout_b(nio):ny_layout_e(nio))=v2d_layout - deallocate(v2d_layout) + write(filename_layout,'(a,a,I4.4)') trim(filenamein),".",nio + call check( nf90_open(filename_layout,nf90_write,gfile_loc_layout(nio),comm=mpi_comm_read,info=MPI_INFO_NULL) ) enddo - else - call check( nf90_get_var(gfile_loc,ugrd_VarId,work_bu,start=u_startloc,count=u_countloc) ) - call check( nf90_get_var(gfile_loc,vgrd_VarId,work_bv,start=v_startloc,count=v_countloc) ) - endif - if(.not.grid_reverse_flag) then - call reverse_grid_r_uv(work_bu,nlon_regional,nlat_regional+1,1) - call reverse_grid_r_uv(work_bv,nlon_regional+1,nlat_regional,1) - endif - call fv3uv2earth(work_bu,work_bv,nlon_regional,nlat_regional,u2d,v2d) - call fv3_h_to_ll(u2d,workau2,nlon_regional,nlat_regional,nloncase,nlatcase,.true.) - call fv3_h_to_ll(v2d,workav2,nlon_regional,nlat_regional,nloncase,nlatcase,.true.) + gfile_loc=gfile_loc_layout(0) + else + call check( nf90_open(filenamein,nf90_write,gfile_loc,comm=mpi_comm_read,info=MPI_INFO_NULL) ) + endif + + do ilevtot=kbgn,kend + varname=grd_uv%names(1,ilevtot) + ilev=grd_uv%lnames(1,ilevtot) + nz=grd_uv%nsig + nzp1=nz+1 + inative=nzp1-ilev + u_countloc=(/nxcase,nycase+1,1/) + v_countloc=(/nxcase+1,nycase,1/) + u_startloc=(/1,1,inative/) + v_startloc=(/1,1,inative/) + + work_au=hwork(1,:,:,ilevtot) + work_av=hwork(2,:,:,ilevtot) + + call check( nf90_inq_varid(gfile_loc,'u',ugrd_VarId) ) + call check( nf90_inq_varid(gfile_loc,'v',vgrd_VarId) ) + + if(add_saved)then + allocate( workau2(nlatcase,nloncase),workav2(nlatcase,nloncase)) + allocate( workbu2(nlon_regional,nlat_regional+1)) + allocate( workbv2(nlon_regional+1,nlat_regional)) +!!!!!!!! readin work_b !!!!!!!!!!!!!!!! + if(fv3_io_layout_y > 1) then + do nio=0,fv3_io_layout_y-1 + allocate(u2d_layout(nxcase,ny_layout_len(nio)+1)) + u_countloc=(/nxcase,ny_layout_len(nio)+1,1/) + call check( nf90_get_var(gfile_loc_layout(nio),ugrd_VarId,u2d_layout,start=u_startloc,count=u_countloc) ) + work_bu(:,ny_layout_b(nio):ny_layout_e(nio))=u2d_layout(:,1:ny_layout_len(nio)) + if(nio==fv3_io_layout_y-1) work_bu(:,ny_layout_e(nio)+1)=u2d_layout(:,ny_layout_len(nio)+1) + deallocate(u2d_layout) + + allocate(v2d_layout(nxcase+1,ny_layout_len(nio))) + v_countloc=(/nxcase+1,ny_layout_len(nio),1/) + call check( nf90_get_var(gfile_loc_layout(nio),vgrd_VarId,v2d_layout,start=v_startloc,count=v_countloc) ) + work_bv(:,ny_layout_b(nio):ny_layout_e(nio))=v2d_layout + deallocate(v2d_layout) + enddo + else + call check( nf90_get_var(gfile_loc,ugrd_VarId,work_bu,start=u_startloc,count=u_countloc) ) + call check( nf90_get_var(gfile_loc,vgrd_VarId,work_bv,start=v_startloc,count=v_countloc) ) + endif + if(.not.grid_reverse_flag) then + call reverse_grid_r_uv(work_bu,nlon_regional,nlat_regional+1,1) + call reverse_grid_r_uv(work_bv,nlon_regional+1,nlat_regional,1) + endif + call fv3uv2earth(work_bu,work_bv,nlon_regional,nlat_regional,u2d,v2d) + call fv3_h_to_ll(u2d,workau2,nlon_regional,nlat_regional,nloncase,nlatcase,.true.) + call fv3_h_to_ll(v2d,workav2,nlon_regional,nlat_regional,nloncase,nlatcase,.true.) !!!!!!!! find analysis_inc: work_a !!!!!!!!!!!!!!!! - work_au(:,:)=work_au(:,:)-workau2(:,:) - work_av(:,:)=work_av(:,:)-workav2(:,:) - call fv3_ll_to_h(work_au(:,:),u2d,nloncase,nlatcase,nlon_regional,nlat_regional,.true.) - call fv3_ll_to_h(work_av(:,:),v2d,nloncase,nlatcase,nlon_regional,nlat_regional,.true.) - call earthuv2fv3(u2d,v2d,nlon_regional,nlat_regional,workbu2,workbv2) + work_au(:,:)=work_au(:,:)-workau2(:,:) + work_av(:,:)=work_av(:,:)-workav2(:,:) + call fv3_ll_to_h(work_au(:,:),u2d,nloncase,nlatcase,nlon_regional,nlat_regional,.true.) + call fv3_ll_to_h(work_av(:,:),v2d,nloncase,nlatcase,nlon_regional,nlat_regional,.true.) + call earthuv2fv3(u2d,v2d,nlon_regional,nlat_regional,workbu2,workbv2) !!!!!!!! add analysis_inc to readin work_b !!!!!!!!!!!!!!!! - work_bu(:,:)=work_bu(:,:)+workbu2(:,:) - work_bv(:,:)=work_bv(:,:)+workbv2(:,:) - deallocate(workau2,workbu2,workav2,workbv2) - else - call fv3_ll_to_h(work_au(:,:),u2d,nloncase,nlatcase,nlon_regional,nlat_regional,.true.) - call fv3_ll_to_h(work_av(:,:),v2d,nloncase,nlatcase,nlon_regional,nlat_regional,.true.) - call earthuv2fv3(u2d,v2d,nlon_regional,nlat_regional,work_bu(:,:),work_bv(:,:)) - endif - if(.not.grid_reverse_flag) then - call reverse_grid_r_uv(work_bu,nlon_regional,nlat_regional+1,1) - call reverse_grid_r_uv(work_bv,nlon_regional+1,nlat_regional,1) - endif - - if(fv3_io_layout_y > 1) then - do nio=0,fv3_io_layout_y-1 - allocate(u2d_layout(nxcase,ny_layout_len(nio)+1)) - u_countloc=(/nxcase,ny_layout_len(nio)+1,1/) - u2d_layout=work_bu(:,ny_layout_b(nio):ny_layout_e(nio)+1) - call check( nf90_put_var(gfile_loc_layout(nio),ugrd_VarId,u2d_layout,start=u_startloc,count=u_countloc) ) - deallocate(u2d_layout) - - allocate(v2d_layout(nxcase+1,ny_layout_len(nio))) - v_countloc=(/nxcase+1,ny_layout_len(nio),1/) - v2d_layout=work_bv(:,ny_layout_b(nio):ny_layout_e(nio)) - call check( nf90_put_var(gfile_loc_layout(nio),vgrd_VarId,v2d_layout,start=v_startloc,count=v_countloc) ) - deallocate(v2d_layout) - enddo - else - call check( nf90_put_var(gfile_loc,ugrd_VarId,work_bu,start=u_startloc,count=u_countloc) ) - call check( nf90_put_var(gfile_loc,vgrd_VarId,work_bv,start=v_startloc,count=v_countloc) ) - endif - enddo !ilevltot + work_bu(:,:)=work_bu(:,:)+workbu2(:,:) + work_bv(:,:)=work_bv(:,:)+workbv2(:,:) + deallocate(workau2,workbu2,workav2,workbv2) + else + call fv3_ll_to_h(work_au(:,:),u2d,nloncase,nlatcase,nlon_regional,nlat_regional,.true.) + call fv3_ll_to_h(work_av(:,:),v2d,nloncase,nlatcase,nlon_regional,nlat_regional,.true.) + call earthuv2fv3(u2d,v2d,nlon_regional,nlat_regional,work_bu(:,:),work_bv(:,:)) + endif + if(.not.grid_reverse_flag) then + call reverse_grid_r_uv(work_bu,nlon_regional,nlat_regional+1,1) + call reverse_grid_r_uv(work_bv,nlon_regional+1,nlat_regional,1) + endif + + if(fv3_io_layout_y > 1) then + do nio=0,fv3_io_layout_y-1 + allocate(u2d_layout(nxcase,ny_layout_len(nio)+1)) + u_countloc=(/nxcase,ny_layout_len(nio)+1,1/) + u2d_layout=work_bu(:,ny_layout_b(nio):ny_layout_e(nio)+1) + call check( nf90_put_var(gfile_loc_layout(nio),ugrd_VarId,u2d_layout,start=u_startloc,count=u_countloc) ) + deallocate(u2d_layout) + + allocate(v2d_layout(nxcase+1,ny_layout_len(nio))) + v_countloc=(/nxcase+1,ny_layout_len(nio),1/) + v2d_layout=work_bv(:,ny_layout_b(nio):ny_layout_e(nio)) + call check( nf90_put_var(gfile_loc_layout(nio),vgrd_VarId,v2d_layout,start=v_startloc,count=v_countloc) ) + deallocate(v2d_layout) + enddo + else + call check( nf90_put_var(gfile_loc,ugrd_VarId,work_bu,start=u_startloc,count=u_countloc) ) + call check( nf90_put_var(gfile_loc,vgrd_VarId,work_bv,start=v_startloc,count=v_countloc) ) + endif + enddo !ilevltot - if(fv3_io_layout_y > 1) then - do nio=0,fv3_io_layout_y-1 - call check( nf90_close(gfile_loc_layout(nio)) ) - enddo - deallocate(gfile_loc_layout) - else - call check( nf90_close(gfile_loc) ) + if(fv3_io_layout_y > 1) then + do nio=0,fv3_io_layout_y-1 + call check( nf90_close(gfile_loc_layout(nio)) ) + enddo + deallocate(gfile_loc_layout) + else + call check( nf90_close(gfile_loc) ) + endif endif + + call mpi_barrier(mpi_comm_world,ierror) + deallocate(work_bu,work_bv,u2d,v2d) deallocate(work_au,work_av) - end subroutine gsi_fv3ncdf_writeuv subroutine gsi_fv3ncdf_writeuv_v1(grd_uv,ges_u,ges_v,add_saved,fv3filenamegin) !$$$ subprogram documentation block @@ -4080,7 +4171,7 @@ subroutine gsi_fv3ncdf_write(grd_ionouv,cstate_nouv,add_saved,filenamein,fv3file ! !$$$ end documentation block - use mpimod, only: mpi_rtype,mpi_comm_world,mype,mpi_info_null + use mpimod, only: mpi_rtype,mpi_comm_world,mype,mpi_info_null,npe,setcomm,mpi_integer,mpi_max use mod_fv3_lola, only: fv3_ll_to_h use mod_fv3_lola, only: fv3_h_to_ll use netcdf, only: nf90_open,nf90_close @@ -4112,6 +4203,10 @@ subroutine gsi_fv3ncdf_write(grd_ionouv,cstate_nouv,add_saved,filenamein,fv3file real(r_kind),allocatable,dimension(:,:):: workb2,worka2 real(r_kind),allocatable,dimension(:,:):: work_b_tmp + integer(i_kind):: iworld,iworld_group,nread,mpi_comm_read,i,ierror + integer(i_kind),dimension(npe):: members,members_read,mype_read,mype_read_rank + logical:: procuse + ! for io_layout > 1 real(r_kind),allocatable,dimension(:,:):: work_b_layout integer(i_kind) :: nio @@ -4133,143 +4228,168 @@ subroutine gsi_fv3ncdf_write(grd_ionouv,cstate_nouv,add_saved,filenamein,fv3file allocate( workb2(nlon_regional,nlat_regional)) allocate( worka2(nlatcase,nloncase)) - if(fv3_io_layout_y > 1) then - allocate(gfile_loc_layout(0:fv3_io_layout_y-1)) - do nio=0,fv3_io_layout_y-1 - write(filename_layout,'(a,a,I4.4)') trim(filenamein),'.',nio - call check( nf90_open(filename_layout,nf90_write,gfile_loc_layout(nio),comm=mpi_comm_world,info=MPI_INFO_NULL) ) - enddo - gfile_loc=gfile_loc_layout(0) - else - call check( nf90_open(filenamein,nf90_write,gfile_loc,comm=mpi_comm_world,info=MPI_INFO_NULL) ) + procuse = .false. + members=-1 + members_read=-1 + if (kbgn<=kend) then + procuse = .true. + members(mm1) = mype endif - do ilevtot=kbgn,kend - vgsiname=grd_ionouv%names(1,ilevtot) - if(trim(vgsiname)=='amassi') cycle - if(trim(vgsiname)=='amassj') cycle - if(trim(vgsiname)=='amassk') cycle - if(trim(vgsiname)=='pm2_5') cycle - call getfv3lamfilevname(vgsiname,fv3filenamegin,filenamein2,varname) - if(trim(filenamein) /= trim(filenamein2)) then - write(6,*)'filenamein and filenamein2 are not the same as expected, stop' - call flush(6) - call stop2(333) - endif - ilev=grd_ionouv%lnames(1,ilevtot) - nz=grd_ionouv%nsig - nzp1=nz+1 - inative=nzp1-ilev - countloc=(/nxcase,nycase,1/) - startloc=(/1,1,inative/) - - work_a=hwork(1,:,:,ilevtot) - - if( trim(varname) == 'ref_f3d' )then - iret=nf90_inquire_dimension(gfile_loc,1,name,len) - if(trim(name)=='xaxis_1') nx_phy=len - if( nx_phy == nxcase )then - allocate(work_b_tmp(nxcase,nycase)) - countloc_tmp=(/nxcase,nycase,1/) - phy_smaller_domain = .false. - else - allocate(work_b_tmp(nxcase-6,nycase-6)) - countloc_tmp=(/nxcase-6,nycase-6,1/) - phy_smaller_domain = .true. - end if - startloc_tmp=(/1,1,ilev/) - end if + call mpi_allreduce(members,members_read,npe,mpi_integer,mpi_max,mpi_comm_world,ierror) - call check( nf90_inq_varid(gfile_loc,trim(varname),VarId) ) + nread=0 + mype_read_rank=-1 + do i=1,npe + if (members_read(i) >= 0) then + nread=nread+1 + mype_read_rank(nread) = members_read(i) + endif + enddo + call setcomm(iworld,iworld_group,nread,mype_read_rank,mpi_comm_read,ierror) - if(index(vgsiname,"delzinc") > 0) then - if(fv3_io_layout_y > 1) then + if (procuse) then + if(fv3_io_layout_y > 1) then + allocate(gfile_loc_layout(0:fv3_io_layout_y-1)) do nio=0,fv3_io_layout_y-1 - countloc=(/nxcase,ny_layout_len(nio),1/) - allocate(work_b_layout(nxcase,ny_layout_len(nio))) - call check( nf90_get_var(gfile_loc_layout(nio),VarId,work_b_layout,start = startloc, count = countloc) ) - work_b(:,ny_layout_b(nio):ny_layout_e(nio))=work_b_layout - deallocate(work_b_layout) + write(filename_layout,'(a,a,I4.4)') trim(filenamein),'.',nio + call check( nf90_open(filename_layout,nf90_write,gfile_loc_layout(nio),comm=mpi_comm_read,info=MPI_INFO_NULL) ) enddo - else - call check( nf90_get_var(gfile_loc,VarId,work_b,start = startloc, count = countloc) ) - endif - call fv3_ll_to_h(work_a(:,:),workb2,nloncase,nlatcase,nlon_regional,nlat_regional,grid_reverse_flag) - work_b(:,:)=work_b(:,:)+workb2(:,:) - else - if(add_saved)then - if(fv3_io_layout_y > 1) then + gfile_loc=gfile_loc_layout(0) + else + call check( nf90_open(filenamein,nf90_write,gfile_loc,comm=mpi_comm_read,info=MPI_INFO_NULL) ) + endif + + do ilevtot=kbgn,kend + vgsiname=grd_ionouv%names(1,ilevtot) + if(trim(vgsiname)=='amassi') cycle + if(trim(vgsiname)=='amassj') cycle + if(trim(vgsiname)=='amassk') cycle + if(trim(vgsiname)=='pm2_5') cycle + call getfv3lamfilevname(vgsiname,fv3filenamegin,filenamein2,varname) + if(trim(filenamein) /= trim(filenamein2)) then + write(6,*)'filenamein and filenamein2 are not the same as expected, stop' + call flush(6) + call stop2(333) + endif + ilev=grd_ionouv%lnames(1,ilevtot) + nz=grd_ionouv%nsig + nzp1=nz+1 + inative=nzp1-ilev + countloc=(/nxcase,nycase,1/) + startloc=(/1,1,inative/) + + work_a=hwork(1,:,:,ilevtot) + + if( trim(varname) == 'ref_f3d' )then + iret=nf90_inquire_dimension(gfile_loc,1,name,len) + if(trim(name)=='xaxis_1') nx_phy=len + if( nx_phy == nxcase )then + allocate(work_b_tmp(nxcase,nycase)) + countloc_tmp=(/nxcase,nycase,1/) + phy_smaller_domain = .false. + else + allocate(work_b_tmp(nxcase-6,nycase-6)) + countloc_tmp=(/nxcase-6,nycase-6,1/) + phy_smaller_domain = .true. + end if + startloc_tmp=(/1,1,ilev/) + end if + + call check( nf90_inq_varid(gfile_loc,trim(varname),VarId) ) + + + if(index(vgsiname,"delzinc") > 0) then + if(fv3_io_layout_y > 1) then + do nio=0,fv3_io_layout_y-1 + countloc=(/nxcase,ny_layout_len(nio),1/) + allocate(work_b_layout(nxcase,ny_layout_len(nio))) + call check( nf90_get_var(gfile_loc_layout(nio),VarId,work_b_layout,start = startloc, count = countloc) ) + work_b(:,ny_layout_b(nio):ny_layout_e(nio))=work_b_layout + deallocate(work_b_layout) + enddo + else + call check( nf90_get_var(gfile_loc,VarId,work_b,start = startloc, count = countloc) ) + endif + call fv3_ll_to_h(work_a(:,:),workb2,nloncase,nlatcase,nlon_regional,nlat_regional,grid_reverse_flag) + work_b(:,:)=work_b(:,:)+workb2(:,:) + else + if(add_saved)then + if(fv3_io_layout_y > 1) then + do nio=0,fv3_io_layout_y-1 + countloc=(/nxcase,ny_layout_len(nio),1/) + allocate(work_b_layout(nxcase,ny_layout_len(nio))) + call check( nf90_get_var(gfile_loc_layout(nio),VarId,work_b_layout,start = startloc, count = countloc) ) + work_b(:,ny_layout_b(nio):ny_layout_e(nio))=work_b_layout + deallocate(work_b_layout) + enddo + else + if( trim(varname) == 'ref_f3d' )then + work_b = 0.0_r_kind + call check( nf90_get_var(gfile_loc,VarId,work_b_tmp,start = startloc_tmp, count = countloc_tmp) ) + where(work_b_tmp < 0.0_r_kind) + work_b_tmp = 0.0_r_kind + end where + if(phy_smaller_domain)then + work_b(4:nxcase-3,4:nycase-3) = work_b_tmp + else + work_b(1:nxcase,1:nycase) = work_b_tmp + end if + else + call check( nf90_get_var(gfile_loc,VarId,work_b,start = startloc, count = countloc) ) + end if + endif + call fv3_h_to_ll(work_b(:,:),worka2,nlon_regional,nlat_regional,nloncase,nlatcase,grid_reverse_flag) +!!!!!!!! analysis_inc: work_a !!!!!!!!!!!!!!!! + work_a(:,:)=work_a(:,:)-worka2(:,:) + call fv3_ll_to_h(work_a(:,:),workb2,nloncase,nlatcase,nlon_regional,nlat_regional,grid_reverse_flag) + work_b(:,:)=work_b(:,:)+workb2(:,:) + else + call fv3_ll_to_h(work_a(:,:),work_b(:,:),nloncase,nlatcase,nlon_regional,nlat_regional,grid_reverse_flag) + endif + endif + if(fv3_io_layout_y > 1) then do nio=0,fv3_io_layout_y-1 countloc=(/nxcase,ny_layout_len(nio),1/) allocate(work_b_layout(nxcase,ny_layout_len(nio))) - call check( nf90_get_var(gfile_loc_layout(nio),VarId,work_b_layout,start = startloc, count = countloc) ) - work_b(:,ny_layout_b(nio):ny_layout_e(nio))=work_b_layout + work_b_layout=work_b(:,ny_layout_b(nio):ny_layout_e(nio)) + call check( nf90_put_var(gfile_loc_layout(nio),VarId,work_b_layout, start = startloc, count = countloc) ) deallocate(work_b_layout) - enddo - else - if( trim(varname) == 'ref_f3d' )then - work_b = 0.0_r_kind - call check( nf90_get_var(gfile_loc,VarId,work_b_tmp,start = startloc_tmp, count = countloc_tmp) ) - where(work_b_tmp < 0.0_r_kind) - work_b_tmp = 0.0_r_kind - end where - if(phy_smaller_domain)then - work_b(4:nxcase-3,4:nycase-3) = work_b_tmp - else - work_b(1:nxcase,1:nycase) = work_b_tmp - end if - else - call check( nf90_get_var(gfile_loc,VarId,work_b,start = startloc, count = countloc) ) - end if - endif - call fv3_h_to_ll(work_b(:,:),worka2,nlon_regional,nlat_regional,nloncase,nlatcase,grid_reverse_flag) -!!!!!!!! analysis_inc: work_a !!!!!!!!!!!!!!!! - work_a(:,:)=work_a(:,:)-worka2(:,:) - call fv3_ll_to_h(work_a(:,:),workb2,nloncase,nlatcase,nlon_regional,nlat_regional,grid_reverse_flag) - work_b(:,:)=work_b(:,:)+workb2(:,:) - else - call fv3_ll_to_h(work_a(:,:),work_b(:,:),nloncase,nlatcase,nlon_regional,nlat_regional,grid_reverse_flag) - endif - endif - if(fv3_io_layout_y > 1) then - do nio=0,fv3_io_layout_y-1 - countloc=(/nxcase,ny_layout_len(nio),1/) - allocate(work_b_layout(nxcase,ny_layout_len(nio))) - work_b_layout=work_b(:,ny_layout_b(nio):ny_layout_e(nio)) - call check( nf90_put_var(gfile_loc_layout(nio),VarId,work_b_layout, start = startloc, count = countloc) ) - deallocate(work_b_layout) - enddo - else - if( trim(varname) == 'ref_f3d' )then - if(phy_smaller_domain)then - work_b_tmp = work_b(4:nxcase-3,4:nycase-3) - else - work_b_tmp = work_b(1:nxcase,1:nycase) - end if - where(work_b_tmp < 0.0_r_kind) - work_b_tmp = 0.0_r_kind - end where - call check( nf90_put_var(gfile_loc,VarId,work_b_tmp, start = startloc_tmp, count = countloc_tmp) ) - deallocate(work_b_tmp) - else - call check( nf90_put_var(gfile_loc,VarId,work_b, start = startloc, count = countloc) ) - end if - endif - - enddo !ilevtotl loop - if(fv3_io_layout_y > 1) then - do nio=0,fv3_io_layout_y-1 - call check(nf90_close(gfile_loc_layout(nio))) - enddo - deallocate(gfile_loc_layout) - else - call check(nf90_close(gfile_loc)) + enddo + else + if( trim(varname) == 'ref_f3d' )then + if(phy_smaller_domain)then + work_b_tmp = work_b(4:nxcase-3,4:nycase-3) + else + work_b_tmp = work_b(1:nxcase,1:nycase) + end if + where(work_b_tmp < 0.0_r_kind) + work_b_tmp = 0.0_r_kind + end where + call check( nf90_put_var(gfile_loc,VarId,work_b_tmp, start = startloc_tmp, count = countloc_tmp) ) + deallocate(work_b_tmp) + else + call check( nf90_put_var(gfile_loc,VarId,work_b, start = startloc, count = countloc) ) + end if + endif + + enddo !ilevtotl loop + if(fv3_io_layout_y > 1) then + do nio=0,fv3_io_layout_y-1 + call check(nf90_close(gfile_loc_layout(nio))) + enddo + deallocate(gfile_loc_layout) + else + call check(nf90_close(gfile_loc)) + endif endif + + call mpi_barrier(mpi_comm_world,ierror) + deallocate(work_b,work_a) deallocate(workb2,worka2) - end subroutine gsi_fv3ncdf_write subroutine check(status) use kinds, only: i_kind From 91ca8985e8ef45b1d25c846b6c9384092c997216 Mon Sep 17 00:00:00 2001 From: Russ-Treadon-NOAA Date: Mon, 21 Aug 2023 14:38:49 +0000 Subject: [PATCH 39/44] modifications for acorn (wcoss2 test system) build using intel19 spack-stack (#447) --- modulefiles/gsi_common_wcoss2.lua | 35 ++++++++++++++++++++++++ modulefiles/gsi_wcoss2.lua | 45 +++++++++++-------------------- regression/regression_driver.sh | 2 ++ regression/regression_var.sh | 1 + ush/detect_machine.sh | 2 +- ush/sub_wcoss2 | 22 +++++++-------- 6 files changed, 64 insertions(+), 43 deletions(-) create mode 100644 modulefiles/gsi_common_wcoss2.lua diff --git a/modulefiles/gsi_common_wcoss2.lua b/modulefiles/gsi_common_wcoss2.lua new file mode 100644 index 0000000000..12d4efd5c6 --- /dev/null +++ b/modulefiles/gsi_common_wcoss2.lua @@ -0,0 +1,35 @@ +help([[ +Load common modules to build GSI on all machines +]]) + +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 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 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" +local ncdiag_ver=os.getenv("ncdiag_ver") or "1.1.1" + +load("netcdf-c") +load("netcdf-fortran") + +load("bufr/11.7.0") +load("bacio") +load("w3emc") +load("sp") +load("ip/3.3.3") +load("sigio") +load("sfcio") +load("nemsio") +load("wrf-io") +load("ncio") +load("crtm") +load(pathJoin("gsi-ncdiag",ncdiag_ver)) + diff --git a/modulefiles/gsi_wcoss2.lua b/modulefiles/gsi_wcoss2.lua index 652e0de1db..a225514e85 100644 --- a/modulefiles/gsi_wcoss2.lua +++ b/modulefiles/gsi_wcoss2.lua @@ -1,34 +1,21 @@ help([[ ]]) -local PrgEnv_intel_ver=os.getenv("PrgEnv_intel_ver") or "8.1.0" -local intel_ver=os.getenv("intel_ver") or "19.1.3.304" -local craype_ver=os.getenv("craype_ver") or "2.7.8" -local cray_mpich_ver=os.getenv("cray_mpich_ver") or "8.1.9" -local cmake_ver= os.getenv("cmake_ver") or "3.20.2" -local python_ver=os.getenv("python_ver") or "3.8.6" -local prod_util_ver=os.getenv("prod_util_ver") or "2.0.10" - -prepend_path("MODULEPATH", "/lfs/h1/emc/nceplibs/noscrub/hpc-stack/libs/hpc-stack/modulefiles/stack") -local hpc_ver=os.getenv("hpc_ver") or "1.2.0" -local hpc_intel_ver=os.getenv("hpc_intel_ver") or "19.1.3.304" -local hpc_cray_mpich_ver=os.getenv("hpc_cray_mpich_ver") or "8.1.9" - -load(pathJoin("PrgEnv-intel", PrgEnv_intel_ver)) -load(pathJoin("intel", intel_ver)) -load(pathJoin("craype", craype_ver)) -load(pathJoin("cray-mpich", cray_mpich_ver)) -load(pathJoin("cmake", cmake_ver)) -load(pathJoin("python", python_ver)) - -load(pathJoin("prod_util", prod_util_ver)) - -load(pathJoin("hpc", hpc_ver)) -load(pathJoin("hpc-intel", hpc_intel_ver)) -load(pathJoin("hpc-cray-mpich", hpc_cray_mpich_ver)) - -load("gsi_common") +load("PrgEnv-intel") +load("intel") +load("craype") +load("cray-mpich") +load("cmake") + +prepend_path("MODULEPATH", "/lfs/h1/emc/nceplibs/noscrub/Mark.Potts/spack-stack/spack-stack-1.4.1/envs/unified-dev-19/install/modulefiles/Core") +load("stack-intel") +load("stack-cray-mpich") +load("prod-util") +load("gsi_common_wcoss2") + +setenv("CC", "cc") +setenv("CXX", "CC") +setenv("FC", "ftn") pushenv("GSI_BINARY_SOURCE_DIR", "/lfs/h2/emc/global/noscrub/emc.global/FIX/fix/gsi/20230601") - -whatis("Description: GSI environment on WCOSS2") +whatis("Description: GSI environment on Hera with Intel Compilers") diff --git a/regression/regression_driver.sh b/regression/regression_driver.sh index e1d3b18dc7..821cc7cedb 100755 --- a/regression/regression_driver.sh +++ b/regression/regression_driver.sh @@ -35,9 +35,11 @@ for jn in `seq ${RSTART} ${REND}`; do if [ $jn -le 2 ]; then export scripts=${scripts_updat:-$scripts} export fixgsi=${fixgsi_updat:-$fixgsi} + export modulefiles=${modulefiles_updat:-$modulefiles} else export scripts=${scripts_contrl:-$scripts} export fixgsi=${fixgsi_contrl:-$fixgsi} + export modulefiles=${modulefiles_contrl:-$modulefiles} fi rm -f ${job[$jn]}.out diff --git a/regression/regression_var.sh b/regression/regression_var.sh index d94e53a04d..3176372a3b 100755 --- a/regression/regression_var.sh +++ b/regression/regression_var.sh @@ -14,6 +14,7 @@ if [ "$#" = 7 ] ; then export enkfexec_contrl=$7 export fixgsi="$gsisrc/fix" export scripts="$gsisrc/regression" + export modulefiles="$gsisrc/modulefiles" export ush="$gsisrc/ush" export cmaketest="true" export clean="false" diff --git a/ush/detect_machine.sh b/ush/detect_machine.sh index 776f7a0b86..6f0673ce29 100755 --- a/ush/detect_machine.sh +++ b/ush/detect_machine.sh @@ -3,7 +3,7 @@ case $(hostname -f) in adecflow0[12].acorn.wcoss2.ncep.noaa.gov) MACHINE_ID=wcoss2 ;; ### acorn - alogin0[12].acorn.wcoss2.ncep.noaa.gov) MACHINE_ID=wcoss2 ;; ### acorn + alogin0[1-3].acorn.wcoss2.ncep.noaa.gov) MACHINE_ID=wcoss2 ;; ### acorn clogin0[1-9].cactus.wcoss2.ncep.noaa.gov) MACHINE_ID=wcoss2 ;; ### cactus01-9 clogin10.cactus.wcoss2.ncep.noaa.gov) MACHINE_ID=wcoss2 ;; ### cactus10 dlogin0[1-9].dogwood.wcoss2.ncep.noaa.gov) MACHINE_ID=wcoss2 ;; ### dogwood01-9 diff --git a/ush/sub_wcoss2 b/ush/sub_wcoss2 index 57115ef7c6..f41fd305e9 100755 --- a/ush/sub_wcoss2 +++ b/ush/sub_wcoss2 @@ -115,6 +115,7 @@ echo "#PBS -j oe" >> $cfile echo "#PBS -A "$accnt >> $cfile echo "" >> $cfile +echo "set -x" >> $cfile echo "export OMP_NUM_THREADS=$threads" >> $cfile echo "export ntasks=$(( $nodes * $procs ))" >> $cfile echo "export ppn=$procs" >> $cfile @@ -123,19 +124,14 @@ echo "" >> $cfile echo ". "$(awk '{ print $1, $2, $3, $4, $5, $6, $7, $8, $9 }' $regdir/regression_var.out) >>$cfile echo "" >> $cfile -echo "module purge" >> $cfile -echo "module load envvar/1.0" >> $cfile -echo "module load PrgEnv-intel/8.2.0" >> $cfile -echo "module load intel/19.1.3.304" >> $cfile -echo "module load craype/2.7.13" >> $cfile -echo "module load cray-mpich/8.1.12" >> $cfile -echo "module load cray-pals/1.1.3" >> $cfile -echo "module load prod_util/2.0.14" >> $cfile -echo "module load prod_envir/2.0.6" >> $cfile -echo "module load crtm/2.4.0" >> $cfile -echo "module load cfp/2.0.4" >> $cfile -echo "module load netcdf/4.7.4" >> $cfile -echo "module list" >> $cfile +echo "module reset" >> $cfile +echo "module use $modulefiles" >> $cfile +echo "module load gsi_wcoss2" >> $cfile +echo "module load envvar/1.0" >> $cfile +echo "module load cray-pals/1.2.2" >> $cfile +echo "module -t list 2>&1 | while read line;do module show $line 2>&1 | sed -n -e '2p';done | sort" >> $cfile +echo "module avail" >> $cfile + echo "" >> $cfile cat $exec >> $cfile From 06ed4d7361fc986214d5c3ffe137ffdb809ade07 Mon Sep 17 00:00:00 2001 From: Russ-Treadon-NOAA Date: Mon, 21 Aug 2023 18:02:23 +0000 Subject: [PATCH 40/44] add version numbers to module loads in gsi_common_wcoss2.lua (#447) --- modulefiles/gsi_common_wcoss2.lua | 32 ++++++++++++++++--------------- 1 file changed, 17 insertions(+), 15 deletions(-) diff --git a/modulefiles/gsi_common_wcoss2.lua b/modulefiles/gsi_common_wcoss2.lua index 12d4efd5c6..1b2a88db92 100644 --- a/modulefiles/gsi_common_wcoss2.lua +++ b/modulefiles/gsi_common_wcoss2.lua @@ -2,11 +2,12 @@ help([[ Load common modules to build GSI on all machines ]]) -local netcdf_ver=os.getenv("netcdf_ver") or "4.7.4" +local netcdf_c_ver=os.getenv("netcdf_c_ver") or "4.9.2" +local netcdf_fortran_ver=os.getenv("netcdf_fortran_ver") or "4.6.0" 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 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" @@ -17,19 +18,20 @@ local ncio_ver=os.getenv("ncio_ver") or "1.1.2" local crtm_ver=os.getenv("crtm_ver") or "2.4.0" local ncdiag_ver=os.getenv("ncdiag_ver") or "1.1.1" -load("netcdf-c") -load("netcdf-fortran") +load(pathJoin("netcdf-c", netcdf_c_ver)) +load(pathJoin("netcdf-fortran", netcdf_fortran_ver)) -load("bufr/11.7.0") -load("bacio") -load("w3emc") -load("sp") -load("ip/3.3.3") -load("sigio") -load("sfcio") -load("nemsio") -load("wrf-io") -load("ncio") -load("crtm") + +load(pathJoin("bufr", bufr_ver)) +load(pathJoin("bacio", bacio_ver)) +load(pathJoin("w3emc", w3emc_ver)) +load(pathJoin("sp", sp_ver)) +load(pathJoin("ip", ip_ver)) +load(pathJoin("sigio", sigio_ver)) +load(pathJoin("sfcio", sfcio_ver)) +load(pathJoin("nemsio", nemsio_ver)) +load(pathJoin("wrf_io", wrf_io_ver)) +load(pathJoin("ncio", ncio_ver)) +load(pathJoin("crtm", crtm_ver)) load(pathJoin("gsi-ncdiag",ncdiag_ver)) From 1485b2075626c616b539e8abe501a82fd8f51004 Mon Sep 17 00:00:00 2001 From: "russ.treadon" Date: Mon, 11 Sep 2023 17:45:35 +0000 Subject: [PATCH 41/44] revert gsi_wcoss2.lua to develop (#447) --- modulefiles/gsi_wcoss2.lua | 32 ++++++++++++++++++-------------- 1 file changed, 18 insertions(+), 14 deletions(-) diff --git a/modulefiles/gsi_wcoss2.lua b/modulefiles/gsi_wcoss2.lua index a225514e85..1872f89d17 100644 --- a/modulefiles/gsi_wcoss2.lua +++ b/modulefiles/gsi_wcoss2.lua @@ -1,21 +1,25 @@ help([[ ]]) +local PrgEnv_intel_ver=os.getenv("PrgEnv_intel_ver") or "8.1.0" +local intel_ver=os.getenv("intel_ver") or "19.1.3.304" +local craype_ver=os.getenv("craype_ver") or "2.7.8" +local cray_mpich_ver=os.getenv("cray_mpich_ver") or "8.1.7" +local cmake_ver= os.getenv("cmake_ver") or "3.20.2" +local python_ver=os.getenv("python_ver") or "3.8.6" +local prod_util_ver=os.getenv("prod_util_ver") or "2.0.10" -load("PrgEnv-intel") -load("intel") -load("craype") -load("cray-mpich") -load("cmake") +load(pathJoin("PrgEnv-intel", PrgEnv_intel_ver)) +load(pathJoin("intel", intel_ver)) +load(pathJoin("craype", craype_ver)) +load(pathJoin("cray-mpich", cray_mpich_ver)) +load(pathJoin("cmake", cmake_ver)) +load(pathJoin("python", python_ver)) -prepend_path("MODULEPATH", "/lfs/h1/emc/nceplibs/noscrub/Mark.Potts/spack-stack/spack-stack-1.4.1/envs/unified-dev-19/install/modulefiles/Core") -load("stack-intel") -load("stack-cray-mpich") -load("prod-util") -load("gsi_common_wcoss2") +load(pathJoin("prod_util", prod_util_ver)) + +load("gsi_common") -setenv("CC", "cc") -setenv("CXX", "CC") -setenv("FC", "ftn") pushenv("GSI_BINARY_SOURCE_DIR", "/lfs/h2/emc/global/noscrub/emc.global/FIX/fix/gsi/20230601") -whatis("Description: GSI environment on Hera with Intel Compilers") + +whatis("Description: GSI environment on WCOSS2") From 7cb76d8b5e0bdd82b333eab789f7109d51336595 Mon Sep 17 00:00:00 2001 From: "russ.treadon" Date: Tue, 12 Sep 2023 14:59:39 +0000 Subject: [PATCH 42/44] update nemsio version in spack.yaml, clean up sub_wcoss2 (#447) --- ci/spack.yaml | 2 +- ush/sub_wcoss2 | 1 - 2 files changed, 1 insertion(+), 2 deletions(-) diff --git a/ci/spack.yaml b/ci/spack.yaml index 5d97fd48a0..0fc66547e5 100644 --- a/ci/spack.yaml +++ b/ci/spack.yaml @@ -15,7 +15,7 @@ spack: - ip@3.3.3 - sigio@2.3.2 - sfcio@1.4.1 - - nemsio@2.5.2 + - nemsio@2.5.4 - wrf-io@1.2.0 - ncio@1.1.2 - crtm@2.4.0 diff --git a/ush/sub_wcoss2 b/ush/sub_wcoss2 index f41fd305e9..f2df099f23 100755 --- a/ush/sub_wcoss2 +++ b/ush/sub_wcoss2 @@ -115,7 +115,6 @@ echo "#PBS -j oe" >> $cfile echo "#PBS -A "$accnt >> $cfile echo "" >> $cfile -echo "set -x" >> $cfile echo "export OMP_NUM_THREADS=$threads" >> $cfile echo "export ntasks=$(( $nodes * $procs ))" >> $cfile echo "export ppn=$procs" >> $cfile From 047001bbe8ba7c98ddf65eddcc13229059f9ee9b Mon Sep 17 00:00:00 2001 From: "russ.treadon" Date: Tue, 12 Sep 2023 15:06:03 +0000 Subject: [PATCH 43/44] remove gsi_common_wcoss2.lua since no longer used (#447) --- modulefiles/gsi_common_wcoss2.lua | 37 ------------------------------- 1 file changed, 37 deletions(-) delete mode 100644 modulefiles/gsi_common_wcoss2.lua diff --git a/modulefiles/gsi_common_wcoss2.lua b/modulefiles/gsi_common_wcoss2.lua deleted file mode 100644 index 1b2a88db92..0000000000 --- a/modulefiles/gsi_common_wcoss2.lua +++ /dev/null @@ -1,37 +0,0 @@ -help([[ -Load common modules to build GSI on all machines -]]) - -local netcdf_c_ver=os.getenv("netcdf_c_ver") or "4.9.2" -local netcdf_fortran_ver=os.getenv("netcdf_fortran_ver") or "4.6.0" - -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.2" -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 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" -local ncdiag_ver=os.getenv("ncdiag_ver") or "1.1.1" - -load(pathJoin("netcdf-c", netcdf_c_ver)) -load(pathJoin("netcdf-fortran", netcdf_fortran_ver)) - - -load(pathJoin("bufr", bufr_ver)) -load(pathJoin("bacio", bacio_ver)) -load(pathJoin("w3emc", w3emc_ver)) -load(pathJoin("sp", sp_ver)) -load(pathJoin("ip", ip_ver)) -load(pathJoin("sigio", sigio_ver)) -load(pathJoin("sfcio", sfcio_ver)) -load(pathJoin("nemsio", nemsio_ver)) -load(pathJoin("wrf_io", wrf_io_ver)) -load(pathJoin("ncio", ncio_ver)) -load(pathJoin("crtm", crtm_ver)) -load(pathJoin("gsi-ncdiag",ncdiag_ver)) - From dc96296fbc8ce736e24bf25f7e5a0bf3869eaf19 Mon Sep 17 00:00:00 2001 From: "russ.treadon" Date: Tue, 12 Sep 2023 16:06:15 +0000 Subject: [PATCH 44/44] generalize machine specific sub scripts to allow different modulefiles for updat and contrl ctest jobs (#447) --- ush/sub_cheyenne | 2 +- ush/sub_discover | 2 +- ush/sub_gaea | 2 +- ush/sub_hera | 2 +- ush/sub_jet | 2 +- ush/sub_orion | 2 +- 6 files changed, 6 insertions(+), 6 deletions(-) diff --git a/ush/sub_cheyenne b/ush/sub_cheyenne index cb671ce8c1..7389bfeb24 100644 --- a/ush/sub_cheyenne +++ b/ush/sub_cheyenne @@ -125,7 +125,7 @@ echo "" >>$cfile echo "cfile = $cfile" echo "source /glade/u/apps/ch/modulefiles/default/localinit/localinit.sh >> $cfile" echo "module purge" >> $cfile -echo "module use $gsisrc/modulefiles" >> $cfile +echo "module use $modulefiles" >> $cfile echo "module load gsi_cheyenne.intel" >> $cfile echo "module list" >> $cfile diff --git a/ush/sub_discover b/ush/sub_discover index 835cd37ace..583ffbef86 100755 --- a/ush/sub_discover +++ b/ush/sub_discover @@ -129,7 +129,7 @@ echo "export OMP_NUM_THREADS=$threads" >> $cfile echo "" >>$cfile echo ". "$(awk '{ print $1, $2, $3, $4, $5, $6, $7, $8, $9 }' $regdir/regression_var.out) >>$cfile echo "" >>$cfile -echo "module use -a $gsisrc/modulefiles" >> $cfile +echo "module use -a $modulefiles" >> $cfile echo "module load gsi_discover" >> $cfile echo "" >>$cfile echo "jobname=$jobname" >>$cfile diff --git a/ush/sub_gaea b/ush/sub_gaea index b00e547a6a..6fed1b3c10 100755 --- a/ush/sub_gaea +++ b/ush/sub_gaea @@ -128,7 +128,7 @@ echo ". "$(awk '{ print $1, $2, $3, $4, $5, $6, $7, $8, $9 }' $regdir/regression echo "" >>$cfile echo "source /lustre/f2/dev/role.epic/contrib/Lmod_init.sh" >> $cfile -echo "module use $gsisrc/modulefiles" >> $cfile +echo "module use $modulefiles" >> $cfile echo "module load gsi_gaea" >> $cfile echo "module list" >> $cfile echo "" >>$cfile diff --git a/ush/sub_hera b/ush/sub_hera index d904417190..610756af00 100755 --- a/ush/sub_hera +++ b/ush/sub_hera @@ -137,7 +137,7 @@ echo "" >>$cfile echo ". /apps/lmod/lmod/init/sh" >> $cfile echo "module purge" >> $cfile -echo "module use $gsisrc/modulefiles" >> $cfile +echo "module use $modulefiles" >> $cfile echo "module load gsi_hera.intel" >> $cfile echo "module list" >> $cfile echo "" >>$cfile diff --git a/ush/sub_jet b/ush/sub_jet index e45dcc0b3c..d30c566ce3 100755 --- a/ush/sub_jet +++ b/ush/sub_jet @@ -126,7 +126,7 @@ echo "" >>$cfile echo ". /apps/lmod/lmod/init/sh" >> $cfile echo "module purge" >> $cfile -echo "module use $gsisrc/modulefiles" >> $cfile +echo "module use $modulefiles" >> $cfile echo "module load gsi_jet" >> $cfile echo "module list" >> $cfile echo "" >>$cfile diff --git a/ush/sub_orion b/ush/sub_orion index 065e7c8ab0..1bcce5cc4f 100755 --- a/ush/sub_orion +++ b/ush/sub_orion @@ -126,7 +126,7 @@ echo "" >>$cfile echo ". /apps/lmod/lmod/init/sh" >> $cfile echo "module purge" >> $cfile -echo "module use $gsisrc/modulefiles" >> $cfile +echo "module use $modulefiles" >> $cfile echo "module load gsi_orion" >> $cfile echo "module list" >> $cfile echo "" >> $cfile